postgresql10中的pg_stat_statements

postgresql10中的pg_stat_statements

一、postgresql10中的pg_stat_statements

1.1 pg_stat_statements 是什么?

能够统计你SQL的执行统计信息,通俗来讲,能够统计慢查询的SQL。


1.2 pg_stat_statements 怎么用?

pg_stat_statements 做为插件,一定需要先安装,安装前需要确认你的环境。本人的环境

centos7、 PostgreSQL10

安装pg_stat_statements

postgresql10 安装 contrib 完成后,配置postgresql.conf 即可使用pg_stat_statements

  • 注意不同版本的PostgreSQL安装各不同,需要确认自己的版本。
  • 需要确认是否安装了contrib。
find / -name contrib
  • 如果没有安装contrib,则安装。安装之前需要确认查看版本
#sudo yum update 可以更新 yum
yum search contrib
  • 安装 contrib
# 安装对应版本
yum install postgresql10-contrib.x86_64
# 进入psql
sudo -u postgres psql
# 创建一个pg_trgm测试
create extension pg_trgm;
# 验证
\dT
# 退出
\q
  • 配置 postgresql.conf。配置完成需要重新启动
# postgresql.conf
# 修改postgresql.conf 该文件
vim /var/lib/pgsql/10/data/postgresql.conf

# 配置
shared_preload_libraries = 'pg_stat_statements'
pg_stat_statements.max = 10000
pg_stat_statements.track = all
  • 重新启动 pg
service postgresql-10 restart
# systemctl restart postgresql-10.service

1.2.2 在某个租户使用

  • 在某个具体的数据库安装扩展,这样就可以使用了pg_stat_statements

create extension pg_stat_statements; 

  • 查看慢SQL的语句,更多参数使用可以查看官网说明。

    在这里插入图片描述


     

可以灵活打印上面的参数。

select total_time / calls as avgtime, query,calls,rows
total_time,min_time,max_time,mean_time,stddev_time,
shared_blks_hit,shared_blks_read
from pg_stat_statements order by avgtime DESC limit 10 ;

在这里插入图片描述

注意是毫秒数,可以除以1000 转换成秒数。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值