MySQLの最適化でWordPressのアクセス不能状態を復旧

XREAでWordpressのサイトをいくつか運営していますが、そのうちの一つがある日突然レスポンスを全く返さなくなってしまいました。

同じサーバで運用している他サイトは正常に見えてるし、管理画面のphpMyAdminからDBも動いているようだし、これはWordpress周りの異常かなと思って調べたところ、MySQLのオーバヘッドが溜まるとアクセスできなくなるという結構事例も多くある現象が見つかりました。

MySQLの最適化を試したところ、すんなりサイトは復旧しました。

というわけで、その時の最適化作業備忘録です。

DBの最適化

XREAのWeb管理画面からphpMyAdminにアクセスします。

DBのテーブル一覧を開くと、オーバーヘッドができているテーブルが見つかります。

SQLタブを開き、オーバーヘッドがあるテーブルに対して最適化クエリを実行します。

optimize tables `wp_options`, `wp_postmeta`

オーバーヘッドがクリアされます。

最適化スクリプトをcronに設定

手動で最適化すれば暫定的に解決しますが、しばらくしてオーバーヘッドが溜まるとまた同じ事象が繰り返されます。

そこで、XREAのcronにDB最適化を実行するスクリプトを仕込みます。

・mysqlcheck.sh

#!/bin/sh
/usr/local/mysql/bin/mysqlcheck -o -r --databases [DB名] -u[ユーザ名] -p[パスワード]
exit

mysqlcheckコマンドの-oオプションは最適化、-rは修復です。

このファイルを公開ディレクトリのpublic_htmlから外にUPして、Web管理画面のcronジョブ設定からスクリプトを実行するよう設定します。(私はとりあえず様子見で毎時実行させてみました。)

これで手動メンテナンスも不要となります。

それにしても同じサーバ内でWordpressを使ってる他のサイトはオーバヘッドが溜まってもアクセスできるのに対して、あるサイトだけがまたオーバヘッドができるとアクセス不能になってしまう原因は分からず。

PHPが好きなWeb系エンジニアです。フリーランスでWebサイト制作やWordPressのカスタマイズ、システム開発等を雑多にこなしています。バンカラ応援好きの振り飛車党。 高校野球 / 将棋 / WordPress / ブログ / 食べること / 二児の父親 >>詳しいプロフィールはこちら

コメント

  1. […] 私の言葉足らずでは混乱させるかもしれないのでこちらのページをご参考になさってみて下さい。 MySQLの最適化でWordPressのアクセス不能状態を復旧 […]

  2. MySQLの最適化

    ときどき、サイトにログインもできないし、表示もできないことがあって。けど、 ほおって置くと、直ってるんで意識していなかったんですが、今回はちょっとひどかった。   ので、…