前回の記事で、ローカル環境からGCPのPublic Subnetにある踏み台サーバーにリモートデスクトップ(RDP)アクセスできるところまで構築しました。
続いて、ローカル環境からProtected SubnetにあるWebサーバーにHTTP(S)アクセスできるように構築していきます。
ネットワーク構築
外部IPアドレスの追加
NAT用の外部IPアドレス(グローバルIPアドレス)を追加します。
Google Cloud コンソール > メニュー > ネットワーキング > VPC ネットワーク > 外部 IP アドレスで、外部IPアドレスを追加(静的アドレスを予約)します。
data:image/s3,"s3://crabby-images/e9b9d/e9b9d538937017949e96ef8069e2bceb754c0d21" alt="GCPのグローバルIPの取得"
次いで、ロードバランサー用の外部IPアドレス(グローバルIPアドレス)を追加します。
data:image/s3,"s3://crabby-images/c2727/c2727e5cf08c80b3671480ea67424cbeff966a58" alt="GCPのグローバルIPの取得(ロードバランサー用)"
Cloud NATの追加
Cloud NATを追加します。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワーク サービス > Cloud NATで、Cloud NATを作成します(開始ボタンを押下します)。
data:image/s3,"s3://crabby-images/23ec3/23ec3b9db51bcdab1c1bc89e9c451210926c5183" alt="GCPのCloudNATの追加"
data:image/s3,"s3://crabby-images/bcc4a/bcc4a7214e0153221fadfc4489d80742a64922d7" alt="GCPのCloudRouterの追加"
GCE(Webサーバー)の追加
GCE(Webサーバー)をProtected Subnetに追加します。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > VM インスタンスで、VMインスタンスを作成します。
data:image/s3,"s3://crabby-images/dde37/dde3786b4ae6450a4a745870a18748bd4b4f21d8" alt="GCPのGCE追加①"
data:image/s3,"s3://crabby-images/3c649/3c649ee6a557ec452a46f024aa9f4a564d381b89" alt="GCPのGCE追加②"
その他はデフォルト設定のまま作成をします。
Firewallの追加
GCE(Webサーバー)に適用するFirewallを追加します。
data:image/s3,"s3://crabby-images/25f32/25f3252b7faf3518c7714ce04d8bd208cbb2c9d3" alt="GCPのFirewall設定"
GCE(Webサーバー)の起動
GCE(Webサーバー)を起動します。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > VM インスタンスで、作成したインスタンスを選択します。
内部IPを把握します。
data:image/s3,"s3://crabby-images/20175/20175bfa9bfc540843eded784329697ec6dae6b4" alt="GCPのGCE追加③"
Windowsパスワードを設定(取得)します。
data:image/s3,"s3://crabby-images/b5e9b/b5e9b36d290728eda5641044c2ca8112a129c1e1" alt="GCPのGCE追加④"
data:image/s3,"s3://crabby-images/61fcd/61fcd33f5c6679636f123c410a5245a7bbfbeeb8" alt="GCPのGCE追加⑤"
これで、Public Subnetの踏み台サーバーから「(Protected Subnetの)内部IPアドレス」とユーザー名と取得したパスワードを指定して、Protected SubnetのWebサーバーに対してリモートデスクトップ(RDP)で接続することができます。
data:image/s3,"s3://crabby-images/f4773/f4773b261e4e5ea3eddd08a78e8a3f51e3606869" alt="GCPのWebサーバーへRDP接続"
Webサーバー構築
Webサーバー環境のセットアップ
ローカル環境 ⇒ 踏み台サーバー ⇒ WebサーバーにRDP接続します。
以下を参考に、Webサーバー環境をセットアップします。
インスタンスグループの追加
GCEのインスタンスグループを追加します。ロードバランサーの追加に必要です。
Google Cloud コンソール > メニュー > コンピューティング > Compute Engine > インスタンス グループで、インスタンスグループを作成します。
data:image/s3,"s3://crabby-images/e0c0e/e0c0ebb9dfa856f591ee5a44b326b077f5d76eed" alt="GCPのインスタンスグループ"
ロードバランサーの追加
ロードバランサーを追加します。
ロードバランサーは、クライアントからのHTTP(S)リクエストをWebサーバーに通します。複数のWebサーバーをターゲットグループとして登録し、負荷分散することができます。
data:image/s3,"s3://crabby-images/ce65a/ce65a3298760706e176710b7b5ae759fc4d2eaf4" alt=""
ここでは、インスタンスグループには1つのWebサーバーを所属させます。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワークサービス > Cloud Load Balancingで、ロードバランサーを作成します。
「HTTP(S) 負荷分散」を選択し、構成を開始します。
「インターネット接続または内部専用」では、「インターネットから自分の VM へ」を選択し、続行します。
バックエンドを構成します。
data:image/s3,"s3://crabby-images/d83b7/d83b7ecc2e9dca5539a5eaa860c0c2aa4091cd6c" alt="GCPのロードバランサーの追加①"
data:image/s3,"s3://crabby-images/fdba3/fdba35114c72e53bcfceda55f4f92da12d40c0f3" alt="GCPのロードバランサーのバックエンドの設定①"
data:image/s3,"s3://crabby-images/71161/71161d3d7cf9304adb26a5825b1548d24c81ccd5" alt="GCPのロードバランサーのバックエンドの設定②"
data:image/s3,"s3://crabby-images/e9414/e9414be37401c0dbe6137a0264809a5a304235c1" alt="GCPのロードバランサーのバックエンドの設定③"
ホストとパスのルールを設定します。
data:image/s3,"s3://crabby-images/0fa45/0fa45704b32a5d3142aaa4b137e2d0638019f6af" alt="GCPのロードバランサーのホストとパスの設定"
フロントエンドを構成します。
data:image/s3,"s3://crabby-images/ae6db/ae6db7e84eb9db0b1a2e6b8864c31261f8860c87" alt="GCPのロードバランサーのフロントエンドの設定①"
data:image/s3,"s3://crabby-images/118e2/118e236f1d51f4acf83af3ba03f07d1ca69d82e2" alt="GCPのロードバランサーのフロントエンドの設定②"
作成ボタンを押して作成します。
ドメイン取得
HTTP(S)通信をするためのドメイン取得を行います。
こちらを参考に行って下さい。
ドメインと、ロードバランサーの(のフロントエンドで設定した)グローバルIPアドレスを紐付けます。
Google Domainsにアクセスし、マイドメイン > 取得したドメインを選択 > DNSを選択します。
カスタムレコードで新しいレコードを作成します。
data:image/s3,"s3://crabby-images/8fa9f/8fa9fad39a289bf9e55ea2241bb6cb974acd8e4d" alt="GoogleDomainsの設定"
SSL証明書の発行
HTTPS通信のサーバー認証のため、SSL証明書を発行します。
Google Cloud コンソール > メニュー > ネットワーキング > ネットワークサービス > Cloud Load Balancingで、作成したロードバランサーを選択し、フロントエンドの編集を行います。
data:image/s3,"s3://crabby-images/e219e/e219ed00d3aa8656c2ec744dc66a1e893a7b5841" alt="GCPのロードバランサーのフロントエンドの設定③"
更新ボタンを押して保存します。
SSL証明書がActiveになるのを待ちます。数分かかります。
data:image/s3,"s3://crabby-images/0b59e/0b59ed2eace96313d631b51abe2b4fee543132c1" alt="GCPのロードバランサーのフロントエンドの設定④"
data:image/s3,"s3://crabby-images/c06bc/c06bc1a656097ca7decedda6c6e791db95886a04" alt="GCPのロードバランサーのフロントエンドの設定⑤"
以上で、クライアント環境のブラウザで「https://<サブドメイン>.<取得したドメイン名>」(e.g. https://www.iso-domain.com) へアクセスすることができます。
続きはこちらになります。