#はじめに
AWSならSSL証明書の発行が無料!
独自ドメインの取得も可能なのでAWSだけで「デプロイ」「ドメイン取得」「SSL証明書取得」と一元化できます。
この記事では独自ドメインの取得と、SSL証明書の取得方法をAWS公式の記事を引用して紹介します。
また、いろんな方がSSL証明書の取得方法を紹介されてますが、アップデートの多いAWSですのでここでは「2021年新春版」という事で記事にまとめさせていただきました。
より詳しい手順を知りたい方は、下記に参考にさせていただいた記事をまとめてますのでそちらをご参照ください。
#目次
1、ドメインの取得(Route 53)
2、SSL証明書の発行(Certificate Manager)
3、ロードバランサーの作成(EC2)
4、DNSを設定する(Route 53)
#手順
以下の手順で進めました。
#1. ドメインの取得(Route 53)
AWS公式のガイドに遷移するとステップ1、ステップ2、ステップ3がありますが、「ステップ 2: ドメイン名を登録する」のみを参考にしてください。
ここでは主に名前や住所など個人情報を入力しドメインを購入しました。
価格は$9〜購入可能です。
#2. SSL証明書の発行(Certificate Manager)
####ACM (AWS Certificate Manager)
AWS公式ガイドにしたがって作業を進める中で注意するポイントが3点ありました。
https://docs.aws.amazon.com/ja_jp/acm/latest/userguide/gs-acm-request-public.html
####1. 「www」
ドメイン名の追加にきたら先程購入したドメイン入力します。ここでの注意点は「www」を追加する事でした。
www.example.com
example.comの部分が先程購入したドメインになるようにします。
####2. 「DNS」
次のページ検証方法の選択では「DNSの検証」を選択しました。
次に、タグを追加のページでは任意の名前と値を入力して進んで行くと検証の画面に遷移しました。
###3. 「Route53でレコードの作成」
ここでドメイン(もしくは続行を押して証明書の管理画面)でドメインをクリックすると「Route53でレコードの作成」ボタンがあるのでそちらをクリックしました。
しばらくしてリロードすると「発行済み」になります。
※「検証保留中」から変化がない場合は下記の記事も参考にしてみてください。
【AWS】SSL(ACM)証明書が「検証保留中」のエラー解決
https://qiita.com/AKI3/items/0ca59855093dd429923d
3、ロードバランサーの作成(EC2)
####ELB(Elastic Load Balancing)
AWS公式ガイドではステップ1〜ステップ8までありますが、ステップ1と2を注意しました。
https://docs.aws.amazon.com/ja_jp/elasticloadbalancing/latest/application/create-application-load-balancer.html
####ステップ1
3つの選択肢がありますが
Application Load Balancer
を選択しました。
####ステップ??
こちらは公式ガイドでは見受けられませんでした。(見落としてるだけ?)
「手順 2: セキュリティ設定の構成デフォルトの証明書の選択」では「ACMから証明書を選択する」を選択して「証明書の名前」は先程発行した証明書を選択しました。
4、DNSを設定する(Route 53)
####DNS(Domain Name System)
再びRoute 53に戻ります。
AWS公式ガイドの「ステップ 3: DNS を設定する」完全修飾ドメイン名 (FQDN) を参考に設定をおこないました。
https://aws.amazon.com/jp/getting-started/hands-on/get-a-domain/
ガイドにしたがってホストゾーンに遷移するとRoute 53で作成したドメインが表示されてました。
これはRoute 53でドメインを取得するとホストゾーンが自動生成されるそうです。
ドメインをクリックすると詳細画面に遷移します。そこに3っつのドメインが並んでました。
自動生成されたときはタイプNS
とSOA
がデフォルトでセットされてるそうです。
その後SSL証明書の発行をしたとき「Route53でレコードの作成」ボタンを押した際3っつめのタイプA
が追加されるそうです。
####「レコードを追加する」
ここから大幅に公式ガイドから違う表示なってました。
先ず、レコード名の部分に「www」を入力します。
エイリアスを「青」にし、トラフィックのルーティング先を以下のように設定しました。
このホストにある別のレコードへのエイリアスは「application Lord BalancerとClassic Lord Balancer」を選択しました。
次にリージョンの選択では「東京」を選択しました。(自分のリージョンが東京なので)
最後にロードバランサーの選択をクリックすると先程作成したロードバランサーが表示されましたのでそちらを選択しました。
「作成」をクリックするしレコードを確認するとタイプCNAME
のレコードが追加されてました。
以上で完了です。
#感想
慣れると簡単な作業にも思えますが、最初設定したときはエラーも発生して結局3日くらいかかってしまいました。
いろいろな方の記事も参考にさせていただきましたが、記事の内容(AWS公式ガイドも)と実際が違う部分も多く苦労しました。
AWSは頻繁にアップデートされてるそうなので情報のキャッチアップが大切です。
###最後に
エンジニア初学者ですが、同じ様に悩んでる方々の助けになればと思い記事を投稿しております。
万が一情報が間違っている場合ご指摘していただけると幸いです。
#参考
https://dev.classmethod.jp/articles/aws-web-server-https-for-beginner/