相关链接:
pgsql编译安装
pgBouncer连接池
pg_stat_statements 提供了跟踪服务器执行的所有 SQL 语句的规划和执行统计信息的方法。当 pg_stat_statements 处于活动状态时,它会跟踪服务器上所有数据库的统计信息。该模块收集到的统计数据可以通过一个名为 pg_stat_statements 的视图进行访问。
官方文档:pg_stat_statements文档
源码在pgsql包里就提供了,可以在编译pgsql的时候就安装,也可以随后编译
只需要编译这个组件就行,进入到解压的pgsql安装包目录
cd /usr/local/postgresql-xxx
该插件是自带的
cd contrib/pg_stat_statements
make && make install
默认编译安装后的目录为下面的,如果不是用的默认,使用find查找
vi /var/pgsqldata/postgresql.conf
找到 Add settings for extensions here,在下面写插件的参数
具体每条有说明
## 加载模块
shared_preload_libraries='pg_stat_statements'
## 跟踪IO消耗的时间
track_io_timing = on
## 单条SQL的最长长度
track_activity_query_size = 2048
## 最多保留多少条信息
pg_stat_statements.max = 10000
## 嵌套sql设置
## 参数值:all - (所有SQL), top-函数内的sql不被跟踪, none - (不跟踪)
pg_stat_statements.track = all
## 是否跟踪非DML语句
pg_stat_statements.track_utility = off
## 重启后是否保留统计信息
pg_stat_statements.save = on
systemctl restart pgsql
使用pgsql管理工具或者在psql命令行里输入
create extension pg_stat_statements;
上面的命令没有错误即说明没问题
启用后,需要在sql中查询结果
最耗IO的20条
select userid::regrole, dbid, query from pg_stat_statements order by (blk_read_time+blk_write_time)/calls desc limit 20;
最耗时的20条
select userid::regrole, dbid, query from pg_stat_statements order by mean_time desc limit 20;
最耗内存的20条
select userid::regrole, dbid, query from pg_stat_statements order by (shared_blks_hit+shared_blks_dirtied) desc limit 20;
最耗空间的20条
select userid::regrole, dbid, query from pg_stat_statements order by temp_blks_written desc limit 20;