rui live note

WordPress、PHP、子育て、ブログ、将棋、コワーキング、子育て、群馬等に関する日々感じたことを書いているブログです

*

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

      2014/03/15   MySQL, WordPress, 開発 , , , ,

  • このエントリーをはてなブックマークに追加
  • Pocket

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を使ってる他のサイトはオーバヘッドが溜まってもアクセスできるのに対して、あるサイトだけがまたオーバヘッドができるとアクセス不能になってしまう原因は分からず。

ad

この記事が気に入ったらシェアしてもらえると嬉しいです!

  • このエントリーをはてなブックマークに追加
  • Pocket
  • follow us in feedly
  • RSS

Comment

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

  2. MySQLの最適化

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

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

次のHTML タグと属性が使えます: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

  関連記事

git2xserver
XSERVER に Git をインストールする手順

知人の XSERVER で作業をする機会があったのですが、標準で Git が入っ …

Eコマース
EC-CUBEにGoogleアナリティクスのeコマーストラッキングを埋め込む設定方法

Google Analytics の eコマーストラッキング機能を使用すると、サ …

Dropbox
BackWPupプラグインでDropboxへのバックアップがAPIエラーになる場合の対処方法

BackWPup というプラグインを使って、WordPress のバックアップを …

linkwighin
WordPressの関連記事表示に便利なLinkWithinプラグインを入れてみた。

LinkWithin WordPressで関連記事を表示するのにとても便利なプラ …

MySQL
MySQLで実行されたSQLクエリをログ出力する設定

MySQL で実行された全ての SQL クエリをログ出力する設定方法について。 …

CentOS
CentOSでコンソールが文字化けするのをLocale変更して直す

CentOSにSSHでログインしてコンソールをいじってると、マルチバイト文字が文 …

PERARI
WebRTCで動画チャットできる「PERARI」というWebサービスを作りました

※この投稿は「WebRTC Advent Calendar 2014」の3日目の …

D3.js
将棋棋士データベースで遊ぶ(8)〜棋士の師弟関係をD3.jsで可視化〜

※この記事は「将棋 Advent Calendar 2016 – A …

EC-CUBE
EC-CUBEで携帯・スマートフォンテンプレートを無効化する方法

EC-CUBEには標準でスマートフォンや携帯用のテンプレートが用意されていて、そ …

Gravatar
Gravatar Widgetプラグインでサイドバーにプロフィール画像を表示してみた。

Gravatar Widget Gravatar WidgetというWordPr …