PostgreSQL日志分析工具——pgBadger

摘要

之前曾介绍过PostgreSQL的日志审计,这会将执行的SQL输出到服务日志(pg_log),势必会带来性能问题,真正的问题是,这些记录对我们有多少帮助?所以我们来看一下如何使用增加的日志记录来做一些有用的事情。

pg_stat_statements 不仅输出SQL语句,还可以输出执行时间等,通过分析此服务器日志,可以知道执行什么样的SQL,以及缩小范围找到哪些SQL有可能出现性能问题。

SQL日志分析工具pgBadger

pgBadger 主页:home 下载地址:download

pgBadger是在Perl中创建的一个脚本,与PHP脚本中开发的名为pgFouine的程序具有相同的功能。 在命令行上指定并执行服务器日志时,会生成一个将服务器日志分析为HTML文件的报告。

此外,它不仅收集SQL,还收集服务器日志中的错误日志等。

环境

CentOS 6.9、PostgreSQL9.5.9、pgBadger 9.2

安装pgBadger

  1. tar zxvf pgbadger-9.2.tar.gz 
  2. cd pgbadger-9.2 
  3. [root@localhost pgbadger-9.2]# ll 
  4. total 1416 
  5. drwxr-xr-x. 8 root root    4096 Sep 11 01:13 blib 
  6. -rw-rw-r--. 1 root root   94609 Jul 28 07:45 ChangeLog 
  7. -rw-rw-r--. 1 root root     347 Jul 28 07:45 CONTRIBUTING.md 
  8. drwxrwxr-x. 2 root root    4096 Jul 28 07:45 doc 
  9. -rw-rw-r--. 1 root root     903 Jul 28 07:45 LICENSE 
  10. -rw-r--r--. 1 root root   24018 Sep 11 01:13 Makefile 
  11. -rw-rw-r--. 1 root root    1400 Jul 28 07:45 Makefile.PL 
  12. -rw-rw-r--. 1 root root      81 Jul 28 07:45 MANIFEST 
  13. -rw-rw-r--. 1 root root     334 Jul 28 07:45 META.yml 
  14. -rw-rw-r--. 1 root root 1256247 Jul 28 07:45 pgbadger 
  15. -rw-r--r--. 1 root root       0 Sep 11 01:13 pm_to_blib 
  16. -rw-rw-r--. 1 root root   30799 Jul 28 07:45 README 
  17. drwxrwxr-x. 3 root root    4096 Jul 28 07:45 resources 
  18. drwxrwxr-x. 2 root root    4096 Jul 28 07:45 tools 
  19.  
  20. perl Makefile.PL 
  21.  
  22. make; 
  23.  
  24. make install;  

查看安装版本

  1. [root@localhost pgbadger-9.2]# which pgbadger 
  2. /usr/local/bin/pgbadger 
  3. [root@localhost pgbadger-9.2]# pgbadger -V 
  4. pgBadger version 9.2  

PostgreSQL配置

  1. logging_collector = on 
  2. log_filename = 'postgresql-%w.log' 
  3. log_file_mode = 0640 
  4. log_truncate_on_rotation = on 
  5. log_rotation_age = 1d 
  6. log_min_duration_statement = 0 
  7. log_checkpoints = on 
  8. log_connections = on 
  9. log_disconnections = on 
  10. log_duration = on 
  11. log_lock_waits = on 
  12. log_line_prefix = '%t [%p]: [%l-1] user=%u,db=%d '  

安装httpd、php

  1. yum install httpd 
  2. chkconfig httpd on 
  3. service httpd start 
  4. yum install php  

查看/var/www

  1. [root@localhost www]# pwd 
  2. /var/www 
  3. [root@localhost www]# ll 
  4. total 20 
  5. drwxr-xr-x. 2 root root 4096 Aug 15 15:45 cgi-bin 
  6. drwxr-xr-x. 3 root root 4096 Sep 11 02:23 error 
  7. drwxr-xr-x. 2 root root 4096 Sep 11 03:43 html 
  8. drwxr-xr-x. 3 root root 4096 Sep 11 02:23 icons 
  9. drwxr-xr-x. 3 root root 4096 Sep 11 04:33 pgbadger  

日志分析

  1. ./pgbench -i 
  2. ./pgbench -c 10 -t 1000 
  3.  
  4. [root@localhost ~]# pgbadger /opt/postgres/db/pgsql-9.5.9/data/pg_log/*.log -o /var/www/pgbadger/out.html -f stderr 
  5. [========================>] Parsed 10485802 bytes of 10485802 (100.00%), queries: 65341, events: 2 
  6. [========================>] Parsed 755640 bytes of 755640 (100.00%), queries: 70036, events: 2 
  7. LOG: Ok, generating html report... 
  8. [root@localhost ~]#   

在浏览器打开/var/www/pgbadger/out.html

 

 

 

连续日志分析(增量模式)

增量模式用于连续获取分析结果。

以增量模式执行pgBadger会在第二天创建下一个报告(增量报告)。

  1. [root@localhost ~]# pgbadger -I /opt/postgres/db/pgsql-9.5.9/data/pg_log/*.log -o /var/www/pgbadger/out.html -f stderr 
  2. [========================>] Parsed 1499636 bytes of 1499636 (100.00%), queries: 0, events: 0 
  3. [========================>] Parsed 10485846 bytes of 10485846 (100.00%), queries: 65379, events: 0 
  4. [========================>] Parsed 743891 bytes of 743891 (100.00%), queries: 4625, events: 0 
  5. LOG: Ok, generating HTML daily report into /var/www/pgbadger//2017/09/11/... 
  6. LOG: Ok, generating HTML daily report into /var/www/pgbadger//2017/09/12/... 
  7. LOG: Ok, generating HTML weekly report into /var/www/pgbadger//2017/week-38/... 
  8. LOG: Ok, generating global index to access incremental reports... 
  9.  
  10. [root@localhost ~]# ll /var/www/pgbadger/ 
  11. total 692 
  12. drwxr-xr-x. 4 root root   4096 Sep 11 21:09 2017 
  13. -rw-r--r--. 1 root root 695474 Sep 12 21:15 index.html 
  14. -rw-r--r--. 1 root root    187 Sep 12 21:15 LAST_PARSED 
  15. drwxrwxrwx. 6 1107 1107   4096 Aug 28 17:44 postgresql-9.5.9 
  16. [root@localhost ~]# ll /var/www/pgbadger/2017/ 
  17. total 8 
  18. drwxr-xr-x. 4 root root 4096 Sep 12 21:15 09 
  19. drwxr-xr-x. 2 root root 4096 Sep 11 21:09 week-38 
  20. [root@localhost ~]#   

这里创建一个具有年份的目录,链接所有报告的索引页面以及保存最后一个解析行的文件。

以增量模式创建报表时,会创建链接每个报表页面的索引页(index.html)。

 

总结

pgBadger是一个完美的分析工具,旨在提高数据库的性能,因为它具有丰富的统计结果。

当你不知道PostgreSQL性能坏的原因,如果你认为查询执行时间是可疑的,可以尝试使用它。 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/230900.html<

(0)
运维的头像运维
上一篇2025-04-19 11:02
下一篇 2025-04-19 11:03

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注