PostgreSQL版本策略

PostgreSQL 全球开发组计划每年发布一个包含新功能的主要版本(major version)。同时,对于每个主要版本,至少每 3 个月会发布一个次要版本(minor release),用于修复问题和安全漏洞。

当前最新的主要版本是 PostgreSQL 16,下一个主要版本是 PostgreSQL 17,预计 2024 年 9 月发布。当前最新的次要版本是 PostgreSQL 16.4,预计每年二月、五月、八月、十一月第二周的周四都会发布一个的次要版本。另外,如果发布团队认为一个关键 Bug 或者安全更新非常重要,无法等待预定的发布计划,可能会提前发布一个次要版本。

对于主要版本,PostgreSQL 全球开发组将会提供 5 年的更新支持,然后在发布一个最终次要版本之后停止提供支持。

正在开发的新功能可以通过 PostgreSQL WIKI 页面以及 CommitFest 列表查看。

版本编号

PostgreSQL 10 版本开始,主要版本的升级只会修改版本号中的第一部分,例如 PostgreSQL 10 升级为 PostgreSQL 11。在此之前,主要版本的变更涉及第一部分和第二部分,例如 PostgreSQL 9.5 升级为 PostgreSQL 9.6。

次要版本使用版本编号中的最后一部分数字表示。PostgreSQL 10 开始次要版本使用第二部分表示,例如 PostgreSQL 10.0 升级为 PostgreSQL 10.1;早期版本使用第三部分表示次要版本,例如 PostgreSQL 9.5.3 升级为 PostgreSQL 9.5.4。

版本升级

主要版本通常包含一些复杂的功能变更,数据目录的内容无法支持向后兼容,因此主要版本升级需要对数据库进行导出/导入操作,或者使用 pg_upgrade 进行升级。

推荐用户在升级主要版本之前阅读文档中关于升级部分的内容。PostgreSQL 支持跨主要版本升级,例如从 PostgreSQL 10 直接升级到 PostgreSQL 12,但是仍然推荐在升级之前查看所有跨越的主要版本的发行说明。

次要版本的升级相对简单,不需要进行导出/导入操作,用户只需要停止数据库服务,安装新版本软件,然后重启服务。有时候这种升级方式可能需要执行额外的操作,最好还是在升级之前阅读一下发行说明。

次要版本只包含频繁出现的 Bug、低风险修复、安全问题以及数据损坏问题,因此升级次要版本比继续使用旧版本风险更低,推荐使用主要版本的最新次要版本。

版本历史

主要版本 次要版本 是否支持 首次发布 最终发布
16 16.4 2023-09-14 2028-11-09
15 15.8 2022-10-13 2027-11-11
14 14.13 2021-09-30 2026-11-12
13 13.16 2020-09-24 2025-11-13
12 12.20 2019-10-03 2024-11-14
11 11.22 2018-10-18 2023-11-09
10 10.23 2017-10-05 2022-11-10
9.6 9.6.24 2016-09-29 2021-11-11
9.5 9.5.25 2016-01-07 2021-02-11
9.4 9.4.26 2014-12-18 2020-02-13
9.3 9.3.25 2013-09-09 2018-11-08
9.2 9.2.24 2012-09-10 2017-11-09
9.1 9.1.24 2011-09-12 216-10-27
9.0 9.0.23 2010-09-20 2015-10-08
相关推荐
jiayou643 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData15 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData20 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区5 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript