さくら VPS の Ubuntu 12.04 LTS を入れたホストで Munin による Nginx の監視を始めたので設定方法をメモしておく。 Node サービスのみセットアップ。
$ sudo apt-get install munin-node
Nginx - stub_status 設定
Nginx には指定したパスを HTTP 叩くと自身の状況をレポートしてくれる HttpStubStatusModule がある。これは Ubuntu 12.04 で apt-get install nginx すると標準で付いている。
stub_status ディレクティブは、 nginx.conf 等のどこかに /nginx_status パスで stub_status が返るように設定する。サーバ内からのアクセスだけ許可するようにも設定しておく。
1 | server { |
設定したらリロードして試しに叩いて確認しておく。
1 | $ sudo /etc/init.d/nginx reload |
Munin の Nginx プラグインを設定
標準で入っている nginx_request と nginx_status を設定しました。 plugins ディレクトリにプラグインスクリプトのシンボリックリンクを張ります。
1 | $ cd /etc/munin/plugins |
プラグインの設定ファイルを編集します。
1 | $ sudo vi /etc/munin/plugin-conf.d/munin-node |
最後にnginxのセクションを追加し、env.url として先ほどの stub_status の URL を定義します。
1 | [nginx*] |
Munin-node 再起動と確認
1 | $ sudo /etc/init.d/munin-node restart |
/var/log/munin/munin-node.log にエラーが出ていないかチェックしておきます。 これで少しおいてからブラウザで集計ページを見ると Nginx requests と Nginx Status セクションが増えています。
プラグインのグラフについて
Nginx requests
1秒間当たりのリクエスト数のグラフ
Nginx Status
- Active connections - 接続数
- reading - リクエストヘッダの読み込み
- writing - リクエストボディの読み込みからリクエストの処理そしてクライアントのレスポンス書き込みまで
- waiting - keep-alive の待ち状態