E.82. 版本 8.2.19

发布日期: 2010-12-16

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

E.82.1. 迁移到版本 8.2.19

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

E.82.2. 修改列表

  • 强制Linux上wal_sync_method 的缺省为fdatasync (Tom Lane, Marti Raudsepp)

    在Linux上的该缺省实际上是fdatasync已经很多年了, 但是最近的内核更改导致PostgreSQL选择了open_datasync。 这个选择没有导致任何性能改善,并且在某些文件系统上引起彻底的失败, 尤其是带有data=journal挂载选项的ext4

  • 为GIN索引修复WAL重放逻辑中的各种错误 (Tom Lane)

    这可能在复制期间导致"bad buffer id: 0"失败或索引内容的损坏。

  • 当开始检查点WAL记录和它的重做点不在相同的WAL段时,修复从基础备份的恢复 (Jeff Davis)

  • 添加对检测IA64上寄存器堆栈溢出的支持 (Tom Lane)

    IA64体系结构有两个硬件堆栈。堆栈溢出失败的全面预防需要两个堆栈都检查。

  • copyObject()中的堆栈溢出添加检查 (Tom Lane)

    由于堆栈溢出给出一个足够复杂的查询,某些代码路径可能会崩溃。

  • 修复临时GiST索引中页分裂的检测 (Heikki Linnakangas)

    在一个临时索引中有"并发的"页分裂是可能的,比如说, 执行一个插入时有一个打开的游标扫描索引。GiST未能检测这个情况, 并且因此在该游标的执行继续时会交付错误的结果。

  • ANALYZE复杂索引表达式时,避免内存泄露 (Tom Lane)

  • 确保使用整行变量的索引仍然依赖于它的表 (Tom Lane)

    create index i on t (foo(t.*))这样声明的索引, 在它的表被删除时,将不会自动被删除。

  • 不要用多个OUT参数"inline"一个SQL函数 (Tom Lane)

    这避免了由于丢失预期的结果行类型的信息而引起的可能的崩溃。

  • 如果ORDER BYLIMITFOR UPDATEWITH附属于INSERT ... VALUESVALUES 部分则正确的行为 (Tom Lane)

  • 修复COALESCE()表达式的常量折叠 (Tom Lane)

    规划器有时会尝试计算实际永远不可能达到的子表达式,可能导致意外的错误。

  • InhRelation节点添加打印功能 (Tom Lane)

    这避免了启用debug_print_parse并且执行了某些类型的查询时的失败。

  • 修复点到水平线段的距离的不正确的计算 (Tom Lane)

    这个错误影响几个不同的几何距离测量操作。

  • 修复PL/pgSQL对"简单"表达式的处理, 在递归或错误恢复的情况下不会失败 (Tom Lane)

  • 修复PL/Python对设置返回函数的处理 (Jan Urbanski)

    尝试在迭代器中调用SPI函数生成一组结果将会失败。

  • 修复contrib/cube的GiST picksplit算法中的错误 (Alexander Korotkov)

    这会导致相当大的低效,尽管不是实际上不正确的答案,在一个cube字段的GiST索引中。 如果你有这样的一个索引,考虑在安装这个更新之后REINDEX它。

  • 不要在contrib/dblink中发出"标识符将被截断"的通知, 除非创建新的连接 (Itagaki Takahiro)

  • 修复contrib/pgcrypto中丢失的公共键上潜在的内核转储 (Marti Raudsepp)

  • 修复contrib/xml2的XPath查询函数中的内存泄露 (Tom Lane)

  • 更新时区数据文件到tzdata版本2010o, 因为DST规律在Fiji和Samoa发生了改变;还为Hong kong做了历史纠正。