PostgreSQL之查找最慢的SQL 的方法
来源:互联网 发布:数据流量怎么打开不了 编辑:程序博客网 时间:2024/05/01 02:21
帮帮忙顶一下这个文章,非常好的一个文章,非常值得了解。
来自: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次数等统计信息。
可以看出,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 = 1000
- pg_stat_statements.track = all
- CREATE EXTENSION pg_stat_statements;
上面的表格虽然丰富,其实我们基本比较关心执行最慢的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;
在我另一台机器上,用pgadmin查看:
统计结果一直都在,重启也不会清零,那么统计结果如何清零重新统计呢?执行下面SQL即可:
- select pg_stat_statements_reset() ;
参考文献:
1 More on Postgres Performance
2 PostgreSQL manual
0 0
- PostgreSQL之查找最慢的SQL 的方法
- 查找MySQL中查询慢的SQL语句的方法
- 查找运行速度慢的sql语句
- 如何找出执行最慢的SQL
- PostgreSQL模块 pg_stat_statements安装(慢sql原因查找)
- PostgreSQL修改sql表的方法汇总
- 查找写的最烂的SQL
- 解决SQL速度慢的方法
- mysql 分析查找执行效率慢的SQL语句
- mysql 分析查找执行效率慢的SQL语句
- mysql 分析查找执行效率慢的SQL语句
- 转载------mysql 分析查找执行效率慢的SQL语句
- mysql 分析查找执行效率慢的SQL语句
- postgresql查找字段空、不为空的方法总结
- 查找bad sql的方法
- 查找低劣的SQL方法
- 查找低劣的SQL方法
- 查找bad sql的方法
- java多图片上传功能的实现
- 北方大学训练赛,第一周
- 设计模式之外观模式(Facade)
- tomcat内存溢出解决办法
- hhtp 上传图片--使用MultipartEntity
- PostgreSQL之查找最慢的SQL 的方法
- C++各种调用各种报错........让我想起了一度被C++支配的恐怖
- 短信接口调用
- Wireshark网络分析实战笔记(二)显示过滤器
- [Thinking in Java]
- 使用Android Studio对Android应用打包签名
- 通向架构师的道路(第九天)之weblogic的集群与配置
- shell控制语句
- Java面试整理 关于集合