タグ

ブックマーク / techblog.lclco.com (1)

  • PostgreSQLで安全にテーブル定義を変更する - LCL Engineers' Blog

    Webエンジニアの森脇です。 PostgreSQLで、サービス稼働中に安易にALTER TABLE等を実行すると、ダウンタイムに繋がることがあります。安全にテーブル定義を変更するために、弊社で気をつけている点を紹介します。 なお、記事の内容は PostgreSQL 9.5.4 環境で確認しています。 PostgreSQLのロックについて 参照のみのテーブルに対して、ALTER TABLEを実行した場合でもダウンタイムに繋がることがあります。原因について理解するために、PostgreSQLのロックについて簡単に紹介します。 PostgreSQLでは、SELECTでも「ACCESS SHARE」というロックを獲得します。最も弱いロックですが、ALTER TABLE等で獲得される「ACCESS EXCLUSIVE」というロックと競合します。 これは、他のトランザクションでSELECTしているテ

    PostgreSQLで安全にテーブル定義を変更する - LCL Engineers' Blog
  • 1