PostgreSQL打印实时查询语句的三种方法

 更新时间:2025年09月09日 09:13:21   作者:Dontla  
这篇文章主要介绍了三种PostgreSQL实时打印查询的方法:1.通过日志配置记录所有SQL;2.利用pg_stat_activity监控活跃查询;3.使用pg_stat_statements分析历史性能,并提醒生产环境应避免全量记录以减少性能损耗,需要的朋友可以参考下

最后通过后端flask sqlalchemy开启SQLALCHEMY_ECHO每次数据库访问打印实现了:

方法 1:通过 PostgreSQL 日志实时查看

1. 修改 PostgreSQL 配置文件

docker-compose.yml 中挂载的 postgresql.conf 文件中,添加以下日志配置:

# 开启日志记录所有 SQL 语句
log_statement = 'all'

# 设置日志输出格式(推荐包含时间、进程 ID 等)
log_line_prefix = '%t [%p]: [user=%u,db=%d] '

# 开启日志收集器
logging_collector = on
log_directory = '/var/log/postgresql'
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'

2. 重启 PostgreSQL 容器

docker compose down
docker compose up -d

3. 实时查看日志

通过 docker logs 或直接访问挂载的日志目录实时查看:

# 方法 1:通过 docker logs 实时查看
docker compose logs -f postgres

# 方法 2:直接访问宿主机日志目录(假设日志挂载到 ./logs)
tail -f ./logs/postgresql-*.log

日志示例

2025-09-07 16:24:38.123 UTC [1234]: [user=postgres,db=postgres] LOG:  statement: SELECT * FROM my_table;

方法 2:通过 pg_stat_activity 实时监控

1. 查询实时执行的 SQL

定期执行以下 SQL 语句(可通过脚本或 watch 命令):

SELECT 
    pid, 
    usename, 
    query, 
    query_start, 
    now() - query_start AS duration
FROM 
    pg_stat_activity
WHERE 
    state = 'active' 
    AND query != '<IDLE>'
ORDER BY 
    query_start DESC;

2. 使用 watch 实时刷新

watch -n 1 "psql -U postgres -d postgres -c 'SELECT * FROM pg_stat_activity;'"

方法 3:使用 pg_stat_statements 扩展

1. 启用 pg_stat_statements

postgresql.conf 中添加:

shared_preload_libraries = 'pg_stat_statements'
pg_stat_statements.track = all

重启容器后执行:

CREATE EXTENSION pg_stat_statements;

2. 查询实时 SQL 统计

SELECT 
    query, 
    calls, 
    total_exec_time, 
    mean_exec_time
FROM 
    pg_stat_statements
ORDER BY 
    total_exec_time DESC
LIMIT 10;

注意事项

  1. 日志性能开销log_statement = 'all' 会记录所有 SQL,可能影响性能,建议仅用于调试。
  2. 日志轮转:通过 log_rotation_agelog_rotation_size 控制日志文件大小。
  3. 权限问题:确保挂载的日志目录(如 ./logs)有写入权限。
  4. 生产环境:建议仅记录慢查询(log_min_duration_statement)而非所有语句。

总结

  • 实时打印每条查询:使用 方法 1(日志记录)
  • 实时监控活跃查询:使用 方法 2(pg_stat_activity
  • 分析历史查询性能:使用 方法 3(pg_stat_statements

到此这篇关于PostgreSQL打印实时查询语句的三种方法的文章就介绍到这了,更多相关PostgreSQL打印查询语句内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL图(graph)的递归查询实例

    PostgreSQL图(graph)的递归查询实例

    这篇文章主要给大家介绍了关于PostgreSQL图(graph)的递归查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用PostgreSQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-12-12
  • postgresql使用dblink跨库增删改查的步骤

    postgresql使用dblink跨库增删改查的步骤

    这篇文章主要介绍了postgresql使用dblink跨库增删改查,本文给大家介绍的非常详细对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • postgresql使用filter进行多维度聚合的解决方法

    postgresql使用filter进行多维度聚合的解决方法

    这篇文章给大家介绍postgresql使用filter进行多维度聚合的解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-07-07
  • postgresql 实现取出分组中最大的几条数据

    postgresql 实现取出分组中最大的几条数据

    这篇文章主要介绍了postgresql 实现取出分组中最大的几条数据,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL大版本升级的详细流程

    PostgreSQL大版本升级的详细流程

    PostgreSQL版本发布规则,一年一个大版本,一个季度一个小版本;PG遇到的BUG问题,社区会很快进行修复,并在下一个版本中发布,因此有必要进行对数据库版本升级,本文给大家介绍了PostgreSQL大版本升级的详细流程,需要的朋友可以参考下
    2024-04-04
  • PostgreSQL13基于流复制搭建后备服务器的方法

    PostgreSQL13基于流复制搭建后备服务器的方法

    这篇文章主要介绍了PostgreSQL13基于流复制搭建后备服务器,后备服务器作为主服务器的数据备份,可以保障数据不丢,而且在主服务器发生故障后可以提升为主服务器继续提供服务。需要的朋友可以参考下
    2022-01-01
  • PostgreSQL 如何查找需要收集的vacuum 表信息

    PostgreSQL 如何查找需要收集的vacuum 表信息

    这篇文章主要介绍了PostgreSQL 如何查找需要收集的vacuum 表信息,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • PostgreSQL存储过程用法实战详解

    PostgreSQL存储过程用法实战详解

    这篇文章主要介绍了PostgreSQL存储过程用法,结合具体实例详细分析了PostgreSQL数据库存储过程的定义、使用方法及相关操作注意事项,并附带一个完整实例供大家参考,需要的朋友可以参考下
    2018-08-08
  • PostgreSQL流复制(主从复制)详细教程

    PostgreSQL流复制(主从复制)详细教程

    本文详细介绍了PostgreSQL流复制技术,流复制通过WAL日志实时同步主从库数据,支持异步和同步两种模式,具有一定的参考价值,感兴趣的可以了解一下
    2025-11-11
  • postgresql 中的参数查看和修改方式

    postgresql 中的参数查看和修改方式

    这篇文章主要介绍了postgresql 中的参数查看和修改方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论