E.195. 版本 7.3.10

发布日期: 2005-05-09

这个版本包含各种自7.3.9以来的补丁,包括几个安全相关的问题。

E.195.1. 迁移到版本 7.3.10

运行7.3.X的不需要转储/恢复。不过, 转储/恢复是处理在7.3.X系统目录中的初始化内容中发现的重大安全问题的一种方式。 使用7.3.10的initdb的dump/initdb/reload序列将自动改正这个问题。

安全问题是非特权用户可以通过SQL命令引用内建字符设置编码转换函数, 但是该函数不是这样使用的,并且对于恶意的参数选择是不安全的。 修复包括改变这些函数声明的参数列表,这样它们可以不再被SQL命令调用。 (这样并不影响它们通过编码转换机制的正常使用。) 强烈推荐所有安装修复这个错误,通过initdb或通过下面给出的手动修复过程。 该错误至少允许非特权数据库用户毁坏他们的服务器进程, 甚至可能允许非特权用户获得数据库超级用户的权限。

如果你希望不做initdb,那么执行下列的过程。作为数据库超级用户,执行:

BEGIN;
UPDATE pg_proc SET proargtypes[3] = 'internal'::regtype
WHERE pronamespace = 11 AND pronargs = 5
     AND proargtypes[2] = 'cstring'::regtype;
-- 该命令应该报告已经更新了90行;
-- 如果不是,那么回滚并调查而不是提交!
COMMIT;

上面的程序必须在每个安装的数据库中执行,包括template1, 并且理论上也包括template0。如果你不修复模板数据库, 那么任何随后创建的数据库将包含相同的错误。template1 可以用与任意其他数据库相同的方式修复,但是修复template0 需要额外的步骤。首先,从任意数据库发出:

UPDATE pg_database SET datallowconn = true WHERE datname = 'template0';

然后连接到template0并执行以上所述的修复程序。最后,执行:

-- 重新冻结template0:
VACUUM FREEZE;
-- 保护它免受未来的变化:
UPDATE pg_database SET datallowconn = false WHERE datname = 'template0';

E.195.2. 修改列表

  • 改变编码函数签名以阻止滥用

  • 修复古老竞态条件,该条件允许一个事务因为某些目的(如 SELECT FOR UPDATE)被视作已提交

    这是一个极其严重的bug,因为它会导致表面数据的不一致性被应用短暂的看到。

  • 修复相关扩展和VACUUM之间的竞态条件

    这理论上可能导致丢失新近插入的数据的一个页面,尽管情况看起来概率很低。 没有导致多于一个维护失败的已知情况。

  • 修复了TIME WITH TIME ZONE值的比较

    当使用--enable-integer-datetimes配置开关时,该比较代码是错误的。 注意:如果你在TIME WITH TIME ZONE字段上有索引, 它将需要在安装这个更新后REINDEX,因为这个修复纠正了字段值的顺序。

  • TIME WITH TIME ZONE值修复了EXTRACT(EPOCH)

  • 修复了INTERVAL值中负分数秒的错误显示

    这个错误只有在使用了--enable-integer-datetimes配置开关的时候发生。

  • 在plpgsql中额外的缓冲区溢出检查(Neil)

  • 修复pg_dump转储触发器名字正确的包含%(Neil)

  • 阻止to_char(interval)为月份相关的格式转储内核

  • 为更新的OpenSSL构建修复contrib/pgcrypto(Marko Kreen)

  • contrib/intagg修复更多的64位问题

  • 阻止返回RECORD的函数的不正确的最优化