其实很简单,最近可能需要对postgresql进行监控,所以接触了很多相关的监控命令和工具,这边文章主要是记录下工作过程,怕之后会忘记。我想要的功能:记录每条sql的执行时间,能够查询每天执行最慢的top10。下面先介绍下pg_stat_statements:(翻译)pg_stat_statements模块提供了一种跟踪执行的所有SQL语句的统计信息的方法。这个模块必须改写配置文件postgresql.conf中的shared_preload_libraries变量(之后讲解如何配置),这是因为他需要额外的共享内存。同时也意味着需要重启服务。1-先看下pg_stat_statements视图
| 字段名 | 类型 | 引用 | 说明 |
| userid | oid | pg_authid.oid | 执行者id |
| dbid | oid | pg_database.oid | 执行数据库id |
| query | text | | 执行的语句 |
| calls | bigint | | 执行次数 |
| total_time | double precision | | 执行总时间 (平均值=total_time/calls ) |
| rows | bigint | | 影响的总行数 |
| shared_blks_hit | bigint | | 共享块命中数量 |
| shared_blks_read | bigint | | 共享块读数量 |
| shared_blks_written | bigint | | 共享块写数量 |
| local_blks_hit | bigint | | 本地块命中数量 |
| local_blks_read | bigint | | 本地块读数量 |
| local_blks_written | bigint | | 本地块写数量 |
如上视图和函数pg_stat_statements_reset只有在数据库已经正确安装,并且已经执行pg_stat_statements.sql脚本后才会生效。只要pg_stat_statements成功添加,就会跟踪服务器上所有的数据库操作。处于安全的原因,普通用户不允许查看其他用户执行的语句信息(query),如果视图安装到他的数据库,那么就可以查看相关的统计信息(子健做的实验实在超级用户下:postgres用户postgres库)注意,如果语句信息(query)一样,不论任何out-of-line变量的值被使用,都会认为这几条声明是相同的。使用out-of-line变量有助于组织语句并且可能回事统计数据更加有用2-函数pg_stat_statements_reset() returns voidpg_stat_statements_reset丢弃目前由pg_stat_statements统计的所有信息,默认情况下,这个函数只能运行在超级用户下。3-配置变量pg_stat_statements.max(integer)pg_stat_statements.max是最大追踪的统计数据数量(即,视图中的最大行数)。如果数据量大于最大值,那么执行最少的语句将会被丢弃(本人测试,如果语句执行次数都为1时,其次是时间久的数据被丢弃),这个值默认是1000,这个变量在服务启动前设置。pg_stat_statements.track(enum)pg_stat_statements.track控制统计数据规则,top用于追踪top-level statement(直接由客户端方发送的),all还会追踪嵌套的statements(例如在函数中调用的statements)pg_stat_statements.track_utility(boolen)pg_stat_statements.track_utility控制是否跟踪公共程序命令(utility commands),公共程序命令是SELECT/INSERT/UPDATE/DELETE以外的命令,默认值是开启,只有超级用户可以更改此设置。pg_stat_statements.save(boolean)pg_stat_statements.save指定在服务器关闭时,是否保存统计信息。如果设置off,服务关闭时,统计信息将不会保存。默认值是on。这个值只能够在postgresql.conf中或者命令行设置。
PostgreSQL开源监控工具——pgwatch详细安装和测试ERROR 1045 (28000): Access denied for user "root"@"localhost" (using password: NO)相关资讯 PostgreSQL教程 pg_stat_statements
- PostgreSQL 列所有表结构的查询语 (02/18/2013 08:37:22)
- 循序渐进PostgreSQL: 学习pqxx C++ (12/08/2012 11:25:13)
- PostgreSQL集群方案hot standby初 (07/10/2012 09:42:30)
| - PostgresQL中的NUlls first/last功 (01/20/2013 11:55:23)
- PostgreSQL 堆分配器mmgr详解 (09/12/2012 09:33:05)
- PostgreSQL数据库压力测试工具 (07/09/2012 19:47:31)
|
本文评论 查看全部评论 (0)