查看原文
其他

PostgreSQL小版本更新,17beta3,12将EOL

冯若航 非法加冯
2024-09-02

PostgreSQL全球开发组发布了所有受支持PG大版本的更新,包括16.4、15.8、14.13、13.16 和 12.20 版本,以及PostgreSQL 17 的第三个 beta 测试版。此次发布修复了1个安全漏洞和过去几个月报告的 55 个 BUG。

欲了解更多变更详情,请查阅发布说明[1]


PostgreSQL 12 终止支持通知

PostgreSQL 12将于2024年11月14日停止发布修复补丁。如果您在生产环境中运行PostgreSQL 12,我们建议您计划升级到更新的、受支持的 PostgreSQL 大版本。更多信息请参阅我们的版本政策[2]


安全问题

CVE-2024-7348[3]:在 pg_dump 期间替换PostgreSQL关系执行任意SQL

CVSS v3.1基础分值:8.8[4]

受影响的大版本范围:12 - 16。

能够创建和删除非临时对象的攻击者,在超级用户并发执行的 pg_dump 过程中有可能注入 SQL 代码,并由超级用执行。攻击涉及用视图或外部表替换序列或类似对象,这些对象将执行恶意代码。为防止此类攻击,引入了一个新的服务器参数 restrict_nonsystem_relation_kind,可以禁用非内置视图的展开以及访问外部表,并教授pg_dump在可用时设置它。请注意,只有当 pg_dump 和导出数据的 Server 版本都足够新,才能阻止此攻击。

PostgreSQL 项目感谢 Noah Misch 报告此问题。


错误修复和改进

此更新修复了过去几个月报告的55多个错误。以下列出的问题影响PostgreSQL 16。这些问题中的一些也可能影响其他受支持的PostgreSQL版本。

•修复了“合并右反连接”计划的错误结果,其中如果内部关系被知道具有唯一的连接键,当外部关系中存在重复的连接键时,合并可能会表现异常。•防止在VACUUM[5]中无限循环。•在ALTER TABLE DETACH ... PARTITION CONCURRENTLY[6]期间修复分区修剪设置。•修复在CALL[7]语句中用作参数的稳定函数的行为。•当在备用服务器上或在其他会话的临时序列上调用时,pg_sequence_last_value()现在返回NULL,而不是抛出错误。•修正websearch_to_tsquery()中忽略的操作符的解析。•在INSERT ... DEFAULT[8]中正确检查视图列的可更新性。•在ALTER TABLE ... SET LOGGED|UNLOGGED[9]期间锁定所拥有的序列。•如果排队的AFTER触发器不再存在,则不抛出错误。•当所需索引具有表达式或谓词时,例如通过可更新视图,修正INSERT ... ON CONFLICT[10]选择仲裁索引的问题。•拒绝修改另一个会话的临时表ALTER TABLE[11]•修正在CREATE TABLE ... LIKE STATISTICS[12]中对表达式的扩展统计信息的处理。•修正无法重新计算从MIN()MAX()聚合生成的子查询的问题。•禁止在位置参数中使用下划线。•避免在JIT内联的后端函数抛出错误时崩溃。•修正启动热备服务器时准备事务的子事务的处理。•防止逻辑复制槽的错误初始化。•修正逻辑复制WAL发送器在发布对行类型与表物理不同的分区表的更改时的内存泄漏。•禁止OpenSSL创建有状态的TLS会话票证。•修正PL/pgSQL[13]处理包含下划线的整数范围(例如,FOR i IN 1_001..1_002)的方式。•修正PL/Perl[14]与Perl 5.40之间的不兼容。•修正与递归PL/Python[15]函数和触发器相关的几个问题。•确保pg_restore -l[16]正确报告目录项的依赖关系。pg_stat_statements[17]现在为出现在SQL语言函数中的非SELECT/INSERT/UPDATE(实用)语句传递查询ID。•修正postgres_fdw[18]在将外部表映射到复杂远程视图时的问题。postgres_fdw[19]不再向远程服务器发送FETCH FIRST WITH TIES子句




更新

所有PostgreSQL更新版本都是累积的。与其他小版本一样,用户无需转储和重新加载数据库或使用pg_upgrade来应用此更新版本;您可以简单地关闭PostgreSQL并更新其二进制文件。

跳过一个或多个更新版本的用户可能需要执行额外的更新后步骤;请查阅早期版本的发布说明了解详细信息。

更多详情,请查阅发布说明[20]


关于PostgreSQL 17测试版的说明

此版本标志着PostgreSQL 17的第三个测试版本,并使社区更接近预计在第三季度末的正式发布。

本着开源PostgreSQL社区的精神,我们强烈鼓励您在您的系统上测试PostgreSQL 17的新功能,以帮助我们消除可能存在的错误或其他问题。虽然我们不建议您在生产环境中运行PostgreSQL 17 Beta 3,但我们鼓励您找到方法在此测试版上运行您的典型应用工作负载。

您的测试和反馈将帮助社区确保PostgreSQL 17版本符合我们交付世界上最先进的开源关系数据库的稳定、可靠版本的标准。请阅读有关我们的测试版测试过程[21]的更多信息以及您如何贡献:

https://www.postgresql.org/developer/beta/


升级到PostgreSQL 17 Beta 3

要从PostgreSQL的早期版本升级到PostgreSQL 17 Beta 3,您将需要使用类似于在PostgreSQL的主要版本之间升级的策略(例如pg_upgradepg_dump / pg_restore)。有关更多信息,请访问升级[22]文档部分。


自Beta 2以来的更改

PostgreSQL 17 Beta 3的修复和变更包括:

•将standby_slot_names参数重命名为synchronized_standby_slots。•几项SQL/JSON修复。•修复pg_combinebackup --clone。•修复pg_createsubscriber以适用于包含空格的数据库名称。•pg_createsubscriber现在在目标数据库上运行时删除预先存在的订阅。•在pg_upgrade期间检索订阅信息的效率提高。•在sslmode=prefer中修复TLS回退行为,当服务器在启动过程中发送错误时出错。•文档记录了在备用服务器上立即执行上一个备份后使用pg_basebackup增量备份时的错误案例。•修正pg_upgrade --transaction-size可能导致后端使用比预期多一个数量级的RAM的问题。

请参阅发布说明[23]以获取新功能和更改功能的完整列表,并查看PostgreSQL 17未决问题[24]以了解更多修复和变更详情。


测试错误和兼容性

每个PostgreSQL版本的稳定性很大程度上取决于您,社区,通过您的工作负载和测试工具测试即将发布的版本,以便在正式发布PostgreSQL 17之前发现错误和回归。由于这是一个测试版,数据库行为、功能详情和API的细微更改仍然是可能的。您的反馈和测试将帮助确定新功能的最终调整,因此请在近期进行测试。用户测试的质量有助于确定我们何时可以进行最终发布。

未决问题[25]的列表在PostgreSQL wiki中公开可见。您可以使用PostgreSQL网站上的此表格报告错误[26]

https://www.postgresql.org/account/submitbug/


References

[1] 发布说明: https://www.postgresql.org/docs/release/
[2] 版本政策: https://www.postgresql.org/support/versioning/
[3] CVE-2024-7348: https://www.postgresql.org/support/security/CVE-2024-7348/
[4] 8.8: https://nvd.nist.gov/vuln-metrics/cvss/v3-calculator?vector=AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
[5] VACUUMhttps://www.postgresql.org/docs/current/sql-vacuum.html
[6] ALTER TABLE DETACH ... PARTITION CONCURRENTLYhttps://www.postgresql.org/docs/current/sql-altertable.html
[7] CALLhttps://www.postgresql.org/docs/current/sql-call.html
[8] INSERT ... DEFAULThttps://www.postgresql.org/docs/current/sql-insert.html
[9] ALTER TABLE ... SET LOGGED|UNLOGGEDhttps://www.postgresql.org/docs/current/sql-altertable.html
[10] INSERT ... ON CONFLICThttps://www.postgresql.org/docs/current/sql-insert.html
[11] ALTER TABLEhttps://www.postgresql.org/docs/current/sql-altertable.html
[12] CREATE TABLE ... LIKE STATISTICShttps://www.postgresql.org/docs/current/sql-createtable.html
[13] PL/pgSQL: https://www.postgresql.org/docs/current/plpgsql.html
[14] PL/Perl: https://www.postgresql.org/docs/current/plperl.html
[15] PL/Python: https://www.postgresql.org/docs/current/plpython.html
[16] pg_restore -lhttps://www.postgresql.org/docs/current/app-pgrestore.html
[17] pg_stat_statementshttps://www.postgresql.org/docs/current/pgstatstatements.html
[18] postgres_fdwhttps://www.postgresql.org/docs/current/postgres-fdw.html
[19] postgres_fdwhttps://www.postgresql.org/docs/current/postgres-fdw.html
[20] 发布说明: https://www.postgresql.org/docs/release/
[21] 测试版测试过程: https://www.postgresql.org/developer/beta/
[22] 升级: https://www.postgresql.org/docs/17/static/upgrading.html
[23] 发布说明: https://www.postgresql.org/docs/17/release-17.html
[24] PostgreSQL 17未决问题: https://wiki.postgresql.org/wiki/PostgreSQL_17_Open_Items
[25] 未决问题: https://wiki.postgresql.org/wiki/PostgreSQL_17_Open_Items
[26] 报告错误: https://www.postgresql.org/account/submitbug/
[27] 下载: https://www.postgresql.org/download/
[28] 发布说明: https://www.postgresql.org/docs/release/
[29] 安全: https://www.postgresql.org/support/security/
[30] 版本政策: https://www.postgresql.org/support/versioning/
[31] 测试版测试信息: https://www.postgresql.org/developer/beta/
[32] PostgreSQL 17测试版发布说明: https://www.postgresql.org/docs/17/release-17.html
[33] PostgreSQL 17未决问题: https://wiki.postgresql.org/wiki/PostgreSQL_17_Open_Items
[34] 功能矩阵: https://www.postgresql.org/about/featurematrix/
[35] 提交错误: https://www.postgresql.org/account/submitbug/
[36] 在X/Twitter上关注@postgresql: https://twitter.com/postgresql
[37] 捐赠: https://www.postgresql.org/about/donate/
[38] pgsql-www@lists.postgresql.org: mailto:pgsql-www@lists.postgresql.org
[39] 邮件列表: https://www.postgresql.org/list/


数据库老司机

点一个关注 ⭐️,精彩不迷路

对 PostgreSQL 与 Pigsty 感兴趣的朋友

欢迎微信搜索 pigsty-cc加入 PGSQL 交流群

StackOverflow 2024调研:PostgreSQL已经超神了

PG隆中对,一个PG三个核,一个好汉三百个帮

憋大招,数据库全能王真的要来了。

PostgreSQL正在吞噬数据库世界

让PG停摆一周的大会:PGCon.Dev参会记

PGCon.Dev 扩展生态峰会小记 @ 温哥华

PostgreSQL 17 Beta1 发布!牙膏管挤爆了!

为什么PostgreSQL是未来数据的基石?

PostgreSQL is eating the database world

技术极简主义:一切皆用Postgres

PostgreSQL:世界上最成功的数据库

PostgreSQL 到底有多强?




继续滑动看下一个
非法加冯
向上滑动看下一个

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存