一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - PostgreSQL - 關(guān)于PostgreSQL錯(cuò)誤日志與慢查詢?nèi)罩臼占?

關(guān)于PostgreSQL錯(cuò)誤日志與慢查詢?nèi)罩臼占?/h1>

2021-03-15 17:56207礦工 PostgreSQL

這篇文章主要介紹了關(guān)于PostgreSQL錯(cuò)誤日志與慢查詢?nèi)罩臼占?,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

PostgreSQL錯(cuò)誤日志慢查詢日志對(duì)于線上系統(tǒng)分析、問題預(yù)警、問題排查起到非常重要的作用,在此不做贅述。

此文檔記錄錯(cuò)誤日志與慢查詢?nèi)罩镜氖占?、分析與存儲(chǔ)展示的方法。

一、總體思路

 

PostgreSQL日志輸出可以配置多種多樣的格式,其中以csvlog格式輸出的日志信息最全面。但是CSV日志只能以本地文件的方式收集,不能直接寫入網(wǎng)絡(luò),實(shí)時(shí)上傳日志服務(wù)器。

日志收集:

PostgreSQL服務(wù)器分布在不同的機(jī)器,我們使用rsyslog客戶端-服務(wù)器的方式來收集日志到日志服務(wù)器。具體方法:在PostgreSQL服務(wù)器部署客戶端,在日志服務(wù)器部署服務(wù)器,客戶端監(jiān)控日志文件的變化,實(shí)時(shí)將新增日志上傳到服務(wù)器,服務(wù)器根據(jù)不同客戶端上傳的日志,分別記錄在不同的文件中。

此方法的好處是在PostgreSQL服務(wù)器本地可以保存一份原始的完整的csv日志,供全量信息查看與分析。

日志分析:

使用Logstash進(jìn)行日志分析,Logstash是一個(gè)開源數(shù)據(jù)收集引擎,具有實(shí)時(shí)管道功能。Logstash可以動(dòng)態(tài)地將來自不同文件的數(shù)據(jù)統(tǒng)一起來,進(jìn)行數(shù)據(jù)篩選清洗,并將數(shù)據(jù)標(biāo)準(zhǔn)化到你所選擇的目的地。

日志存儲(chǔ)展示:

使用傳統(tǒng)的Elasticsearch進(jìn)行數(shù)據(jù)存儲(chǔ),Kibana進(jìn)行數(shù)據(jù)展示。

二、rsyslog服務(wù)器端配置

 

新增以下內(nèi)容到rsyslog配置文件/etc/rsyslog.conf,并重啟rsyslog服務(wù)。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
$PreserveFQDN on   #用于正確的獲取主機(jī)名
$FileOwner root   #存儲(chǔ)的文件屬主
$FileGroup root   #文件屬主
$FileCreateMode 0644 #生成的文件權(quán)限
$DirCreateMode 0755 #生成的目錄權(quán)限
$Umask 0022
$PrivDropToUser root  #可以刪除日志的用戶
$PrivDropToGroup root  #可以刪除日志的用戶組
module(load="imuxsock")
module(load="imklog")
module(load="imudp")
#input(type="imudp" port="514")
module(load="imtcp" MaxSessions="500")
input(type="imtcp" port="514")?
$template linefmt,"%msg:2:$%\n"  #接收日志的格式(去掉開頭的空格)?
$template pgloglocation,"/data/pglogs/%hostname%/%$YEAR%-%$MONTH%-%$DAY%.csv"?
:rawmsg,contains,"pg_5432" ?pgloglocation;linefmt
##變量:%fromhost-ip%

三、rsyslog客戶端配置

 

新建配置文件/etc/rsyslog.d/10-pg.conf,并重啟rsyslog服務(wù)。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
cat /etc/rsyslog.d/10-pg.conf?
module(load="imuxsock")
module(load="imklog")
module(load="imfile")?
#module(load="imudp")
#input(type="imudp" port="514")?
module(load="imtcp" MaxSessions="500")
input(type="imtcp" port="514")?
ruleset(name="remote"){
    action(type="omfwd"
            target="x.x.x.x"  #日志服務(wù)器IP地址
            port="514"     #端口
            protocol="tcp"   #使用協(xié)議
            queue.type="linkedList" #使用異步處理
            queue.spoolDirectory="/var/log/rsyslog" #隊(duì)列目錄
            queue.fileName="pglog"         #隊(duì)列名稱
            queue.maxDiskSpace="1g"         #隊(duì)列占最大磁盤空間
            queue.saveOnShutdown="on"  #保存內(nèi)存數(shù)據(jù)如果rsyslog關(guān)閉
            action.resumeRetryCount="-1" #無限重試插入失敗
       )
    stop
}?
?
input(
 type="imfile"
 File="/pg/data/log/*.csv" #PG服務(wù)器日志路徑
 Facility="local1"
 Severity="info"
 Tag="pg_5432"       #定義日志標(biāo)簽,重要,服務(wù)端根據(jù)這個(gè)標(biāo)簽可以識(shí)別日志
 PersistStateInterval="1"  #回寫偏移量數(shù)據(jù)到文件間隔時(shí)間(秒),根據(jù)實(shí)際情況而定
 deleteStateOnFileDelete="on"
 reopenOnTruncate="on"
 Ruleset="remote"      #rsyslog.conf中定義的rule名稱
)

四、logstash配置

 

在日志服務(wù)器上編輯好配置文件后,啟動(dòng)logstash即可。配置文件如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
input {
 file {
  path => ["/data/pglogs/*/*.csv"]
  start_position => "end"
  codec => multiline {
   pattern => "^20[0-9]{2}-[0-9]{2}-[0-9]{2} [0-9]{2}:[0-9]{2}:[0-9]{2}"
   negate => true
   what => "previous"
  }
 }
}
?
filter {
 csv {
  separator => ","
  columns => ["log_time","user_name","database_name","process_id","connection_from","session_id","session_line_num","command_tag","session_start_time","virtual_transaction_id","transaction_id","error_severity","sql_state_code","message","detail","hint","internal_query","internal_query_pos","context","query","query_pos","location","application_name"]
  convert => {
   "process_id" => "integer"
   "session_line_num" => "integer"
   "transaction_id" => "integer"
   "internal_query_pos" => "integer"
   "query_pos" => "integer"
  }
  skip_empty_columns => true
 }
?
 mutate{
   split => { "log_time" => " CST" }
   add_field => { "log_time_tmp" => "%{[log_time][0]}" }
   remove_field => ["log_time"]
 }
?
 date {
   match => ["log_time_tmp", "yyyy-MM-dd HH:mm:ss.SSS"]
   target => "@timestamp"
   locale => "cn"
   remove_field => ["log_time_tmp"]
 }
?
 if "duration:" in [message] and "ms" in [message] and "statement:" in [message] {
  grok{
   match => { "message" => "duration: %{NUMBER:duration} ms" }
  }
  mutate{
   split => { "message" => "statement: " }
   add_field => { "statement" => "%{[message][1]}" }
   remove_field => ["message"]
  }
 }
 mutate{
  split => { "path" => "/" }
  add_field => { "db_host" => "%{[path][3]}" }
  remove_field => ["path", "host"]
  convert => { "duration" => "float" }
 }
}?
?
output {
 if [error_severity] == "ERROR" or [error_severity] == "FATAL" or [error_severity] == "PANIC" {
  elasticsearch {
   hosts => ["x.x.x.x:x", "x.x.x.x:x"]
   index => "pg_error"
   id => "elasticsearch_pg_error"
  }
 }else if [duration] and [statement] {
  elasticsearch {
   hosts => ["x.x.x.x:x", "x.x.x.x:x"]
   index => "pg_slow"
   id => "elasticsearch_pg_slow"
  }
 }
}

五、此處省略了Elasticsearch存儲(chǔ)與Kibana展示,這里不多介紹

補(bǔ)充:PostgreSQL開發(fā)者模式錯(cuò)誤反饋與日志設(shè)置

####when何時(shí)記錄

?
1
2
#client_min_messages = notice
log_min_messages = debug5 #debug級(jí)別是提供給開發(fā)人員使用的,這個(gè)可以看到程序調(diào)用的信息以及SQL轉(zhuǎn)化為數(shù)據(jù)結(jié)構(gòu)的信息,每分鐘的級(jí)別

####where記錄到哪里

?
1
2
3
4
#log_destination = 'stderr'
logging_collector = on  #打開日志收集
log_directory = 'pg_log' #日志目錄
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'

####what寫什么日志

?
1
2
3
4
5
6
7
8
debug_print_parse = on #解析樹
debug_print_rewritten = on #查詢重寫后的SQL
debug_print_plan = on  #執(zhí)行計(jì)劃詳細(xì)
debug_pretty_print = on #對(duì)debug_print_parse,debug_print_rewritten,debug_print_plan可讀性格式化
#log_checkpoints = off #如果是研究pg的磁盤IO,這個(gè)需要設(shè)置為on
log_connections = on #連接日志
log_disconnection = on #斷開連接日志
#log_duration=on #語句執(zhí)行時(shí)間,對(duì)于分析

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

原文鏈接:https://my.oschina.net/207miner/blog/3021932

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 草草视频免费观看 | 日本人成动漫网站在线观看 | 91精品国产品国语在线不卡 | 国产亚洲一区二区三区 | 91久久99热青草国产 | 日本xxx片免费高清在线 | 美女靠逼的视频 | 欧美一区精品二区三区 | 免费国产在线视频 | 亚洲国产AV无码综合在线 | 国产成人精品系列在线观看 | 国产一区二区免费福利片 | 亚洲精品国产A久久久久久 亚洲精品福利一区二区在线观看 | 99热这里只有精品久久免费 | 日日免费视频 | 欧美成人免费草草影院视频 | 欧美丝袜videohd | 日本大尺度动漫在线观看缘之空 | www毛片| 精品免费国产 | 欧美日韩亚洲成人 | 日本小视频网站 | 亚洲成人福利 | 免费看视频高清在线观看 | 成年性午夜免费视频网站不卡 | 日韩大片在线 | 波多野结衣护士 | 精品卡1卡2卡三卡免费网站 | 亚洲精品AV无码喷奶水糖心 | 处女摘花视频 | 极品手交handjobtattoo| 92精品国产成人观看免费 | 楚乔传第二部免费播放电视连续剧 | 国产精品中文 | 天堂8在线天堂资源在线 | 99久久精品免费看国产高清 | 俺去俺去啦最新官网在线 | 东方影视欧美天天影院 | 欧美理论片手机在线观看片免费 | 色哟约 | 8x8x丝袜美女 |