キャッシュのキーサイズが足りない!
nginxのエラーログを見てみると以下の記述が大量に出ていました。
2015/05/22 16:47:25 [crit] 1628#0: ngx_slab_alloc() failed: no memory in cache keys zone "czone"
どうやらリバースプロキシに設定したczoneで、キャッシュのためのキーのサイズが足りないとのこと。
調べてみるとリバースプロキシのキャッシュ1つにつき128バイト使うようです。
試しにファイル数を調べてみます。
ちなみにproxy_cache_pathのkeys_zoneのサイズは8MBに設定されていました。
# <span class="functions">find</span> /var/cache/nginx/ -type f | <span class="functions">wc</span> -l
「62133」と表示されました。
62133*128=7953024なので、どうやら計算通り上限の8MBに達していたようです。
念のため以下のコマンドでキャッシュ全体のサイズも確認したところまだ余裕がありました。
$ <span class="functions">du</span> -s -m /var/cache/nginx/
ではnginxの設定を変えます。
# cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.org ← 念のためコピー # vi /etc/nginx/nginx.conf
proxy_cache_pathの行を探してキャッシュのkeys_zoneのサイズを8MBから倍の16MBに増やします。ついでにキャッシュのサイズも5GBから7BGに増やしました。
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=czone:8m max_size=5000m inactive=1d; ↓ proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=czone:16m max_size=7000m inactive=1d;
これで運用したところ、今のところエラーメッセージは出ていません。