1、pg_stat_database
成都創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的云溪網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!yzs=# select *from pg_stat_database;
-[ RECORD 1 ]--+------------------------------
datid | 13156 #數(shù)據(jù)庫(kù)的oid
datname | postgres #數(shù)據(jù)庫(kù)名
numbackends | 0 #訪問當(dāng)前數(shù)據(jù)庫(kù)的連接數(shù)量
xact_commit | 2357 #該數(shù)據(jù)庫(kù)事務(wù)提交總量:和下面的rollback和作為TPS統(tǒng)計(jì)
xact_rollback | 17 #該數(shù)據(jù)庫(kù)事務(wù)rollback總量,如果特別多,需要看業(yè)務(wù)是否有問題了
blks_read | 1946 #總磁盤物理讀的塊數(shù),這里的read可能是從 cache中讀取,如果很高需要結(jié)合blk_read_time看是否真的存在從磁盤讀取的情況
blks_hit | 103625 #從shared buffer命中塊數(shù)
tup_returned | 1413113 #對(duì)于表來(lái)說(shuō),是全表掃描的行數(shù);對(duì)于索引是通過(guò)索引返回的索引行數(shù),如果這個(gè)值明顯大于tup_fetched,說(shuō)明當(dāng)前數(shù)據(jù)庫(kù)存在大量的全表掃描。查看執(zhí)行計(jì)劃,這個(gè)是databas全局級(jí)別的
tup_fetched | 36041 #指通過(guò)索引返回的行數(shù)
tup_inserted | 104 #插入的行數(shù)
tup_updated | 0 #更新的行數(shù)
tup_deleted | 19 #刪除的行數(shù)
conflicts | 0 #與恢復(fù)沖突取消的查詢次數(shù),只會(huì)在備機(jī)上發(fā)生
temp_files | 0 #產(chǎn)生臨時(shí)文件的數(shù)量,如果這個(gè)值很高,需要調(diào)大work_mem
temp_bytes | 0 #臨時(shí)文件的大小
deadlocks | 0 #死鎖的數(shù)量,如果這個(gè)值很大說(shuō)明業(yè)務(wù)邏輯有問題
blk_read_time | 0 #數(shù)據(jù)庫(kù)中花費(fèi)在讀取文件的時(shí)間,這個(gè)值很高說(shuō)明內(nèi)存較小,需要頻繁從磁盤讀入數(shù)據(jù)文件
blk_write_time | 0 #數(shù)據(jù)庫(kù)中花費(fèi)在寫數(shù)據(jù)文件的時(shí)間,pg中臟頁(yè)一般寫入page cache,如果這個(gè)值較高,則說(shuō)明cache較小,操作系統(tǒng)的cache需要更積極的寫入
stats_reset | 2019-02-11 23:42:37.526743-08 #統(tǒng)計(jì)信息重置的時(shí)間
通過(guò)pg_stat_database可以大概了解數(shù)據(jù)庫(kù)的歷史情況。
比如tup_returned值明顯大于tup_fetched,歷史SQL語(yǔ)句很多是全表掃描,存在沒有使用索引的SQL,可結(jié)合pg_stat_statments查找慢SQL,也可結(jié)合pg_stat_user_table找全表掃描次數(shù)和行數(shù)最多的表;
通過(guò)看tup_updated很高,可以說(shuō)明數(shù)據(jù)庫(kù)有頻繁的更新,這個(gè)時(shí)候需要關(guān)注vaccum相關(guān)的指標(biāo)和長(zhǎng)事務(wù),如果沒有及時(shí)進(jìn)行垃圾回收,會(huì)引起表膨脹;
temp_files較高說(shuō)明存在很多排序,hash,或者聚合這種操作,可以增大work_mem減少臨時(shí)文件的產(chǎn)生,并且同時(shí)這些操作的性能也會(huì)有較大的提升。
2、pg_stat_user_tables
yzs=# select *from pg_stat_user_tables;
-[ RECORD 1 ]-------+------------------------------
relid | 16440 #表oid
schemaname | public #模式名
relname | t1 #表名
seq_scan | 50 #這個(gè)表進(jìn)行全表掃描的次數(shù)
seq_tup_read | 1867763 #全表掃描的數(shù)據(jù)行數(shù),如果這個(gè)值很大說(shuō)明操作這個(gè)表的SQL語(yǔ)句很可能是全表掃描,需要結(jié)合執(zhí)行計(jì)劃分析
idx_scan | #索引掃描的次數(shù)
idx_tup_fetch | #通過(guò)索引掃描返回的行數(shù)
n_tup_ins | 1130502 #插入的數(shù)據(jù)行數(shù)
n_tup_upd | 0 #更新的數(shù)據(jù)行數(shù)
n_tup_del | 81920 #刪除的數(shù)據(jù)行數(shù)
n_tup_hot_upd | 0 #hot update的數(shù)據(jù)行數(shù),這個(gè)值與n_tup_upd接近說(shuō)明更新性能較好,不需要更新索引
n_live_tup | 655366 #活的行數(shù)量
n_dead_tup | 0 #死記錄個(gè)數(shù)
n_mod_since_analyze | 6 #上次analyze的實(shí)際
last_vacuum | 2019-04-07 00:22:00.955542-07 #上次手動(dòng)vacuum的實(shí)際
last_autovacuum | #上次autovacuum的實(shí)際
last_analyze | #上次analyze時(shí)間
last_autoanalyze | 2019-04-07 00:26:07.668391-07 #上次自動(dòng)analyze時(shí)間
vacuum_count | 2 #vacuum次數(shù)
autovacuum_count | 0 #自動(dòng)vacuum次數(shù)
analyze_count | 0 #analyze次數(shù)
autoanalyze_count | 10 #自動(dòng)analyze次數(shù)
通過(guò)查詢pg_stat_user_tables,可以基本清除哪些表的全表掃描次數(shù)較多,表中DML哪種操作多,也可以了解垃圾數(shù)據(jù)的數(shù)量。
3、pg_stat_user_indexes
yzs=# select *from pg_stat_user_indexes;
-[ RECORD 1 ]-+----------
relid | 16447 #相關(guān)表的oid
indexrelid | 16450 #索引的oid
schemaname | public #模式名
relname | t3 #表名
indexrelname | t3_id_idx #索引名
idx_scan | 0 #通過(guò)索引掃描的次數(shù),如果該值很小,說(shuō)明該索引很少被用到,可以考慮刪除
idx_tup_read | 0 #通過(guò)任意索引方法返回的索引行數(shù)
idx_tup_fetch | 0 #通過(guò)索引方法返回的數(shù)據(jù)行數(shù)
可以知道當(dāng)前哪些索引頻繁使用,哪些是無(wú)效索引。無(wú)效索引可以刪除掉,減少磁盤空間的使用和提升insert、delete、update的性能。
4、pg_statio_user_tables
yzs=# select *from pg_statio_user_tables;
-[ RECORD 1 ]---+--------
relid | 16447
schemaname | public
relname | t3
heap_blks_read | 1 #從page cache或磁盤讀取表的塊數(shù)
heap_blks_hit | 1 #從shared buffer命中的塊數(shù)
idx_blks_read | 0 #從page cache或磁盤讀取的索引的塊數(shù)
idx_blks_hit | 0 #從shared buffer命中的索引塊數(shù)
toast_blks_read | #從page cache或磁盤讀取的toast表的塊數(shù)
toast_blks_hit | #在shared buffer中命中toast表的塊數(shù)
tidx_blks_read | #從page cache或者磁盤中讀入的toast表索引的塊數(shù)
tidx_blks_hit | #在shared buffer中命中toast表索引的塊數(shù)
如果heap_blks_read、idx_blks_read很高,說(shuō)明shared buffer較小,存在頻繁從磁盤或者page cache讀取到shared buffer中命中toast表的塊數(shù)。
5、?pg_stat_bgwriter
yzs=# select *from pg_stat_bgwriter;
-[ RECORD 1 ]---------+------------------------------
checkpoints_timed | 206 #指超過(guò)checkpoint_timeout的時(shí)間后觸發(fā)的檢查點(diǎn)次數(shù)
checkpoints_req | 8 #手動(dòng)觸發(fā)checkpoint或者因?yàn)閃AL文件數(shù)量達(dá)到max_wal_size時(shí)也會(huì)增加,如果這個(gè)值大于checkpoints_req說(shuō)明checkpoint_timeout設(shè)置的不合理
checkpoint_write_time | 306582 #從shared buffer 中write到page cache花費(fèi)的時(shí)間
checkpoint_sync_time | 367 #checkpoint調(diào)用fsync將臟數(shù)據(jù)刷到磁盤花費(fèi)的時(shí)間,如果這個(gè)值很長(zhǎng),容易造成IO抖動(dòng),需要增加checkpoint_timeout或者checkpoint_completion_target
buffers_checkpoint | 6671 #通過(guò)checkpoint寫入臟塊的數(shù)量
buffers_clean | 0 #通過(guò)bgwriter寫入塊的數(shù)量
maxwritten_clean | 0 #bgwriter超過(guò)bgwriter_lru_maxpages時(shí)停止的次數(shù),如果這個(gè)值很高,需要增加bgwriter_lru_maxpages
buffers_backend | 7953 #通過(guò)backend寫入的塊數(shù)量
buffers_backend_fsync | 0 #backend需要fsync的次數(shù)
buffers_alloc | 11613 #被分配的緩沖區(qū)數(shù)量
stats_reset | 2019-02-11 23:42:35.273758-08
通過(guò)這個(gè)視圖,可以判斷checkpoint以及max_wal_size是否合理
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。