news 2026/6/25 23:10:13

别让 PG 背锅:一次真实慢查询的 7 步排查记录

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
别让 PG 背锅:一次真实慢查询的 7 步排查记录

问题定位与解决方案

慢查询问题定位慢查询主要出现在以下SQL语句:

SELECT o.id, o.amount, u.nick FROM orders o JOIN users u ON u.id = o.user_id WHERE o.status = 'PAID' AND o.pay_time >= '2025-12-17 00:00:00' ORDER BY o.id DESC LIMIT 20;

执行时间为38秒,问题根源在于索引未有效过滤数据,导致全表扫描。

执行计划分析通过EXPLAIN (ANALYZE, BUFFERS)分析执行计划:

Limit (cost=0.56..2923.45 rows=20 width=48) (actual time=38042.213..38042.215 rows=20 loops=1) -> Nested Loop (cost=0.56..2342342.11 rows=16043 width=48) -> Index Scan Backward using orders_pkey on orders o (cost=0.56..823234.22 rows=16043 width=32) Filter: ((status = 'PAID'::order_status) AND (pay_time >= '2025-12-17 00:00:00'::timestamp)) Rows Removed by Filter: 12345678 -> Index Scan using users_pkey on users u (cost=0.56..8.77 rows=1 width=24) Index Cond: (id = o.user_id) Buffers: shared hit=52346 read=1234567 I/O Timings: read=30452.123

关键问题在于Rows Removed by Filter: 12345678,说明索引未有效过滤数据。

索引优化方案现有索引:

\d orders Indexes: "orders_pkey" PRIMARY KEY, btree (id) "idx_orders_status" btree (status) "idx_orders_paytime" btree (pay_time)

优化方案是创建复合索引:

CREATE INDEX CONCURRENTLY idx_orders_status_paytime_id ON orders (status, pay_time DESC, id DESC);

优化后执行计划:

Limit (cost=0.56..12.34 rows=20 width=48) (actual time=0.381..0.389 rows=20 loops=1) -> Index Scan using idx_orders_status_paytime_id on orders o ... Index Cond: ((status = 'PAID'::order_status) AND (pay_time >= '2025-12-17 00:00:00'::timestamp)) Buffers: shared hit=64

执行时间从38秒降至0.38毫秒。

参数优化调整以下参数以进一步提升性能:

ALTER SYSTEM SET random_page_cost = 1.1; ALTER SYSTEM SET work_mem = '32MB'; SELECT pg_reload_conf();

验证与效果优化后SQL平均执行时间从28秒降至0.4毫秒,QPS回升至1.9万。

常用诊断SQL

-- 当前活跃慢查询 SELECT pid, now()-xact_start, left(query,120) FROM pg_stat_activity WHERE state='active' AND now()-xact_start > interval '3 s'; -- 表+索引大小 SELECT relname, pg_size_pretty(pg_total_relation_size(relid)) FROM pg_catalog.pg_statio_user_tables ORDER BY pg_total_relation_size(relid) DESC LIMIT 10; -- 未使用的索引 SELECT schemaname, relname, indexrelname, idx_scan FROM pg_stat_user_indexes WHERE idx_scan=0;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 20:37:03

低代码资源合集

mksz824-真实高质量低代码商业项目,前端后端运维管理系统 文件大小: 27.0GB内容特色: 27GB全栈低代码商业项目源码与运维脚本适用人群: 想快速落地企业级系统的开发者核心价值: 拿来即用,省80%编码量,附上线部署手册下载链接: https://pan.q…

作者头像 李华
网站建设 2026/6/25 3:28:31

为什么你的Open-AutoGLM跑不起来?可能是requirements.txt少了这4个包

第一章:Open-AutoGLM requirements.txt 配置在构建 Open-AutoGLM 项目时,requirements.txt 文件是管理 Python 依赖的核心组件。该文件定义了项目运行所需的所有第三方库及其版本约束,确保开发、测试与生产环境的一致性。依赖项声明规范 所有…

作者头像 李华
网站建设 2026/6/25 15:24:32

为什么90%的比价项目都失败了?Open-AutoGLM避坑指南大公开

第一章:为什么90%的比价项目都失败了?在电商与价格敏感型应用激增的背景下,比价系统看似是技术实现中的“简单项目”。然而,实际落地时,超过九成的比价项目在6个月内停止维护或彻底失败。根本原因并非技术门槛过高&…

作者头像 李华
网站建设 2026/6/25 15:18:34

从零构建统计学核心:Python 实现 PDF、CDF 与逆向采样

这是一部关于如何从零构建统计学核心算法的深度技术指南。 为了真正达到“通俗易懂”且“内容详实”的要求,我将这篇内容扩展为六个核心章节。我们将不仅仅停留在代码层面,而是深入到数学直觉、算法原理、工程实现以及实际应用场景中。 我们将以书中的“…

作者头像 李华