WordPressをCside Netからさくらインターネットに移行する

今回のエントリは、レンタルサーバを使って自分で WordPress を運用している人にだけ役に立つ(かもしれない)エントリです。Cside Netから、さくらインターネットに移行した際の手順をメモしたエントリです。WordPress のデータレポジトリを MySQL4 から MySQL5 に移行する場合の手順を含んています。羊ページはこうやって運用されているのか、という雰囲気が分かって面白い人には、面白いかもしれません。


羊ページは約 8年に渡って、Cside のレンタルサーバ上で運用してきた。この間、長時間のサービス停止やデータロストもなく、おおむね満足すべき運用だったと思う。しかし、2010年の 5月から WordPress を CMS として全面的に使用するようになって、MySQL のバージョンが4.0.x であること、またそのパフォーマンスには不満を感じていた。特に、MySQL のバージョンが低いことで、WordPress の最新バージョンや一部のプラグイン(broken link checker等)が使用できないのが非常に問題だった。

羊ページは元々静的 HTML で構築されていたが、ひつじログとして幾つか CMS も試している。ただ、メインテナンスの困難さと自由度の低さから、どれも使ってみて都度断念してきた。WordPress は初めて、これなら使えると思った CMS だ。WordPress の 3.2ではMySQLは5.x が要求されることが既にアナウンスされており、Cside が MySQL5 を提供しない限り、羊ページは WordPress のバージョンアップが出来なくなる。

ホスティング契約の更新を目前にして、Cside のサポートに MySQL5 提供の可能性について問い合わせてみたが、予定は無い、との回答が来てしまった。であれば、業者を変えるしかないと即決した。


僕が最初にホスティング業者を選ぶときに Cside と迷ったのはさくらインターネットだった。当時から、Shell が解放されている業者として有名だったが、8年たって、ホスティング業者の大手に成長したようだ。実際にサービス内容と価格を比べてみると、Cside がこの数年、あまり新しい機能を入れてきていないのに比べると、積極的に色々サービスが拡充されている印象を持った。

僕が Cside と契約していたのは、Personal 独自ドメインと呼ばれるもので、年額 20,160円で 5GBのディスクスペースが提供される。Shell アクセスは無く、SSL は使えるが CA は独自(信頼されていないサイトの警告が出てしまう)だ。収容サーバは Intel Xeon 2.8GHzでメモリ1GB、2003年からの運用されており、OS は Debian 3 だ。

これに対して、さくらインターネットの相当する契約は(おおよそ)、レンタルサーバ プレミアムで、年額 15,000円+工事手数料 1,000円。ディスクスペースは40GB(RAID1) 使えて、MySQLは4 or 5 のいずれかが選択できる。SSL は共有だが、公式の CA の認証を通ったものだ。サーバーは新規のものに収容されたようで、Intel Core2 CPU T7200 2.00GHz でメモリ 2GBのスペック。OS は FreeBSD 7.1-RELEASE-p13 i386 が載っている。Apache のエラーログが見られたり、Web ベースのファイルマネージャがあるのが便利。


ディスク容量だけでサービスを評価するのは意味がないが、Csdie に比べてさくらインターネットは容量 8倍、価格が 2割安く年払いでもカード決済が可能(Cside は年払いは銀行振り込みのみ)。

メールアドレスの発行や、ML の運用などのできることはほぼ同じだが、コントロールパネルの作り込み、ConceptBase を使った FAQ DB の検索機能、spam メールフィルタの標準装備など、使い勝手ではさくらインターネットが勝っている印象を受けた。ということで、サインアップしてみた。

なお、さくらインターネットのサインアップ画面は、JavaScript 等で凝った遷移をしているのか、セキュリティー系のプラグインを沢山入れたfirefox では申し込みを完了することができなかった。(結局、IE を使った)


申し込みから数分で、完了報告とアカウント情報がメールされてくるので、早速移行作業を開始する。幾つか、試行錯誤をしたのだが、うまくいった方法を中心に書いておく。

まず、移行前環境と移行先環境の整理。


■移行元
Cside.jp Personal 独自ドメイン
MySQL 4.0.24

■移行先
さくらインターネット レンタルサーバプレミアム
My SQL 5.1.42

■レジストラ
goddady.com

手順としては、以下のようになる。

移行元 Apache 上のデータをローカルにFTPダウンロード→移行元 MySQL のテーブルをエクスポート→ローカルに落とした Apache 上に載せるデータを移行先に FTP アップロード→ローカルの MySQL テーブルデータを移行先にアップロード→ wp-config.php の DB 設定を変更→さくらインターネットに sheeppage.net を登録→レジストラの Nameserver エントリを移行先の DNS サーバに変更


まず、Cside のサーバ上にある WordPress 本体や画像ファイルなどをまとめて、FTP 経由でローカルに落とす。元々マスターがローカルにあっても、作業用のデータファイルなどが混ざっていて、移行には向かない場合がある。あらかじめ、落としておいた方がよい。また、WordPress のプラグインやテーマはWeb の管理画面からイントールや設定変更が行われるので、ローカルの初期状態とは食い違っている場合が多く、面倒だがこの手順を踏んでおくことをお勧めする。

なお、ASCII と Binary を間違えると当然、ファイルが壊れるので拡張毎に処理を分けられるクライアントを使った方が良い。*.mo ファイルなど WordPress 固有のバイナリファイルの拡張子には注意。


次に、MySQL のテーブルデータをエクスポートしておく。wp_ で始まるテーブルを全てエクスポートする。作業には、phpMyAdmin を使用することになるが、必ずインターフェイスを UTF8 に切り替えておくこと。WordPress 日本語版は UTF8 でデータを格納しており、phpMyAdmin のデフォルトの EUC モードでエクスポートすると.sql ファイルの中が EUC と UTF8 混在になってしまう(これに気がつかなくて、やり直しになった)

さくらインターネット側は16MiB までのインポート制限がある。zip 圧縮にも対応しているので、もし.sql ファイルが大きくなってしまった場合は、ローカルで一度.zip に圧縮してから(Csideの phpMyAdmin はエクスポート時の圧縮オプションに対応していない )アップロードしても良いだろう。しかし、元があまり大きな.sqlファイル(30MBとか)では、圧縮すればエラーにはならないが、インポート時に結果表示がきちんと出ないので、一度にインポートする適宜テーブルの数を調整した方が良い。僕は10MB程度で分割して、4つのエクスポートファイルを使用した。


さくらインターネットの Apache に、ローカルのファイルをアップロードする。Cside とは推奨のアクセス権が異なっているので注意。アクセス権は705 になるように、FTP クライアントのデフォルト設定を変更しておく必要がある。


さくらインターネットの MySQL にテーブルデータをインポートする。まず、コントロールパネルから DB のバージョン(MySQL5)を選択し、パスワードを設定して DB が使えるようにしておく。

phpMyAdminの管理画面の言語設定がUTF8になっていることを確認し、おまじないに(Helpを読んでみたものの、これが正しいのか自信はないが)SQL互換モードをMySQL40に変更してインポートする。

インポート先は自分の契約ドメインの方にして、スキーマにインポートしてしまわないように注意(そういうことをする人は、そもそもこういう作業はしないと思うが、、)

インポートの際には、クエリがノーエラーで通ったことを確認する。


WordPressのDB設定をCsideのものから、さくらインターネットのものに変更してアップロードする。wp-config.phpのサーバ名、DB名、ユーザ名、パスワード、のみ変更する。

ここまでの作業で、サーバ上のデータは完全に移行先にコピーされた。次に、自分の契約しているgTDLドメインをさくらのサーバに登録する。コントロールバネルから、自分のドメイン(僕の場合sheeppage.net)を追加する。この作業は必ず、レジストラ側の設定変更の前に行うこと、とさくらインターネットの移行手順には書かれているので注意。

次に、(ここは各自の契約形態によるが)、DNS の設定変更を行う。具体的には、自分の契約しているレジストラ(僕の場合はgodaddy.com)に Nameserver の変更依頼を行う。

godaddy.com では、契約更新や Nameserver の変更は全て web から可能なので、ここでさくらインターネットの DNS サーバ(プラマリ/セカンダリ)に書き換えておく。浸透速度はケースによるが、僕の場合1時間程度で浸透した。


DNS の変更が済めば、WordPress の管理画面から一通りの設定の調整を行えば移行は完了する。例えば、wp-DBManager のアーカイブ保存先パスなどは、Cside とさくらインターネットでは異なるので、設定変更する必要がある。

また、DNS の変更後に Cside 側の設定を変更したくなった場合には(さくらインターネットのように、サブドメイン経由での設定変更ではないので)一時的に、Cside の DNS をクライアントから参照することで、移行前の sheeppage.net にアクセスできることも覚えておきたい(DNS 変更後に Cside のコントロールパネルへのアクセスが出来なくなって非常に焦ったのだった、、)


以上、Cside からさくらインターネットへの WordPress 移行のメモでした。さくらに移行後、直ぐにWordPress を最新の 3.0.1 にアップデートしましたが、かなり改良点が多く、移行して正解、と思っています。

窓を一枚撮る。美しい。

Photo: a window in Malacca 2010. Malacca, Malaysia, Sony α900, Carl Zeiss Planar T* 85mm/F1.4(ZA)

Photo: "a window in Malacca" 2010. Malacca, Malaysia, Sony α900, Carl Zeiss Planar T* 85mm/F1.4(ZA)

いきなり連れて行かれた蜂蜜農場と、マレーシアの伝統住居展示場は、ツアーに対する我々の懸念を悪い意味で裏切らなかった。腹に詰め物をした仮面の若者が、ステージでおどけて踊る謎の民族舞踊を見ながら、我々のテンションは最低に近づいて行った。まさか、マラッカの観光というのは、伊豆周辺観光スポット巡りのような物なのではないか、その懸念が頭を過ぎる。

移動するバンの窓から見える町並み。炎天下にうずくまるように建つ、低層のコンクリート打ち放しの民家は、たいぶ沖縄あたりの町並みに似ていた。あるいは、サイパンあたりで見たことがあるような気もする。そんな日常の風景に和みもしたが、がっかりもしていた。お昼少し前の時間、外に人影はない。これが、マラッカ?


それから数分、メルセデス・ベンツのおんぼろバンが、いわゆる世界遺産としての「マラッカ」の街に入ったとき、僕たちは思わず声を上げた。それまでの、炎天の下で寝ぼけたように広がっていた現代的な住宅地が、突然、赤い土壁に白い文字がアクセントのオランダ統治時代の町並みに変わった。

目が、一気に覚める。鮮烈な白や黄色の壁、西欧と中国の要素が混在した建築が、どこまでも続く街路。どこにレンズを向けても、写真になる。「そりゃ、ここに行けば良い写真が撮れるよな」とあきらめにも似た羨望で眺める、そんな景色が突然眼前に広がった。

バンを降りて直ぐに、窓を一枚撮る。美しい。

マラッカに行こう。

Photo: highway 2010. Kuala Lumpur(KL), Malaysia, Ricoh GR DIGITAL III, GR LENS F1.9/28.

Photo: "highway" 2010. Kuala Lumpur(KL), Malaysia, Ricoh GR DIGITAL III, GR LENS F1.9/28.

ホテルのコンシェルジュとは、もちろん、あらゆるお客のあらゆるリクエストを訊く立場にあり、我々が夜の9時にもなって「明日マラッカに行きたい」と言い出しても、特に動じることは無かった。マレー訛りの弾むような英語でにこやかに、


「それは良い考えです」

とさえ言い切った。ただ、バスで現地に行くというプランは


「外国人には無理です」

ということらしい。マラッカ行きの高速バスのバス停は現在工事中で場所も移っており、恐らく飛行機の時間までに帰ってくることはできないだろう、というのがコンシェルジュの主張だった。

どうするか。ホテルが紹介するバスツアーというもがあるという。一人、220リンギットで安くはない。(タクシーを雇うと4時間で800リンギット、これは高すぎるので却下)ツアーねぇ、というのが我々の雰囲気ではあったが、マラッカに行ってなおかつ飛行機に間に合わせるためにはこれ以外の選択肢は無いように思えた。マラッカはそういえば、世界遺産なのだ。ならば行こう、マラッカへ。


翌朝八時半、ホテルに現れたのは、バス、ではなく「バンだろ」という代物であった。日本で見るメルセデスとは違う、業務車両メルセデスのバンに詰め込まれて、我々はマラッカに向かう。昨日の雨は上がり、メルセデスのガラスについた水滴越しに、朝八時半のクアラルンプール市街を眺める。良く晴れている。

街は、ブロックによってイスラム風、中華風、コスモポリタン風と景色が分かれる。モスクの尖塔が、高層ビルをバックに目立つ。クアラルンプールの市街では、ほとんどクラクションを聞かない。信号と横断歩道はいい加減で、交通ルールも緩いが、人が横断しようとすると車はクラクションを鳴らすでもなく、ちゃんと待ってくれる。その優しさと余裕というのが、僕にとってはとても新鮮だった。そこに作り物ではない、優しいアジア、みたいなものを感じたのだ。