E.263. 版本 7.3.10
发布日期: 2005-05-09
这个版本包含各种自7.3.9以来的补丁,包括几个安全相关的问题。
E.263.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.263.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的函数的不正确的最优化