【PGCCC】PostgreSQL 17 发布!

PostgreSQL全球开发小组 9.26日发布PostgreSQL 17,这是世界上最先进的开源数据库的最新版本。

PostgreSQL 17 以数十年的开源开发为基础,在适应新兴数据访问和存储模式的同时,提高了性能和可扩展性。PostgreSQL 的此版本显著提高了整体性能,包括彻底改进的真空内存管理实现、存储访问优化和高并发工作负载改进、批量加载和导出加速以及索引查询执行改进。PostgreSQL 17 具有使全新工作负载和关键系统都受益的功能,例如,增加了使用 SQL/JSONJSON_TABLE命令的开发人员体验,以及增强了逻辑复制,从而简化了高可用性工作负载和主要版本升级的管理。

PostgreSQL 核心团队成员 Jonathan Katz 表示:“PostgreSQL 17 凸显了推动 PostgreSQL 发展的全球开源社区如何构建增强功能,帮助用户在数据库旅程的各个阶段。”“无论是大规模操作数据库的改进,还是建立在令人愉悦的开发人员体验基础上的新功能,PostgreSQL 17 都将增强您的数据管理体验。”

PostgreSQL 是一种创新的数据管理系统,以可靠性、稳健性和可扩展性而闻名,受益于全球开发者社区 25 多年的开源开发,已成为各种规模组织的首选开源关系数据库。

系统范围的性能提升

PostgreSQL真空清理 过程对于正常运行至关重要,需要服务器实例资源才能运行。PostgreSQL 17 引入了一种用于真空清理的新内部内存结构,可减少高达 20 倍的内存消耗。这提高了真空清理速度,还减少了共享资源的使用,从而为您的工作负载提供了更多资源。

PostgreSQL 17 继续改进其 I/O 层的性能。由于预写日志 ( WAL ) 处理的改进,高并发工作负载的写入吞吐量可能提高 2 倍。此外,新的流式 I/O 接口加快了顺序扫描(从表读取所有数据)的速度,并加快了 ANALYZE更新计划器统计信息的速度。

PostgreSQL 17 还将其性能提升扩展到查询执行。PostgreSQL 17IN通过使用 B 树 索引(PostgreSQL 中的默认索引方法)子句提高了查询的性能。此外, BRIN索引现在支持并行构建。PostgreSQL 17 包括多项查询规划改进,包括对NOT NULL约束的优化,以及对处理通用表表达式 (WITH查询)的改进。此版本增加了更多 SIMD(单指令/多数据)支持以加速计算,包括使用 AVX-512 进行 bit_count 函数执行。

进一步扩展强大的开发人员体验

PostgreSQL 是第一个添加 JSON 支持 (2012) 的关系数据库,PostgreSQL 17 增加了对 SQL/JSON 标准的实现。 现在JSON_TABLE 在 PostgreSQL 17 中可用,允许开发人员将 JSON 数据转换为标准 PostgreSQL 表。PostgreSQL 17 现在支持SQL /JSON 构造函数 ( JSON、、) 和 查询函数JSON_SCALAR( 、、),为开发人员提供了与 JSON 数据交互的其他方式。此版本添加了更多 表达式,重点是将 JSON 数据转换为本机 PostgreSQL 数据类型,包括数字、布尔值、字符串和日期/时间类型。JSON_SERIALIZEJSON_EXISTSJSON_QUERYJSON_VALUEjsonpath

PostgreSQL 17 为 添加了更多功能MERGE,用于条件更新,包括子句和更新视图的RETURNING功能。此外,PostgreSQL 17 还具有批量加载和数据导出的新功能,包括使用命令导出大行时性能提高 2 倍。 当源和目标编码匹配时,性能也会得到改进,并包含一个新选项,即使出现插入错误,也允许继续导入。COPYCOPYON_ERROR

此版本扩展了管理分区中的数据和跨远程 PostgreSQL 实例分布的数据的功能。PostgreSQL 17 支持在 分区表上使用标识列和排除约束。用于在远程 PostgreSQL 实例上执行查询的PostgreSQL 外部数据包装器 ( ) 现在可以向远程服务器postgres_fdw推送EXISTS和 子查询,以实现更高效的处理。IN

PostgreSQL 17 还包含一个内置的、独立于平台的、不可变的排序规则提供程序,该提供程序保证是不可变的,并提供与排序规则类似的排序语义,C只是使用UTF-8编码而不是 SQL_ASCII。使用这个新的排序规则提供程序可以保证您的基于文本的查询将返回相同的排序结果,无论您在何处运行 PostgreSQL。

逻辑复制增强功能可实现高可用性和主要版本升级

逻辑复制 用于在许多用例中实时传输数据。但是,在此版本之前,想要执行主要版本升级的用户必须删除逻辑复制槽,这需要在升级后将数据重新同步到订阅者。从 PostgreSQL 17 升级开始,用户不必删除逻辑复制槽,从而简化了使用逻辑复制时的升级过程。

PostgreSQL 17 现在包含逻辑复制的故障转移控制,使其在高可用性环境中部署时更具弹性。此外,PostgreSQL 17 还引入了 pg_createsubscriber 用于将物理副本转换为新逻辑副本的命令行工具。

管理安全和运营的更多选项

PostgreSQL 17 进一步扩展了用户管理数据库系统整体生命周期的方式。PostgreSQL 有一个新的 TLS 选项,sslnegotiation允许用户在使用 ALPN (postgresql在 ALPN 目录中注册为)时执行直接 TLS 握手。PostgreSQL 17 还添加了 pg_maintain 预定义角色,该角色允许用户执行维护操作。

pg_basebackupPostgreSQL 中包含的备份实用程序现在支持增量备份,并添加了pg_combinebackup 用于重建完整备份的实用程序。此外, pg_dump还包含一个名为 的新选项–filter,可让您选择在生成转储文件时要包含的对象。

PostgreSQL 17 还增强了监控和分析功能。 EXPLAIN现在显示本地 I/O 块读写所花费的时间,并包括两个新选项: SERIALIZE和MEMORY,可用于查看网络传输的数据转换所花费的时间以及使用了多少内存。PostgreSQL 17 现在报告清理索引的进度,并添加了pg_wait_events 系统视图,当与结合使用时pg_stat_activity,可以更深入地了解活动会话正在等待的原因。

其他功能

PostgreSQL 17 中还添加了许多其他新功能和改进,这些功能和改进可能对您的用例也有所帮助。请参阅 发行说明,了解新功能和更改功能的完整列表。

关于 PostgreSQL

PostgreSQL是世界上最先进的开源数据库,拥有一个由数千名用户、贡献者、公司和组织组成的全球社区。PostgreSQL 始于加州大学伯克利分校,历经 35 年的工程开发,一直以无与伦比的速度发展。PostgreSQL 成熟的功能集不仅可与顶级专有数据库系统相媲美,而且在高级数据库功能、可扩展性、安全性和稳定性方面也超越了它们。

链接

下载
发行说明
新闻资料包
安全页面
关注@postgresql
#PG证书#PG考试#postgresql初级#postgresql中级#postgresql高级

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值