E.103. 版本 8.1.22

发布日期: 2010-10-04

这个版本包含各种自8.1.21以来的修复。关于8.1主版本的新特性信息, 请查看Section E.125

PostgreSQL社区将在2010年11月份停止对8.1.X版本系列的更新。建议用户尽快升级到新的版本分支。

E.103.1. 迁移到版本 8.1.22

运行8.1.X的用户不需要转储/恢复。不过,如果你是从一个早于8.1.18的版本升级而来, 那么请查看8.1.18的版本声明。

E.103.2. 修改列表

  • 在PL/Perl和PL/Tcl中为每个调用的SQL用户id使用一个单独的解释器 (Tom Lane)

    这个修改阻止了破坏稍后将在同一个会话中在另一个SQL用户身份下执行的Perl或Tcl代码引起的安全问题(例如,在一个SECURITY DEFINER函数中)。大多数脚本语言提供很多可能执行的方式,比如重新定义被目标函数调用的标准函数或操作符。如果没有这个修改,任何拥有Perl或Tcl语言使用权限的SQL用户基本上都可以以目标函数所有者的SQL权限做任何事情。

    这个修改的代价是Perl和Tcl函数之间有意的沟通变得更加困难。为了提供一个逃逸出口,PL/PerlU和PL/TclU函数继续每个会话只使用一个解释器。这不认为是一个安全问题,因为所有这样的函数都在数据库超级用户的信任级别执行。

    有可能第三方程序语言声称提供受信任的执行有相似的安全问题。我们建议为了安全鉴定的目的联系任何你依赖的PL的作者。

    我们感谢Tim Bunce指出这个问题 (CVE-2010-3433)。

  • 阻止pg_get_expr()中可能的崩溃,通过不允许它被一个参数调用,该参数不是它打算使用的系统目录字段之一 (Heikki Linnakangas, Tom Lane)

  • 修复"不能处理未规划的子查询"错误 (Tom Lane)

    这在子查询包含一个连接别名引用,该引用扩展成一个包含另一个子查询的表达式时发生。

  • 阻止show_session_authorization()在自动清理进程中崩溃 (Tom Lane)

  • 防止函数返回行类型不是完全相同的记录集 (Tom Lane)

  • 当哈希一个通过引用传递的函数结果时,修复可能的失败 (Tao Ma, Tom Lane)

  • 当在写入锁文件时,小心的同步它们的内容(postmaster.pid和套接字锁文件) (Tom Lane)

    如果机器在主进程启动之后很快就崩溃,那么这个疏忽会导致损坏锁文件的内容。转而阻止随后的尝试成功的启动主进程,直到手动移除锁文件。

  • 当分配XID到深层嵌套的子事务时,避免递归 (Andres Freund, Robert Haas)

    如果限制了堆栈空间,那么原始的代码会导致一个崩溃。

  • 修复log_line_prefix%i逃逸,它会导致在后台启动时就产生垃圾 (Tom Lane)

  • 修复启用归档时,ALTER TABLE ... SET TABLESPACE中可能的数据损坏 (Jeff Davis)

  • 允许CREATE DATABASEALTER DATABASE ... SET TABLESPACE被查询取消中断 (Guillaume Lelarge)

  • 在PL/Python中,防止PyCObject_AsVoidPtrPyCObject_FromVoidPtr产生空指针结果 (Peter Eisentraut)

  • 改善contrib/dblink对包含删除字段的表的处理 (Tom Lane)

  • 修复contrib/dblink中"重复的连接名"错误之后的连接泄露 (Itagaki Takahiro)

  • 修复contrib/dblink,正确的处理连接名字长于62字节 (Itagaki Takahiro)

  • 更新建立的基础结构和文档,以反映源代码仓库从CVS搬到了Git (Magnus Hagander and others)

  • 更新时区数据文件到tzdata版本20101,因为DST规律在Egypt和Paletine发生了改变;还有对Finland的历史纠正。

    这个修改还为两个Micronesian时区添加了新的名字:Pacific/Chuuk现在比Pacific/Truk更受欢迎(并且首选的缩写是CHUT,不是TRUT),Pacific/Pohnpei比Pacific/Ponape更受欢迎。