麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > 綜合 > 正文

PostgreSQL之查找最慢的SQL 的方法

2024-07-21 02:53:16
字體:
來源:轉載
供稿:網友

幫幫忙頂一下這個文章,非常好的一個文章,非常值得了解。

來自:http://blog.chinaunix.net/uid-24774106-id-3780341.html

PostgreSQL部署上之后,經過一段時間的運行,我們比較關心那些SQL運行時間比較長,或者說那些SQL執行的特別慢,拖累的性能,只有找到這些SQL,才能有針對性地對這些SQL進行優化,提升PostgreSQL的性能。   PostgreSQL提供了pg_stat_statements來存儲SQL的運行次數,總運行時間,shared_buffer命中次數,shared_buffer read次數等統計信息。

NameTypeReferencesDescription
useridoidpg_authid.oidOID of user who executed the statement
dbidoidpg_database.oidOID of database in which the statement was executed
querytext Text of the statement (up to track_activity_query_size bytes)
callsbigint Number of times executed
total_timedouble PRecision Total time spent in the statement, in seconds
rowsbigint Total number of rows retrieved or affected by the statement
shared_blks_hitbigint Total number of shared blocks hits by the statement
shared_blks_readbigint Total number of shared blocks reads by the statement
shared_blks_writtenbigint Total number of shared blocks writes by the statement
local_blks_hitbigint Total number of local blocks hits by the statement
local_blks_readbigint Total number of local blocks reads by the statement
local_blks_writtenbigint Total number of local blocks writes by the statement
temp_blks_readbigint Total number of temp blocks reads by the statement
temp_blks_writtenbigint Total number of temp blocks writes by the statemen
   上圖表來自PostgreSQL官方文檔,注意的一點是,我的PostgreSQL是9.1.9,此時total_time的單位是秒,我觀9.2的PostgreSQL的文檔,total_time單位已經是毫秒。所以我的參考文獻More On PostgreSQL perform 里面應該用的是9.2,因為外國這位大神默認單位是毫秒。   可以看出,pg_stat_statements統計了SQL的很多信息,方便我們分析SQL的性能。但是這個屬于PostgreSQL的擴展,需要修改postgresql.conf,才能使用:操作步驟如下    1 修改配置文件,并且重啟PostgreSQL方能生效

#------------------------------------------------------------------------------# PG_STAT_STATEMENTS OPTIONS#------------------------------------------------------------------------------shared_preload_libraries = 'pg_stat_statements'custom_variable_classes = 'pg_stat_statements'pg_stat_statements.max = 1000pg_stat_statements.track = all    2 創建pg_stat_statements擴展CREATE EXTENSION pg_stat_statements;    從此之后,PostgreSQL就能記錄SQL的統計信息。   上面的表格雖然豐富,其實我們基本比較關心執行最慢的SQL,如何查看執行最慢的10條SQL?SELECT  query, calls, total_time, (total_time/calls) as average ,rows,         100.0 * shared_blks_hit /nullif(shared_blks_hit + shared_blks_read, 0) AS hit_percent FROM    pg_stat_statements ORDER   BY average DESC LIMIT 10;    我在我本地的DB,查找最慢的2條SQL,輸出如下:      在我另一臺機器上,用pgadmin查看:       統計結果一直都在,重啟也不會清零,那么統計結果如何清零重新統計呢?執行下面SQL即可:select pg_stat_statements_reset() ;    找到最耗時的SQL,我們就能針對這些耗時的SQL,查看是否有優化的余地。參考文獻:1 More on Postgres Performance 2   PostgreSQL manual


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久国产综合精品 | 久国久产久精永久网页 | 久久成年网站 | 日本在线免费观看视频 | 丰满年轻岳中文字幕一区二区 | 伊人yinren22综合网色 | 韩国十九禁高潮床戏在线观看 | av免费片 | 草久视频在线观看 | 日韩视频―中文字幕 | 成人免费观看49www在线观看 | 久久综合久久综合久久综合 | 中文字幕亚洲一区二区三区 | 中文字幕在线日韩 | 99亚洲伊人久久精品影院红桃 | sese在线视频 | 日本在线播放一区二区三区 | 中文区永久区 | 久久亚洲精品久久国产一区二区 | 性欧美大战久久久久久久免费观看 | sese在线视频| 毛片在线免费播放 | 欧美亚洲国产一区二区三区 | 久久久久久久久久综合 | 久久草在线看 | 亚洲电影在线播放 | 香蕉视频99 | 精品久久久久久久 | 成人在线视频在线观看 | 欧美日韩一 | 欧美日韩高清在线观看 | 精品视频一区二区三区四区 | 久久丝袜脚交足黄网站免费 | 成年人精品视频 | 亚洲精品wwww| 欧美18—19sex性护士中国 | 欧美日韩爱爱视频 | 黄wwww| 免费色片 | 亚洲xxx在线观看 | 精品国内视频 |