0

0

SQL PostgreSQL 的 parallel_setup_cost / parallel_tuple_cost 的并行查询阈值调优

冷炫風刃

冷炫風刃

发布时间:2026-02-24 21:25:02

|

962人浏览过

|

来源于php中文网

原创

postgresql并行查询未启用的主因是parallel_setup_cost默认值1000.0过高,导致规划器放弃并行;需调低至50.0~200.0,并配合parallel_tuple_cost下调及满足硬性条件(如max_parallel_workers_per_gather>0、无for update等)才能生效。

sql postgresql 的 parallel_setup_cost / parallel_tuple_cost 的并行查询阈值调优

parallel_setup_cost 太高导致并行根本没启用

PostgreSQL 并行查询不是“写了 SELECT 就自动并行”,它得先算一笔账:启动并行的开销(parallel_setup_cost)是否值得。默认值是 1000.0,对中小查询来说太高了—— planner 一看“光 setup 就要 1000”,干脆单线程跑完拉倒。

常见错误现象:EXPLAIN 显示计划里完全没有 GatherGather Merge 节点,哪怕表有几千万行、CPU 闲着、max_parallel_workers_per_gather 也设了 4。

  • 调低到 50.0200.0 是更现实的起点(SSD + 多核机器可往低走)
  • 别全局改:只在慢查询前加 SET LOCAL parallel_setup_cost = 50.0; 测试效果
  • 注意:这个值单位是“规划器成本单位”,和 seq_page_cost 同量纲,不是毫秒

parallel_tuple_cost 影响并行扫描的“性价比”判断

parallel_tuple_cost 控制的是:从并行 worker 拿回一条元组的代价。默认 0.1,比单进程的 cpu_tuple_cost(默认 0.01)高 10 倍——planner 默认认为跨进程传数据很贵。

Peppertype.ai
Peppertype.ai

高质量AI内容生成软件,它通过使用机器学习来理解用户的需求。

下载

使用场景:当你的表宽很窄(比如只有 2–3 个 int 字段),或用 SSD+NVMe,网络/共享内存延迟极低时,这个默认值就太保守了。

  • 可尝试降到 0.020.05,尤其配合 parallel_setup_cost 下调后效果更明显
  • 别设成 0.0:会导致 planner 过度激进,小结果集也硬上并行,反而因调度开销变慢
  • 该参数对索引扫描无效——它只影响顺序扫描(Seq Scan)和位图堆扫描(Bitmap Heap Scan)的并行决策

为什么调了参数还是不并行?检查这几个硬性条件

即使 parallel_setup_costparallel_tuple_cost 都调得很激进,并行也可能被拦在门外。这不是参数问题,而是 PostgreSQL 的硬约束。

  • max_parallel_workers_per_gather 必须 > 0(默认是 2,但有些云厂商 RDS 默认关成 0)
  • 查询不能含不支持并行的节点:比如 FOR UPDATE、窗口函数带 RANGE、某些 CTE、或自定义聚合函数未标记 PARALLEL SAFE
  • 目标表必须是普通表(不是视图、物化视图、分区表的父表);且 relpages 统计值不能为 0(VACUUMANALYZE 没跑过会卡住)
  • 如果用了 LIMIT,planner 可能预判“取前 10 行没必要并行”,此时加 OFFSET 0 有时能绕过误判(但非常规手段)

生产环境调参的真实节奏

这两个 cost 参数不是“设一次就稳了”的开关。实际负载中,同一条 SQL 在不同数据量、不同并发压力下,最优值可能差一倍。

  • 优先在 EXPLAIN (ANALYZE, BUFFERS) 确认并行已生效的前提下微调,而不是凭空压低
  • 不要在 postgresql.conf 全局修改:用 ALTER DATABASE ... SET 或连接级 SET 更可控
  • 最易被忽略的一点:parallel_setup_costparallel_tuple_cost 的作用是“让 planner 更愿意选并行”,但最终是否提速,取决于实际 I/O 吞吐、worker 间数据倾斜、以及你的查询是否真能被拆分——比如一个 GROUP BY 聚合字段基数极低,所有 worker 全往同一个 hash bucket 里塞数据,那并行反而更慢

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1027

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

379

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1822

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

377

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1394

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

437

2024.04.29

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号