[pgsql-jp: 40360] Re: vacuumdbでもI/O
加藤 健太
kenta @ diverta.co.jp
2010年 8月 23日 (月) 16:40:08 JST
石井様
加藤です。ありがとうございます。参考になりました!
うちのようなシステムだとdefault設定は要注意ですね。
On Sun, 22 Aug 2010 12:02:04 +0900 (JST)
Tatsuo Ishii <ishii @ sraoss.co.jp> wrote:
> 石井です。
>
> > ありがとうございます!DBのスキーマの変更は更新として認識される
> > のでしょうか?
> > 例えば、レコード数1万件のテーブルで、カラムを1件追加すると、1万件更新し
> > たことになるのでしょうか?
>
> カラム追加の際にデフォルト値を設定したりすると、新しいテーブルにカラム
> を追加しながら元データを丸ごとコピーするので、かなり大量の更新が発生す
> るようです。
> # ただ、その際にWALの大量書き込みが発生するかどうかはわかりません。
> # もしかしたら賢く最適化しているかも。
>
> デフォルト値を設定しないなど、物理的にタプルを拡張する必要がない場合は、
> システムカタログの修正くらいしか更新が発生しないので、WALの書き込みは
> わずかだと思います。
> --
> Tatsuo Ishii
> SRA OSS, Inc. Japan
> English: http://www.sraoss.co.jp/index_en.php
> Japanese: http://www.sraoss.co.jp
>
> > On Fri, 20 Aug 2010 20:26:34 +0900
> > Tatsuhito Kasahara <kasahara.tatsuhito @ oss.ntt.co.jp> wrote:
> >
> > > こんばんは、笠原と申します。
> > >
> > > 加藤 健太 wrote:
> > > > そこにWALファイルもあるのですが、vacuumの時にファイルの書き込みなどは行
> > > > われるのでしょうか?
> > > VACUUM 時には、
> > > ・不要なレコードを掃除したページのイメージ
> > > ・上記のページ操作を記録したWAL
> > > が書き込みされます。
> > >
> > > もし、"デフォルト以外のテーブルスペース"に置いたテーブルへの
> > > VACUUM にて、"デフォルトのテーブルスペース"へ書き込みが発生
> > > しているようであれば、WAL の書き込みの影響だと思います。
> > >
> > > 基本的に、更新が走らない DB であれば、VACUUM をしても書き込みは
> > > ほとんど発生しません。
> > >
> > > ただし、更新されていない DB であっても、古いトランザクションで挿入された
> > > データが FREEZE されずに残っていると、データの書き込みが発生します。
> > > 一度 FREEZE されたレコードは、以降 FREEZE 対象にはなりません。
> > >
> > > # FREEZE 処理は、VACUUM 中に行われる処理です。古いトランザクションで
> > > 挿入されたレコードに特別な ID を振って"必ず可視"である、という情報を
> > > 付与する操作です。そのため、データの更新が発生します。
> > >
> > > (参考)
> > > http://www.postgresql.jp/document/current/html/routine-vacuuming.html#VACUUM-FOR-WRAPAROUND
> > >
> > > --
> > > NTT OSSセンタ
> > >
> > > 笠原辰仁
> >
pgsql-jp メーリングリストの案内