前回の記事で、ローカル環境からGCPのPublic Subnetにある踏み台サーバーにリモートデスクトップ(RDP)アクセスできるところまで構築しました。
続いて、ローカル環境からProtected SubnetにあるWebサーバーにHTTP(S)アクセスできるように構築していきます。
ネットワーク構築
外部IPアドレスの追加
NAT用の外部IPアドレス(グローバルIPアドレス)を追加します。
Google Cloud コンソール > メニュー > ネットワーキング > VPC ネットワーク > 外部 IP アドレスで、外部IPアドレスを追加(静的アドレスを予約)します。
data:image/s3,"s3://crabby-images/0707b/0707b0cfdc301b1392ee8928deef667b2074f967" alt="GCPのグローバルIPの取得"
次いで、ロードバランサー用の外部IPアドレス(グローバルIPアドレス)を追加します。
data:image/s3,"s3://crabby-images/f5a19/f5a19093a5669d7849c7734519bdbeb7a7be075c" alt="GCPのグローバルIPの取得(ロードバランサー用)"
Cloud NATの追加
Cloud NATを追加します。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワーク サービス > Cloud NATで、Cloud NATを作成します(開始ボタンを押下します)。
data:image/s3,"s3://crabby-images/07d39/07d39c213a5d272dfcda132703c1884e90adccfb" alt="GCPのCloudNATの追加"
data:image/s3,"s3://crabby-images/d14f0/d14f034a1281158ff241c4d57dd11efe30ae4ea9" alt="GCPのCloudRouterの追加"
GCE(Webサーバー)の追加
GCE(Webサーバー)をProtected Subnetに追加します。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > VM インスタンスで、VMインスタンスを作成します。
data:image/s3,"s3://crabby-images/e132c/e132c15af06804e0b23fcb63d698537f483671f0" alt="GCPのGCE追加①"
data:image/s3,"s3://crabby-images/a2eab/a2eab98987a04eaec889f63980ee7d4b1f71921a" alt="GCPのGCE追加②"
その他はデフォルト設定のまま作成をします。
Firewallの追加
GCE(Webサーバー)に適用するFirewallを追加します。
data:image/s3,"s3://crabby-images/31682/316822ba7610a5b2992b8542e79367ea5ea464cb" alt="GCPのFirewall設定"
GCE(Webサーバー)の起動
GCE(Webサーバー)を起動します。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > VM インスタンスで、作成したインスタンスを選択します。
内部IPを把握します。
data:image/s3,"s3://crabby-images/c9760/c97601540256d555e2db3fb5acacba850fecee15" alt="GCPのGCE追加③"
Windowsパスワードを設定(取得)します。
data:image/s3,"s3://crabby-images/42358/42358d00d993819f5d0ae915bbcaa51123b85279" alt="GCPのGCE追加④"
data:image/s3,"s3://crabby-images/cfd4d/cfd4d197bbf4c3b2749a152662fc9d64c8cf19bd" alt="GCPのGCE追加⑤"
これで、Public Subnetの踏み台サーバーから「(Protected Subnetの)内部IPアドレス」とユーザー名と取得したパスワードを指定して、Protected SubnetのWebサーバーに対してリモートデスクトップ(RDP)で接続することができます。
data:image/s3,"s3://crabby-images/1b4d8/1b4d85c82584d9b089770ae5fb1a223fa1ede812" alt="GCPのWebサーバーへRDP接続"
Webサーバー構築
Webサーバー環境のセットアップ
ローカル環境 ⇒ 踏み台サーバー ⇒ WebサーバーにRDP接続します。
以下を参考に、Webサーバー環境をセットアップします。
インスタンスグループの追加
GCEのインスタンスグループを追加します。ロードバランサーの追加に必要です。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > インスタンス グループで、インスタンスグループを作成します。
data:image/s3,"s3://crabby-images/f12f3/f12f301566fa5fe45a1284bdbfed93dbfb7e173d" alt="GCPのインスタンスグループ"
ロードバランサーの追加
ロードバランサーを追加します。
ロードバランサーは、クライアントからのHTTP(S)リクエストをWebサーバーに通します。複数のWebサーバーをターゲットグループとして登録し、負荷分散することができます。
data:image/s3,"s3://crabby-images/b601c/b601cbe9c4ef495000eba4565595e6702dac00c2" alt=""
ここでは、インスタンスグループには1つのWebサーバーを所属させます。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワークサービス > Cloud Load Balancingで、ロードバランサーを作成します。
「HTTP(S) 負荷分散」を選択し、構成を開始します。
「インターネット接続または内部専用」では、「インターネットから自分の VM へ」を選択し、続行します。
バックエンドを構成します。
data:image/s3,"s3://crabby-images/0eb17/0eb170dd97b8c0f0c3c30995f299ffa5281a6969" alt="GCPのロードバランサーの追加①"
data:image/s3,"s3://crabby-images/64e0c/64e0cf007e1da62e1d1ec243802d6580871c5f39" alt="GCPのロードバランサーのバックエンドの設定①"
data:image/s3,"s3://crabby-images/2fe5b/2fe5b6a6f7bd3e452e31a4dcfb7961ab5fc17483" alt="GCPのロードバランサーのバックエンドの設定②"
data:image/s3,"s3://crabby-images/c39f6/c39f6bad3bb916413471ab2c095f81fafb01eaed" alt="GCPのロードバランサーのバックエンドの設定③"
ホストとパスのルールを設定します。
data:image/s3,"s3://crabby-images/34338/3433812e5336ed0e01092849c745dafc78c07d54" alt="GCPのロードバランサーのホストとパスの設定"
フロントエンドを構成します。
data:image/s3,"s3://crabby-images/31191/311916ccdf279e97779d8a06b61c6cf8a6ffbfce" alt="GCPのロードバランサーのフロントエンドの設定①"
data:image/s3,"s3://crabby-images/e9f3f/e9f3fb3dbbd5f37e71164384371e0458679e54b9" alt="GCPのロードバランサーのフロントエンドの設定②"
作成ボタンを押して作成します。
ドメイン取得
HTTP(S)通信をするためのドメイン取得を行います。
こちらを参考に行って下さい。
ドメインと、ロードバランサーの(のフロントエンドで設定した)グローバルIPアドレスを紐付けます。
Google Domainsにアクセスし、マイドメイン > 取得したドメインを選択 > DNSを選択します。
カスタムレコードで新しいレコードを作成します。
data:image/s3,"s3://crabby-images/6d3fe/6d3fe303cf7b4c73f2868d14e0dc40fc43be50c3" alt="GoogleDomainsの設定"
SSL証明書の発行
HTTPS通信のサーバー認証のため、SSL証明書を発行します。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワークサービス > Cloud Load Balancingで、作成したロードバランサーを選択し、フロントエンドの編集を行います。
data:image/s3,"s3://crabby-images/f1829/f1829df37e1807cf6c550ddfb3db67b61539bf8f" alt="GCPのロードバランサーのフロントエンドの設定③"
更新ボタンを押して保存します。
SSL証明書がActiveになるのを待ちます。数分かかります。
data:image/s3,"s3://crabby-images/e2654/e265428003d59969344f95a78506cc2f47f65911" alt="GCPのロードバランサーのフロントエンドの設定④"
data:image/s3,"s3://crabby-images/cb72e/cb72e383e50938140083ef1ec8dbdcbb97eb0ac1" alt="GCPのロードバランサーのフロントエンドの設定⑤"
以上で、クライアント環境のブラウザで「https://<サブドメイン>.<取得したドメイン名>」(e.g. https://www.iso-domain.com) へアクセスすることができます。
続きはこちらになります。