もくじ
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-22.jpg)
レンタルサーバで上で WordPress を使った Webサイトを運営しているのですが、これを Amazon Web Services (AWS) に移行するまでのメモです。
Amazon Web Services (AWS) は日々進化し続けているので、この情報もすぐに古くなってしまうかもです。
ネットや書籍の情報もそれほど充実していないので、何度もなんどもなんども挫折感を味わいました… まだ人が歩いていないところに飛び込むにはそれなりの覚悟が必要ですね。
でもね、物事はいたってシンプル(イメージ図)。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-21.jpg)
【01】X.509 証明書を作成する
「アクセス証明書」の「X.509 証明書」タブから作成します。ダウンロードした秘密鍵ファイル(○○.pem)はどこか大切に保存しておきましょう。これはサーバにアクセスするための鍵です。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-01.jpg)
【02】Key Pairs を作成する
「EC2」タブの「Key Pairs」から[Create Key Pair]を選択して Key Pair Name を設定します。この名前はあとで入力する必要があるので他と差別化できるのがいいですね。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-02.jpg)
【03】CloudFormation を使って簡単にパッケージインストール
まずは WordPress に必要な LAMP 環境(Linux, Apache, MySQL, PHP)をサクっと整えてしまいましょう!
Amazon Web Services (AWS) の AWS Management Console 画面から「CloudFormation」タブを選択し、使いたい Region を選んで[Create New Stack]をクリック!
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-03.jpg)
Samples using Amazon RDS の WordPress Blog を選択して[Continue]へと進みます。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-04.jpg)
「Stack Name」や「Show Advanced Option」を入力して次へ。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-05.jpg)
KeyName は Key Pairs の名前を入力します。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-06.jpg)
Status が「CREATE_IN_PROGRESS」になりましたね!ここから5分ほどかかるので、コーヒーでも煎れて待ちましょう。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-07.jpg)
[CREATE_COMPLETE」に変わりました!
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-08.jpg)
「EC2」タブの「Instances」からインスタンスが立ち上がっているのを確認します。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-09.jpg)
同じく「EC2」の「Load Balancers」も確認。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-10.jpg)
「RDS」タブの「DB Instances」で MySQL が作成されていることも確認。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-11.jpg)
【04】グローバルIPアドレスを取得する
インスタンスを終了/起動するたびに IPアドレスが変わってしまうので、これを固定します。「EC2」タブの「Elastic IPs」へと進み、[Allocate New Address]をクリック。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-12.jpg)
「EC2」を選択して[Yes, Allocate]
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-13.jpg)
グローバルIPアドレスが割り振られました!この状態ではまだ EC2 のインスタンスと連携されていないので、[Associate Address]をクリックします。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-14.jpg)
連携させるインスタンスを選択して[Yes, Associate]
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-15.jpg)
Addressと Instance ID が連携されました!
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-16.jpg)
【05】SSH(SFTP)でアクセス
「EC2」タブの「Instances」の画面下部から Public DNS を確認します。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-17.jpg)
SSH アクセスは Mac の Transmit で行いました。「SFTPサーバへ接続」を選び、必要な情報を入力します。
- サーバ:Public DNS を入力します
- ユーザ名:ec2-user(これは固定です)
- パスワード:作成して連結させた Key Pairsファイル(○○.pem)を選択します
- ポート:22
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-18.jpg)
「/var/www/html」が Webサイトのデータ置き場ですが、ec2-user ではこのデータを変更する権限がありませんので、root でアクセスできるようにします。
【06】root のパスワードを変更する
「EC2」タブの「Instances」の「Instance Actions」から「Connect」をクリックすると、SSH でのアクセス方法が表示されます。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-19.jpg)
「【01】X.509 証明書を作成する」でダウンロードした秘密鍵ファイル(○○.pem)は Mac の「HDD > ユーザ > ユーザ名」 に置いておき、○○.pem のパーミッションを変更します。Windows の場合は 400、Macは 600 です。
![](https://www.head-t.com/img/2011/2011-11/2011-11-18_01-20.jpg)
Mac のターミナルを立ち上げて、以下のコマンドを入力します。
$ ssh -i ○○.pem ec2-user@○○○.○○.○○.○○
$ sudo passwd root
パスワードを2回入力して完了です。
とりあえずここまでー!