E.88. 版本 9.1.19

E.88.1. 迁移到版本9.1.19
E.88.2. 修改列表

发布日期:. 2015-10-08

这个版本包含自9.1.18以来的各种修复。关于9.1主版本的新特性信息,请查看 第 E.107 节

E.88.1. 迁移到版本9.1.19

运行9.1.X的用户不需要转储/恢复。

不过,如果您是从一个早于9.0.16的版本升级而来,请查看 第 E.115 节

E.88.2. 修改列表

  • 修复contrib/pgcrypto,检测和报告过短的 crypt()盐 (Josh Kupershmidt)

    某些无效的salt参数破坏了服务器或公开了几个字节的服务器内存。 我们没有排除在公开字节中安排机密信息存在的攻击的可行性,但似乎不大可能。 (CVE-2015-5288)

  • 在属于外部子事务的门户(光标)失败后修复子事务清理 (Tom Lane, Michael Paquier)

    在外部子事务游标中执行的函数可能会引用在内部子事务中创建的关系导致断言失败或崩溃。

  • 将关系插入关系缓存init文件中 (Tom Lane)

    在最近次要版本的修补程序中的监督会导致从init文件中省略 pg_trigger_tgrelid_tgname_index 。后续会话检测到这一点, 然后认为init文件被破坏,并且默认忽略它,导致会话启动时间显着降低。 除了修复错误之外,还要安装一些防护装置,以使任何类似的未来错误都会更加明显。

  • 当将许多元组插入到SPI查询结果中时,避免使用O(N^2)行为 (Neil Conway)

  • 当有许多未读通知时,改进LISTEN启动时间 (Matt Newell)

  • 向后打补丁,9.3版本时每个资源所有者锁缓存的增加 (Jeff Janes)

    pg_dump尝试转储大量表时,这显着提高了性能。

  • 默认情况下禁用SSL重新协商 (Michael Paquier, Andres Freund)

    虽然使用SSL重新协商理论上是一个好主意,但我们在实践中看到了太多的错误, 包括底层的OpenSSL库和我们的使用。重新协商将在9.5及以后完全删除。 在较旧的分支中,只需将ssl_renegotiation_limit的默认值更改为零(禁用)。

  • 降低*_freeze_max_age参数的最小值 (Andres Freund)

    这主要是为了使相关行为的测试较少耗时, 但是对于具有有限磁盘空间的安装也可能是有价值的。

  • 限制wal_buffers的最大值为2GB,以避免服务器崩溃 (Josh Berkus)

  • 修复numeric值的乘法中罕见的内部溢出 (Dean Rasheed)

  • 防止难以达到的堆栈溢出,包括记录类型、范围类型、jsonjsonbtsqueryltxtqueryquery_int (Noah Misch)

  • 修复日期时间输入中DOWDOY的处理 (Greg Stark)

    这些令牌并不意味着在datetime值中使用,但以前它们导致不透明的内部错误消息而不是 无效输入语法

  • 向正则表达式匹配中添加更多查询取消检查 (Tom Lane)

  • 向正则表达式添加递归深度保护,SIMILAR TOLIKE匹配 (Tom Lane)

    合适的搜索模式和低堆栈深度限制可能会导致堆栈超载崩溃。

  • 修复正则表达式执行中潜在的无限循环 (Tom Lane)

    一个搜索模式可以表面上匹配零长度字符串,但是实际上因为反向引用并不匹配, 会导致一个无限循环。

  • 修复正则表达式编译中的低内存故障 (Andreas Seltenreich)

  • 修复在正则表达式执行期间低概率的内存泄漏 (Tom Lane)

  • 修复在事务中止期间锁清除中罕见的低内存故障 (Tom Lane)

  • 修复在使用小的work_mem设置的tuplestores时, 排序期间意外的内存不足情况错误 (Tom Lane)

  • 修复qsort中非常低可能性的堆栈溢出 (Tom Lane)

  • 修复无效内存分配请求大小与大work_mem 设置的哈希连接失败 (Tomas Vondra, Tom Lane)

  • 修复各种计划错误 (Tom Lane)

    这些错误会导致不正确的查询计划会给出错误的答案,或者启用断言的构建中的断言失败, 或者奇怪的计划错误,比如无法为给定的查询设计查询计划找不到要排序的路径项计划不应该参考子计划的变量无法将所有NestLoopParams分配给计划节点。 感谢Andreas Seltenreich和Piotr Stefaniak的模糊测试,揭露了这些问题。

  • 在所有支持的分支中使用模糊路径开销规则 (Tom Lane)

    当替代计划选择具有效果相同的估计成本时,此更改旨在避免平台特定的行为。

  • 确保在postmaster启动时备用升级触发器文件被删除 (Michael Paquier, Fujii Masao)

    如果这些文件出现在用于初始化一个新的备用服务器的数据库备份中, 则可以防止不必要的升级。

  • 在postmaster关闭期间,确保移除每套接字锁文件并且在我们移除 postmaster.pid文件之前关闭监听套接字 (Tom Lane)

    如果外部脚本尝试在pg_ctl stop返回时立即启动新的postmaster, 则可以避免竞争条件失败。

  • 修复崩溃恢复期间主进程对启动进程崩溃的处理 (Tom Lane)

    如果,在崩溃恢复循环期间,启动进程还未恢复数据库一致性就崩溃了, 我们会尝试加载一个新的启动进程,这通常会再次崩溃,导致无限循环。

  • 当我们尝试发出信号并且自动清理工作者已经不在时,请勿打印WARNING, 并减少此类信号的日志冗长度 (Tom Lane)

  • 如果服务器时钟向后大量移动,防止自动清理加载进程睡眠过长 (Álvaro Herrera)

  • 确保GIN索引未完成插入列表的清理可以通过取消请求中断 (Jeff Janes)

  • 允许重新使用GIN索引中的全零页面 (Heikki Linnakangas)

    这样的页面可能会在崩溃后遗留下来。

  • 修复了一个在subtrans/multixact截断中导致关于明显回绕 的其他无害警告的一个接一个的错误 (Thomas Munro)

  • 修复PL/pgSQL的错误内容信息中CONTINUEMOVE语句类型的错误报告 (Pavel Stehule, Tom Lane)

  • 修复PL/Perl以正确处理非ASCII错误消息文本 (Alex Hunsaker)

  • 修复当返回一个record结果的字符串表示时, PL/Python的崩溃 (Tom Lane)

  • 修复PL/Tcl中忽略了检查malloc()调用失败的某些地方 (Michael Paquier, Álvaro Herrera)

  • contrib/isn中,修复以979开头的ISBN-13编号的输出 (Fabien Coelho)

    以979(但不是9790)开头的EAN被认为是ISBN,但是它们必须以新的13位格式打印, 而不是10位格式。

  • 改进libpq对内存不足条件的处理 (Michael Paquier, Heikki Linnakangas)

  • 修复ecpg中内存泄露和缺少内存不足检查 (Michael Paquier)

  • 修复psql的数字输出区域感知格式的代码 (Tom Lane)

    \pset numericlocale on调用的格式化代码对于一些不常见的情况 (例如具有指数而不是小数点的数字)做错了事情。它也可以从money 数据类型中转移已经本地化的输出。

  • 当没有当前连接时,在psql\c命令中防止崩溃 (Noah Misch)

  • 修正在pg_dump的目录输出格式中默认的zlib 压缩级别的选择 (Andrew Dunstan)

  • 确保在pg_dump中使用tar 格式输出创建的临时文件不是世界可读的 (Michael Paquier)

  • 修复pg_dumppg_upgrade以支持 postgrestemplate1数据库在非缺省表空间中的情况 (Marti Raudsepp, Bruce Momjian)

  • 修复pg_dump在从过旧的服务器转储而获得特定的权限类型时, 正确地处理对象权限 (Tom Lane)

    当从7.3之前的服务器转储函数或过程语言时,pg_dump 将产生撤销所有者的授予权限然后赋予所有权限给PUBLICGRANT/REVOKE命令。因为权限仅包括USAGEEXECUTE,所以这不是一个安全问题,但是,对于旧系统的行为来说, 这当然是一个令人惊讶的表现。修复它在这些情况下单独保留默认权限状态。

  • 修复pg_dump以转储shell类型 (Tom Lane)

    Shell类型(也就是还未完全定义的类型)对于很多方面是没有用的, 但是pg_dump应该转储它们。

  • 修复pg_dump和其他客户端程序中的各种小内存泄漏 (Michael Paquier)

  • 修复PPC硬件的spinlock汇编代码与AIX的本地汇编程序兼容 (Tom Lane)

    如果gcc被配置为使用本机汇编程序,这种情况正在变得越来越普遍, 那么使用gcc构建就不起作用。

  • AIX上,测试-qlonglong编译器选项而不仅仅假设它是安全的 (Noah Misch)

  • AIX上,使用-Wl,-brtllib连接选项以允许在运行时解决符号 (Noah Misch)

    Perl在5.8.0及以后的版本中依赖于此能力。

  • 由于编译器错误,在使用32位xlc编译时, 避免使用内联函数 (Noah Misch)

  • 在需要时为sched_yield()使用librt, 在某些Solaris版本上是这样的 (Oskari Saarenmaa)

  • 修复Windows install.bat脚本以处理包含空格的目标路径名 (Heikki Linnakangas)

  • PostgreSQL版本号的数值形式 (例如90405)对扩展Makefiles可用, 作为一个名为VERSION_NUM的变量 (Michael Paquier)

  • 更新时区数据文件到tzdata版本2015g, 因为DST规律在开曼群岛、斐济、摩尔多瓦、摩洛哥、诺福克岛、北朝鲜、 土耳其和乌拉圭发生了改变。加拿大北洛矶山脉有一个新的时区名 America/Fort_Nelson