他のバージョンの文書 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9.6 | 9.5 | 9.4 | 9.3 | 9.2 | 9.1 | 9.0 | 8.4 | 8.3 | 8.2 | 8.1 | 8.0 | 7.4 | 7.3 | 7.2

E.12. リリース9.5.4

リリース日: 2016-08-11

このリリースは9.5.3に対し、各種不具合を修正したものです。 9.5メジャーリリースにおける新機能については、E.16. リリース9.5 を参照してください。

E.12.1. バージョン9.5.4への移行

9.5.Xからの移行ではダンプ/リストアは不要です。

しかしながら、9.5.2よりも前のリリースからアップグレードする場合は、E.14. リリース9.5.2を参照して下さい。

E.12.2. 変更点

  • 入れ子になったCASE-WHEN式誤評価のおそれがあり、 修正されました。 (Heikki Linnakangas, Michael Paquier, Tom Lane)

    他のCASEのテスト値の副式内に現れるCASE式が、 自身のテスト値がnullであるかどうかを取り違える可能性がありました。 そのうえ、CASE式で使われている等価演算子を実装しているSQL関数のインライン化が、SQL関数本体でCASE式内で呼ばれる関数に誤ったテスト値を渡す原因となる可能性がありました。 テスト値が異なるデータ型の場合にはクラッシュに至るおそれがあり、さらにそのような状況をサーバメモリの一部を暴露できるように悪用されるおそれがありました。 (CVE-2016-5423)

  • データベース名とロール名についてクライアントプログラムの特殊文字の扱いを修正しました。 (Noah Misch, Nathan Bossart, Michael Paquier)

    vacuumdb他、各種クライアントプログラムの多数の箇所が、ダブルクオートやバックスラッシュを含むデータベース名やロール名で混乱するおそれがありました。 これを安全にするためクオート規則を厳格にしました。 そのうえ、conninfo文字列がこれらプログラムむけにデータベース名パラメータとして使われている場合に、全て確実にそのように正しく扱われるようにしました。

    psql\connectコマンド、\passwordコマンドにて、二つ組ダブルクオートの扱いをドキュメントと一致するように修正しました。

    psql\connectコマンドに、前接続から接続パラメータを再利用するかを明示的に制御できる新たなオプション-reuse-previousを導入しました。 (これが無い場合は従来通りデータベース名がconninfo文字列とみられるかで判断されます。) これにより、pg_dumpallスクリプトで特殊文字が含まれるデータベース名の安全な取り扱いが可能になります。

    改行・復帰の文字をWindowsで安全にクオートするのは現実的と見られないため、これからはpg_dumpallはこれら文字を含むデータベース名、ロール名の処理を拒絶します。 将来このような名前をサーバ側で拒絶するかもしれませんが、その処置は未だ取られていません。

    特殊文字を含む作りこまれたオブジェクト名が、次回のpg_dumpallなどの定期メンテナンス操作にてスーパーユーザ権限でコマンドを実行させるために使われるかもしれないため、これらはセキュリティ修正とみなされます。 (CVE-2016-5424)

  • 入れ子になった複合値に適用されるIS NULL/IS NOT NULLの、稀な場合の誤動作を修正しました。 (Andrew Gierth, Tom Lane)

    SQL標準は全てNULL値の行にはIS NULLはTRUEを返すべきと明記しています(従ってROW(NULL,NULL) IS NULLはTRUE)。 しかし、これは再帰的に適用されることを意味しません(従ってROW(NULL, ROW(NULL,NULL)) IS NULLはFALSE)。 中核となるエグゼキュータではこれを正しく実現していますが、ある種のプランナ最適化がこのテストを再帰的に扱っていました(そのため両ケースでTRUEになる)。 また、contrib/postgres_fdwがリモート問い合わせで同様の誤動作をする可能性がありました。

  • 再帰CTE(WITH項)の中のINSERT ... ON CONFLICTに対する unrecognized node type(「認識されないノードタイプ」)エラーを修正しました。 (Peter Geoghegan)

  • プランナの式の前処理段階にて単純化されたインデックス式やインデックス述語をうまく照合できるようにINSERT ... ON CONFLICTを修正しました。 (Tom Lane)

  • INSERT ... ON CONFLICTコマンドの対象テーブルに適用されるけれども選択された裁定用インデックスではない排他制約の違反を正しく扱うようにしました。

    このような場合、通常の制約違反エラーを出すべきところですが、無限ループになっていました。

  • INSERT ... ON CONFLICTを対象テーブルがOIDにユニークインデックスを持っているときに失敗しないように修正しました。 (Tom Lane)

  • 多すぎるコロン区切りフィールドを持つIPv6アドレスをinetcidrデータ型が適切に拒絶するようにしました。 (Tom Lane)

  • NaN入力座標に対してclose_ps()point ## lseg演算子)でのクラッシュを防止しました。 (Tom Lane)

    クラッシュするのでなくNULLを返すようにしました。

  • 一貫性に欠けた値が渡された場合に起こりうるpg_get_expr()でのクラッシュを回避しました。 (Michael Paquier, Thomas Munro)

  • to_number()でのいくつかの1バイトのバッファ超過読み込みを修正しました。 (Peter Eisentraut)

    いくつかの場合にto_number()関数が入力文字列から本来よりも1文字多く読んでいました。 入力文字列がたまたまメモリ末尾に配置された場合には、クラッシュする小さな可能性があります。

  • CREATE MATERIALIZED VIEWまたはCREATE TABLE ASに 含まれる問い合わせは、WITH NO DATAが指定されているとき、プランナを実行しないようにしました。 (Michael Paquier, Tom Lane)

    これは、例えばマテリアライズドビューから呼び出されるSTABLE関数が未だ存在していないテーブルに依存している場合など、不要な失敗条件を回避します。

  • heap_update()を通る高価な処理パスの間の安全でない中間状態を回避しました。 (Masahiko Sawada, Andres Freund)

    これまで、これらの場合は対象タプルを(XMAXをセットすることで)ロックしていましたが、その動作をWAL記録していませんでした。 したがって、ページがディスクに溢れて、それからタプル更新が完了する前にデータベースクラッシュが起きたとき、データ一貫性問題の危険がありました。

  • 行ロック操作のWAL再生中のヒントビット更新を修正しました。 (Andres Freund)

    知られている本問題の影響は、準備されているけれどコミットされていないトランザクションにより保持された行ロックが、クラッシュと再起動の後に適用に失敗するかもしれないことだけです。

  • シリアライザブルモードでFOR KEY SHARE行ロックを取得するときの不要なcould not serialize access(「直列化アクセスができませんでした」)エラーを回避しました。 (Álvaro Herrera)

  • プランノードから返される展開されたデータムを確実に参照専用としました。 (Tom Lane)

    これは下位プランノードの結果が上位ノードの複数個所で参照される一部ケースでの失敗を回避します。 PostgreSQL本体に関する限り、PL/pgSQL関数から返される配列値だけが危険があります。 しかし、拡張で別のものに展開されたデータムを使っているかもしれません。

  • 指定された変数がNULL文字列値を持っているときに、postgres -Cでのクラッシュを回避しました。 (Michael Paquier)

  • WAL送信プロセスで、意図しないレシーバの待機を防止しました。 (Kyotaro Horiguchi)

  • ロジカルデコーディングで起こりうる大きいサブトランザクションの喪失を修正しました。 (Petru-Florin Mihancea)

  • サブトランザクションが実質の変更を含まないときのロジカルデコーディング失敗を修正しました。 (Marko Tiikkaja, Andrew Gierth)

  • バックエンドが共有カタログの最新の統計を確実に見るようにしました。 (Tom Lane)

    統計情報コレクタは通常のバックエンドからの要求の後、共有カタログについて統計ファイルを更新するのに失敗していました。 自動バキュームランチャーが定常的に要求するため、この問題は部分的に隠されていましたが、自動VACUUMを無効にすると顕在化しました。

  • 複数バックエンドがほぼ同時に更新を要求したときの統計ファイルの冗長な書き込みを回避しました。 (Tom Lane, Tomas Vondra)

  • VACUUMの間のトランザクションIDの消費を回避しました。 (Alexander Korotkov)

    VACUUMは一部ケースで現在トランザクションへの不要なXID割り当てを引き起こしていました。 通常これは無視してよいものですが、XID周回限度に直面していたなら、周回対策のバキュームの間にさらにXIDを消費することは、甚だ悪い事態です。

  • 9.3より前のバージョンからpg_upgradeを適用したクラスタにおいて、マルチトランザクションIDをバキュームするとき起こりうる失敗を防止しました。 (Andrew Gierth, Álvaro Herrera)

    この障害のよくある症状はMultiXactId NNN has not been created yet -- apparent wraparound(「マルチトランザクションID NNNは未だ作られていません、周回しているようです」)といったエラーです。

  • 手動ANALYZEでカラムリストを指定するとき、テーブルのchanges_since_analyzeカウンタをリセットしないようにしました。 (Tom Lane)

    私たちが一部カラムだけをアナライズするとき、他のカラムむけに定常的な自動アナライズが行われるのを妨げるべきではありません。

  • ユニークもしくはほぼユニークでNULL要素を多数持つカラムに対して、ANALYZEn_distinctの過剰見積もりを修正しました。 (Tom Lane)

    NULLが互いに異なる値であるかのように数えられることがあり、いくつかの類型の問い合わせで深刻なプランナの見積もり誤りをもたらしていました。

  • 自動VACUUMが複数のワーカを同じ共有カタログのために起動するのを防止しました。 (Álvaro Herrera)

    通常このバキュームは何にせよ長時間を要さないため、大した問題にはなりません。 しかし、ひどく肥大化したカタログの場合、一つを除く全てのワーカが他のテーブルに有益な仕事をする代わりに無駄に待つという結果になりかねません。

  • B-Tree のマーク/リストア処理の障害を修正しました。 (Kevin Grittner)

    この障害は、内側ソースノードがB-Treeインデックススキャンであるマージ結合で不正な結合結果またはアサート失敗をもたらすおそれがあります。

  • B-Treeインデックスのページ削除の試みを中断するときの二重のバッファロック解放を回避しました。 (Tom Lane)

    この誤りは破損したB-Treeインデックスを伴ういくつかの場合で、VACUUMの完了を妨げます。

  • 巨大な(shared_buffersより大きい)ハッシュインデックスの構築を修正しました。 (Tom Lane)

    大きいインデックスむけに、不正なハッシュ値がインデックスに挿入される原因となるバグを含んだコードパスが使われていました。 そのため、その後のインデックス検索は、初期構築後にインデックスに挿入されたタプルを除き、常に失敗しました。

  • NaNの要素値を含む幾何カラムに対するGiSTインデックス構築で、無限ループを防止しました。 (Tom Lane)

  • intervalカラムに対するcontrib/btree_gistインデックスでの最近傍インデックススキャン(ORDER BY distance)の間に起こりうるクラッシュを修正しました。 interval (Peter Geoghegan)

  • BRINインデックス要素を更新しようとするときのPANIC: failed to add BRIN tuple(「BRINタプルの追加に失敗しました」)エラーを修正しました。 (Álvaro Herrera)

  • バックグラウンドワーカの終了の際に起こりうるクラッシュを修正しました。 (Dmitry Ivanov)

  • PL/pgSQLのIMPORT FOREIGN SCHEMAコマンド内のINTO句の扱いを修正しました。 (Tom Lane)

  • contrib/btree_ginがありうる最小のbigint値を正しく扱えるように修正しました。 (Peter Eisentraut)

  • libpqが将来のサーバから正しくサーババージョンを解釈するようにしました。 (Peter Eisentraut)

    9.6の次のリリースから3パートのバージョン番号に代えて、2パートのバージョン番号に切り替えることが計画されています。 このような場合にPQserverVersion()が正しい値を返すことを保証しました。

  • ecpgunsigned long long配列要素むけコードを修正しました。 (Michael Meskes)

  • pg_dump-c-Cの両オプションを伴う場合に、求められていないCREATE SCHEMA publicコマンドの出力を回避しました。 (David Johnston, Tom Lane)

  • パラレルのpg_dumpおよびpg_restoreSIGTERM/control-Cの扱いを改善しました。 (Tom Lane)

    これらがCREATE INDEXなどの何らか長い実行をしている場合に、ワーカプロセスが必ず速やかに終了し、接続されているバックエンドへの問い合わせキャンセル要求を送信するようにしました。

  • パラレルのpg_dumppg_restoreにてエラー報告を修正しました。 (Tom Lane)

    これまでは、pg_dumppg_restoreのワーカプロセスからのエラーメッセージがユーザのコンソールに出力されないことがありました。 メッセージはマスタプロセスを通して伝達され、マスタプロセスのメッセージ伝搬を妨げるいくつかデッドロックするシナリオがあったためです。 代わりとして単純にstderrにすべてを出力します。 いくつかのケースでは重複するメッセージが出力されることになります(例えばすべてのワーカがサーバシャットダウンを報告します)。 しかし、メッセージが無いよりは良いと思われます。

  • パラレルのpg_dumpまたはpg_restoreがWindows上でエラー後に速やかに終了することを保証しました。 (Kyotaro Horiguchi)

    これまではエラーを報告しますがユーザにより手動で停止されるまで単に止まっていました。

  • パラレルpg_dumpがスタンバイサーバに対して実行したとき、手際よく失敗するようにしました。 (Magnus Hagander)

    --no-synchronized-snapshotsが指定されていないかぎり、この使い方はサポートされませんが、あまりよいエラー処理がなされていませんでした。

  • zlibサポート無しでビルドしたときに、pg_dumpがよりよく振る舞うようにしました。 (Kyotaro Horiguchi)

    パラレルダンプを正しく処理できず、他の場合でもいくつかのやや見当はずれな警告を出していました。

  • pg_basebackupが圧縮無しの指定として-Z 0を受け付けるようにしました。 (Fujii Masao)

  • AIXの共有ライブラリをビルドするMakefileのルールをパラレルmakeで安全になるように修正しました。 (Noah Misch)

  • ビルドディレクトリのパス名が空白文字を含むとき動作するように、TAPテストとMSVCスクリプトを修正しました。 (Michael Paquier, Kyotaro Horiguchi)

  • lock timeoutに対してstatement timeoutの報告について、より予測可能にしました。 (Tom Lane)

    負荷の重いマシンでは、ステートメントタイムアウトが先に発生したはずであるのに、lock timeoutの報告のためにリグレッションテストがしばしば失敗していました。

  • デンマーク語、ウェールズ語のロケールについてリグレッションテストを安全にしました。 (Jeff Janes, Tom Lane)

    これらのロケールの通常と違ったソート規則を働かせる一部データを変更しました。

  • タイムゾーンコードのコピーをIANAのtzcode release 2016cに適合するように更新しました。 (Tom Lane)

    これはタイムゾーンデータファイルの予測される将来の変更に対応するために必要です。 また、通常と異なるタイムゾーンに対応して、いくつかの稀な場合のバグを修正しています。

  • タイムゾーンデータファイルをtzdata release 2016fに更新しました。 ケメロヴォとノヴォシビルスクの夏時間の変更、アゼルバイジャン、ベラルーシ、およびモロッコの歴史的な修正が含まれます。