rss

Software Developer's

デベロッパー・ソリューションマイクロソフトキャリアIT求人

カテゴリー業務システムシステム開発プロジェクト管理情報セキュリティ調査レポートインタビューキャリアアップ

チャンネル【今月の特集】新・言語進化論サーバ運用SaaSニュースITイベントメンバー登録登録情報管理

TOP書籍連動> postgresql.confの設定を見直そう




まるごと PostgreSQL!
PostgreSQLチューニング実践テクニック

第1回:postgresql.confによるチューニング(1)

著者:石井達夫(ISHII, Tatsuo)   2005/5/25
前のページ  1  2
postgresql.confの設定を見直そう

   PostgreSQLの設定ファイルであるpostgresql.confには性能に関する項目がいくつかあります。まずはこれらについて見直しましょう。
shared_buffers

   shared_buffersには、PostgreSQLのデータベースエンジン(バックエンド)が使用する共有メモリ上のバッファ領域を指定します。shared_buffersは大きすぎても小さすぎても性能が低下します。初期状態ではinitdbの自動設定機能により、1000程度に設定されていると思いますが、できれば8000〜10000程度まで引き上げた方がよいでしょう。これ以上の値を指定すると、バッファ管理のオーバーヘッドにより逆に性能が低下します。

   shared_buffersを大きくするとpostmasterが立ち上がらないことがあります。その場合はOSの共有メモリ領域を拡張します。共有メモリの拡張方法の詳細は、PostgreSQLマニュアルの「16.5.1. 共有メモリとセマフォ」をご覧ください。

   ところで、「メモリが空いているようなのでそれをPostgreSQLで有効に使いたい」という質問に対して「shared_buffersをできるだけ多く取ってください」というような回答を目にすることがよくありますが、前述のようにそれは間違いです。PostgreSQLでは、むしろ余ったメモリをOSにバッファ領域として使ってもらった方がトータルでの性能が向上します。


deadlock_timeout

   PostgreSQLは自動的にデッドロックを検出する仕掛けを持っています。PostgreSQLで採用されているのは、トランザクションが直接/間接にロックを待っている状態をグラフにし、その中に閉ループが含まれているかどうかを調べる方式です。閉ループが含まれていれば、デッドロックが発生します。たとえば、トランザクションT1、T2がテーブルt1、t2に次のような順序でロックをかけると、図1のようなロック状態になり、デッドロック発生と判断されます。

デッドロック状態
図1:デッドロック状態


T1: LOCK TABLE t1;
T2: LOCK TABLE t2;
T1: LOCK TABLE t2;
T2: LOCK TABLE t1; ……… ここでデッドロック発生

   データベースシステムの中には、実際にロック取得を試みて、一定時間経過してもロックが取得できない場合にデッドロックと判断するシステムもあるようですが、これでは単に処理が遅いだけなのか、本当にデッドロックが発生しているのか区別がつかず、誤った判定をする可能性があります。それに比べてPostgreSQLではきちんとデッドロックを検出しているため、このような誤動作の心配がありません。

   ただ、デッドロック検出は比較的重い処理であるため、PostgreSQLではロック取得を試みてすぐではなく、一定時間経ってもロックが取得できない場合のみデッドロック検出処理を行います。この「一定時間」に相当するのが「deadlock_timeout」パラメータです。

   デッドロック検出処理はデータベースセッションごとに行われます。負荷が高い場合はdeadlock_timeoutで指定した時間が経過してもロックが取得できないことが多いので、同時セッション数が多いとより短い間隔でデッドロック検出処理が実行されるようになり(たとえば100セッション存在するときは、最悪、deadlock_timeout/100ごとに検出処理が発生する)、その結果、ますますシステム負荷が高くなるという悪循環に陥ってしまいます。

   この問題を回避するには、deadlock_timeoutを長めに設定します。デフォルトは1000ミリ秒(すなわち1秒)ですが、これに同時セッション数を乗じた値にするとよいでしょう。たとえば同時セッション数が100ならば100000にします。

   deadlock_timeoutを長くすると当然デッドロックの検出が遅れるようになりますが、そもそもデッドロックが発生すること自体が問題なのです。デッドロックが発生しなければ、deadlock_timeoutを長くしても実用上支障ありません。

前のページ  1  2


石井達夫
著者プロフィール
石井達夫(ISHII, Tatsuo)
PostgreSQLの開発者、エバンジェリスト。本業でもPostgreSQLによるビジネスに関わっている。著書に「PostgreSQL完全攻略ガイド」「PHPxPostgreSQLで作る最強Webシステム」(技術評論社)などがある。


この記事の評価をお聞かせください
ボタンをクリックしますとウインドウが開きます。

INDEX
第1回:postgresql.confによるチューニング(1)
  PostgreSQLのチューニングとは?
Postgresql.confの設定を見直そう
PostgreSQLチューニング実践テクニック
第1回 postgresql.confによるチューニング(1)
第2回 postgresql.confによるチューニング(2)
第3回 VACUUMの活用によるチューニング
第4回 インデックスの活用によるチューニング
第5回 高度なインデックスの活用
第6回 統計情報の最適化
第7回 オプティマイザに関するチューニング
第8回 GROUP BYを使用したチューニング
10月公開カレンダー
  1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31      
11月公開カレンダー
        1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30  


Enterprise Watchニュース

トピック米Oracleの設立30周年を祝う「OpenWorld 2007」開幕(2007/11/12 17:00)

ハードウェアサン、運べるコンテナ型データセンター「PROJECT BLACKBOX」国内初お披露目(2007/11/12 16:24)

ソフトウェアセールスフォース、Salesforceの最新版「Winter '08」の提供を開始(2007/11/12 17:00)

海外米Microsoft、中規模向けサーバースイート「Centro」の正式名を発表(2007/11/12 12:44)

スポンサーインフォメーション

メンバー登録のお願い


ThinkITは無料会員制のWebサイトです。

メンバー登録をすることで、ThinkITをより有効に活用することができます。登録は無料です。



採用情報
人材募集 一緒に作ろう!“ThinkIT”NEW
今、“ThinkIT”を一緒に作ってくれる仲間を大募集中です。営業、技術、編集、制作スキルを活かして下さい。
編集局だより

72(なに)かが変わる! キャンペーン実施中

ThinkIT編集局お勧め記事

【新・言語進化論】言語選択の分かれ道【新・言語進化論】
言語選択の分かれ道

プログラミング言語を選択する決定打とは?

ThinkIT編集後記



【PR情報】

転職ならen転職ならエン派遣ならenアルバイトならen履歴書ならen就職ならen求人ならen

実際に使われはじめている仕様記述言語を基本から学んでいこう!
【新・言語進化論】仕様記述言語を知っていますか?
第2回:仕様記述言語の種類について

人気ランキングTOP5
第1位
【特集1:サーバ運用に効くクスリ】
サーバ負荷の原因を探れ!
第2位
マンガ版 たかはしもとのぶの「はじめてのオープンソース」
第3位
W-ZERO3で電車プログラマになるための開発環境術
第4位
【特集1:サーバ運用に効くクスリ】
いまさら聞けないサーバ管理入門
第5位
【特集1:サーバ運用に効くクスリ】
オープンソース統合監視ツール導入指南