XREAでWordpressのサイトをいくつか運営していますが、そのうちの一つがある日突然レスポンスを全く返さなくなってしまいました。
同じサーバで運用している他サイトは正常に見えてるし、管理画面のphpMyAdminからDBも動いているようだし、これはWordpress周りの異常かなと思って調べたところ、MySQLのオーバヘッドが溜まるとアクセスできなくなるという結構事例も多くある現象が見つかりました。
MySQLの最適化を試したところ、すんなりサイトは復旧しました。
というわけで、その時の最適化作業備忘録です。
DBの最適化
XREAのWeb管理画面からphpMyAdminにアクセスします。
DBのテーブル一覧を開くと、オーバーヘッドができているテーブルが見つかります。
SQLタブを開き、オーバーヘッドがあるテーブルに対して最適化クエリを実行します。
[sql]
optimize tables `wp_options`, `wp_postmeta`
[/sql]
オーバーヘッドがクリアされます。
最適化スクリプトをcronに設定
手動で最適化すれば暫定的に解決しますが、しばらくしてオーバーヘッドが溜まるとまた同じ事象が繰り返されます。
そこで、XREAのcronにDB最適化を実行するスクリプトを仕込みます。
・mysqlcheck.sh
[shell]
#!/bin/sh
/usr/local/mysql/bin/mysqlcheck -o -r –databases [DB名] -u[ユーザ名] -p[パスワード]
exit
[/shell]
mysqlcheckコマンドの-oオプションは最適化、-rは修復です。
このファイルを公開ディレクトリのpublic_htmlから外にUPして、Web管理画面のcronジョブ設定からスクリプトを実行するよう設定します。(私はとりあえず様子見で毎時実行させてみました。)
これで手動メンテナンスも不要となります。
それにしても同じサーバ内でWordpressを使ってる他のサイトはオーバヘッドが溜まってもアクセスできるのに対して、あるサイトだけがまたオーバヘッドができるとアクセス不能になってしまう原因は分からず。