内容
この記事はAWS初学者を導く体系的な動画学習サービス
「AWS CloudTech」の課題カリキュラムで作成しました。
https://aws-cloud-tech.com
前回の「スケーラビリティのあるブログサービスを構築する」のレッスンに引き続き、今回はRoute53とS3の機能を使い、独自ドメインを設定と障害時にSORRYページへ通信を流すという設定を行なっていきたいと思います。
前回の記事
現状は、クライアントのブラウザのURL欄にロードバランサーのドメイン名を入力すると、ロードバランサーまでアクセスでき、ブログが表示される状態です。
今回は、まずFreenomというサービスを利用して無料のドメインを取得します。
取得したドメインでアクセスできるようにRoute53に設定変更を加えていきます。
Route53は外部のサービスで取得したドメインも設定ができます。
その後、フェイルオーバールーティングの設定を行います。
S3にHTMLファイルをアップロードして、S3の静的ウェブサイトホスティング機能でSorryサイトを作成します。
プライマリの通信に問題が発生した場合は、セカンダリに通信を流す設定を行います。
実施手順
前回の記事の構成がされていることを前提で進めていきます。
準備
- EC2インスタンスが2台立ち上がっていることを確認
- RDSを削除した場合は、スナップショットから復元しておく。
- 復元したデータベースのステータスが
利用可能
になるまで待つ。 - ロードバランサーのIPアドレスでブログが閲覧できることを確認しておく。
ドメインの取得とRoute53の設定
今回は無料でドメインを取得できるFreenom
というサービスを利用します。
Freenom https://www.freenom.com/ja/index.html
- Freenomにアクセスし、
新しい無料ドメインを探します
と表示されている検索窓から希望するドメイン名を検索する。 - 検索結果が表示されるので、一覧の中から
今すぐ入手!
を選択 -
今すぐ入手!
が選択
となったらチェックアウト
を選択 -
Period
で使用する期間を選択(12ヶ月までは無料) -
Continue
を選択 - ログインしていない場合はGoogleのアカウントなどと紐づけておく。
- ログイン後、右上のタブから名前を選択、
view cart
を選択すると、カートの中身が表示されるので、利用規約確認のチェックボックスにチェックをいれ、Complete Order
を選択 - 画面が切り替わるので、上部の
Services
タブからMy Domains
を選択 - 入手したドメインの
Manage Domain
を選択 -
Management Tools
タブからNameservers
を選択 -
Use custom nameservers (enter below)
のラジオボタンをチェック - ネームサーバーの記入箇所が出てくるので開いたままにしておく。
現状だと、Freenomの方でDNSレコードの設定などの作業が必要になるので、ドメインの管理サーバーをRoute53のネームサーバーに書き換えます。
- Route53の画面を開き、
ホストゾーンの作成
を選択 - ドメイン名:先ほど入手したドメイン名を入力
-
ホストゾーンの作成
を選択 - レコードの
値/トラフィックのルーティング先
の4つの値を1つずつ先ほどのFreenomのネームサーバーの記入箇所にコピーする。 -
Change Nameservers
を選択
上記の作業は、「取得したドメインは、Route53で管理します。」とFreenomに教えてあげているイメージになります。
取得したドメインとロードバランサーを紐づける
- Route53のホストゾーンから作成したドメイン名を選択し、
レコードを作成
を選択 - ルーティングポリシーは
シンプルルーティング
を選択して次へ進む。 -
シンプルなレコードを定義
を選択 - レコード名:
blog
と入力 - 値/トラフィックのルーティング先:
Application Load BalancerとClassic Load Balancerへのエイリアス
を選択 - リージョンは東京を選択
-
シンプルなレコードを定義
を選択 -
レコードを作成
を選択 - 取得したドメイン名をブラウザのURL欄に貼り付けて、ブログにアクセスできることを確認する。
S3バケットの作成
S3の静的ウェブサイトホスティング機能でSorryサイトを作成します。
S3バケットの名前をドメインの名前と同じにする必要があるので注意しましょう。
- S3の画面に移動し、
バケットを作成
を選択 - バケット名には
ドメイン名
を入力 -
パブリックアクセスをすべてブロック
のチェックを外す。 -
現在の設定により、このバケットとバケット内のオブジェクトが公開される可能性があることを承認します。
にチェックをつける。 -
バケットを作成
を選択
Sorryページの設定
- 作成したバケットを選択
-
アップロード
を選択 -
ファイルを追加
とフォルダを追加
を選択して表示させたいファイルやフォルダを選択 -
アップロード
を選択 -
閉じる
を選択 -
プロパティ
タブを選択 - 下にスクロールすると
静的ウェブサイトホスティング
の項目があるので編集
を選択 -
静的ウェブサイトホスティング
:有効にする
にチェックをつける。 -
インデックスドキュメント
を入力(HTMLファイルの名前) -
エラードキュメント
を入力(error.htmlでOK) -
変更の保存
を選択 -
アクセス許可
タブを選択 - バケットポリシーの項目の
編集
を選択 - AWS公式サイトのバケットポリシーのサンプルコードをコピーしてペースト(https://docs.aws.amazon.com/ja_jp/AmazonS3/latest/userguide/WebsiteAccessPermissionsReqd.html)
- サンプルコードで
Bucket-Name
となっている箇所をバケット名に変更する。 -
変更の保存
を選択 -
プロパティ
タブの静的ウェブサイトホスティング
からバケットウェブサイトエンドポイント
を選択し、Sorryページが表示されることを確認する。
フェイルオーバールーティングの設定
プライマリの通信に異常があった場合にセカンダリとしてSorryページが表示されるように設定します。
- Route53を開き、レコード名がドメイン名のものを選択し、
レコードを編集
を選択 -
ルーティングポリシー
:フェイルオーバー
に変更 -
フェイルオーバーレコードタイプ
:プライマリ
を選択 -
レコードID
を入力(例. LB-P) -
保存
を選択
続いてセカンダリ用のRoute53のDNSレコードを作成します。
-
レコードを作成
を選択 -
フェイルオーバー
を選択して次へ -
レコード名
はプライマリと合わせる。 -
TTL (秒)
はテストなので60
としておく。 -
フェイルオーバーレコードを定義
を選択 - 値/トラフィックのルーティング先:
S3 ウェブサイトエンドポイントへのエイリアス
を選択 - リージョンは東京を選択
- S3バケットの項目は先ほど作成したバケットを選択
- フェイルオーバーレコードタイプ:
セカンダリ
を選択 -
レコードID
を入力(例. LB-S) -
フェイルオーバーレコードを定義
を選択 -
レコードを作成
を選択
設定した機能を確認
- 一度取得したドメイン名でアクセスして問題なく閲覧できることを確認
- サービスに障害が発生したと仮定して、EC2インスタンスを2台とも停止させる。
- インスタンス停止後に再度アクセスしてSorryページが表示されることを確認する。
- EC2インスタンスを2台とも起動させる。
- インスタンス起動後に再度アクセスして通常のページが閲覧できることを確認できればOK