【前回】AWSサイト間VPNの構築(3.AWSのVPN構築)
【次回】AWSサイト間VPNの構築(5.暗号化・ハッシュアルゴリズム変更)
ネットワーク構成
下記のネットワーク構成で、CML上のLAN(172.16.0.0/24)とAWSのサブネット(10.0.0.0/24)が直接通信できるようにします。
※Server(172.16.0.1)からEC2(10.0.0.58)にPingによる疎通確認ができるようにしていきます。
data:image/s3,"s3://crabby-images/e20e4/e20e455da1f5fe424f29bb9d055d2b34e42f6816" alt="CMLとAWSのネットワーク構成"
CMLの構築
AWSのサイト間VPN接続の検証のためにCMLを構築します。
CMLの基本設定
Server、IOSv(VPN-Router)、ExternalConnectorを配置します。
RouterのGi0/0をExternalConnectorに、Gi0/1をServerに接続します。
data:image/s3,"s3://crabby-images/b4320/b4320ac584b4124f59701ea75c73078b22f5cbb6" alt="CMLのノードの配置"
Serverは、「EDIT CONFIG」で下記の設定を行い起動します。
hostname Server
ifconfig eth0 172.16.0.1 netmask 255.255.255.0 up
route add -net 0.0.0.0/0 dev eth0
data:image/s3,"s3://crabby-images/fb005/fb005786e0ed9e300dc67dbe44bc9d9cf7c062b8" alt="Serverの設定"
ExternalConnectorは、「EDIT CONFIG」で「BRIDGE」を選択します。
※CMLの外部ネットワーク接続の詳細はこちらで説明しています。
data:image/s3,"s3://crabby-images/afb86/afb86b76b93a309aee499207216ec44e426157ff" alt="External Connectorの設定"
Routerのインターフェースを設定します。
int Gi0/0
ip address 192.168.1.100 255.255.255.0
no shut
int Gi0/1
ip address 172.16.0.254 255.255.255.0
no shut
RouterのインターフェースにIPアドレスが設定され、リンクアップしたことを確認します。
show ip int brief
data:image/s3,"s3://crabby-images/e33f6/e33f63ae6326772468c09399136fc63533e3d536" alt="Routerのインターフェース設定確認"
Routerのデフォルトルートを設定します。
ip route 0.0.0.0 0.0.0.0 192.168.1.1
※デフォルトルートのネクストホップは、自身のローカル環境のルータのIPアドレスを設定します。下記のコマンドで確認できます。
[Windowsのコマンドプロンプト]
route print -4
-----------------------------------------------------------------------
0.0.0.0 0.0.0.0 192.168.1.1
-----------------------------------------------------------------------
[Macのターミナル]
netstat -rn -f inet | grep default
-----------------------------------------------------------------------
default 192.168.1.1
-----------------------------------------------------------------------
Routerのデフォルトルートが設定されたことを確認します。
show ip route
data:image/s3,"s3://crabby-images/0f1ea/0f1ea662f37978b5766c98dda2e83b5ad6ca7e61" alt="Routerのルーティング設定確認"
隣接機器にPingを実施し、疎通可能であることを確認します。
ping 192.168.1.1
ping 172.16.0.1
data:image/s3,"s3://crabby-images/118f3/118f3b38d257347ad7d51e799e65062f29bd2877" alt="隣接機器へのPing確認"
インターネット内とAWSのトンネルインターフェースの外部IPアドレスにPingを実施し、疎通可能であることを確認します。
ping 8.8.8.8 ※Googleが提供している「Google Public DNS」のIPアドレス
ping X.X.X.X ※AWSのトンネルインターフェースの外部IPアドレス
data:image/s3,"s3://crabby-images/0ba4c/0ba4c8462d2cfc7e8e46e387ae3b4f5b8ee3f0b7" alt="インターネットとAWSへのPing確認"
CMLのVPN設定
AWSの「サイト間のVPN接続」から設定のサンプルをダウンロードできます。
「設定のダウンロード」をクリックします。
data:image/s3,"s3://crabby-images/b66ce/b66ceb20a3a358263204985c511e67ef128f1ed9" alt="VPN設定のダウンロード画面へ遷移"
ベンダーは「Cisco Systems, Inc.」、プラットフォームは「Cisco ASR 1000」を選択し、ダウンロードをクリックします。
data:image/s3,"s3://crabby-images/1e580/1e58016d4d79d9cb35f80e75b334065725532416" alt="VPN設定のダウンロード"
ダウンロードした設定サンプルから、今回は必要最低限の下記を設定します。AWSのVPN接続は、デフォルトでトンネルインターフェースが2つ作成されますが、片方のみ接続します。
*の部分はダウンロードしたテンプレート通りです。
crypto isakmp policy 200
encryption aes 128
authentication pre-share
group 2
lifetime 28800
hash sha
exit
crypto keyring keyring-vpn-*******************
local-address 192.168.1.100 ※ここはCML上のルーターのGi0/0のアドレスを指定
pre-shared-key address ***.***.***.*** key *******************************
exit
crypto isakmp profile isakmp-vpn-*******************
keyring keyring-vpn-*******************
match identity address ***.***.***.*** 255.255.255.255
local-address XXX.XXX.XXX.XXX ※ここは自身のグローバルアドレスを指定
exit
crypto ipsec transform-set ipsec-prop-vpn-******************* esp-aes 128 esp-sha-hmac
mode tunnel
exit
crypto ipsec profile ipsec-vpn-*******************
set pfs group2
set security-association lifetime seconds 3600
set transform-set ipsec-prop-vpn-*******************
exit
interface Tunnel1
ip address 169.254.27.178 255.255.255.252
ip virtual-reassembly
tunnel source 192.168.1.100 ※ここはCML上のルーターのGi0/0のアドレスを指定
tunnel destination ***.***.***.***
tunnel mode ipsec ipv4
tunnel protection ipsec profile ipsec-vpn-*******************
ip tcp adjust-mss 1379
no shutdown
exit
ip route 10.0.0.0 255.255.255.0 Tunnel1
Tunnel1が作成され、リンクアップしていることを確認します。
show ip int brief
data:image/s3,"s3://crabby-images/e2ed4/e2ed424db9f5b85c2959721e972ef1cd54e85304" alt="Routerのインターフェース設定確認"
AWSのEC2を配置したサブネット(10.0.0.0/24)向けのルーティングが追加されていることを確認します。
show ip route
data:image/s3,"s3://crabby-images/08731/08731a0b4869bb07f8d9901f78c28ebd59fbc42d" alt="Routerのルーティング設定確認"
AWSのVPN接続のトンネルインターフェースにPingを実施し、疎通可能であることを確認します。
トンネルインターフェースのセグメント「169.254.27.176/30」は下記のようにアドレスがアサインされます。
169.254.27.176 ネットワークアドレス
169.254.27.177 AWS側のトンネルインターフェース
169.254.27.178 カスタマー側のトンネルインターフェース
169.254.27.179 ブロードキャストアドレス
ping 169.254.27.177
data:image/s3,"s3://crabby-images/dae2a/dae2ab9a80022e7780c1c421e573b26847d3c945" alt="AWSのトンネルインターフェースへのPing確認"
AWSのVPN接続の「トンネル詳細」を確認すると、Tunnel1のステータスが「アップ」になり、VPN接続が確立されています。
data:image/s3,"s3://crabby-images/68d64/68d642e9cec01a15103bce209035db0d38c961fd" alt="AWSのトンネルインターフェースのステータス確認"
疎通確認
ServerからEC2に向けてPingを実施し、疎通可能であることを確認します。
ping 10.0.0.58
data:image/s3,"s3://crabby-images/78b78/78b78d44ea0f860d53d6cf2dfa73dfb64f8ec3b3" alt="ServerからEC2へのPing確認"
CML上のVPN-RouterのGi0/0側でキャプチャすると、暗号化されて送信されていることが分かります。
data:image/s3,"s3://crabby-images/f288a/f288a2ef496a935232314de9bd00cd5038a611c7" alt="パケットキャプチャの確認"
ルーターのステータス確認
フェーズ1(ISAKMP)のステータスを確認するには下記のコマンドを実行します。
stateが”QM IDLE”となっていれば、フェーズ1は成功しています。
show crypto isakmp sa
data:image/s3,"s3://crabby-images/06357/0635753807ef17b19f556fdca24040b904ffab92" alt=""
フェーズ2(IPSec)のステータスを確認するには下記のコマンドを実行します。
“pkts encrypt: “と”pkts decrypt: “の数値がカウントされていれば、暗号化通信が行われていることを示しています。
show crypto ipsec sa
data:image/s3,"s3://crabby-images/7969b/7969bb5e0d676e89d7a47b213538684f5b794775" alt=""
ISAKMPのポート番号
通常、ISAKMPは、UDPの500番ポートが利用されますが、途中にNAT機器を挟んだ場合は、NATトラバーサル用の4500番ポートに変更されます。ルーターのWAN側インターフェースでアクセスリストによる制御を行う場合は、UDPの500番ポートと4500番ポートを許可するようにしましょう。
data:image/s3,"s3://crabby-images/fff0e/fff0ec21ce0de506a615bdc5988688b99e3cb955" alt=""
data:image/s3,"s3://crabby-images/8a7d5/8a7d57bc77969b3dc657c4cf9ff2745cc0f4bdc3" alt=""
アクセスリスト上は、UDP/500は”isakmp”、UDP/4500は”non500-isakmp”として表示されます。(以下は例として送信元を”ANY”としていますが、実際には対向のグローバルIPアドレスを指定します。)
data:image/s3,"s3://crabby-images/fc21f/fc21f27597b3b14040992d71463bd8673b013157" alt=""
これで、AWSサイト間VPN接続のためのCML構築は完了です!
【前回】AWSサイト間VPNの構築(3.AWSのVPN構築)
【次回】AWSサイト間VPNの構築(5.暗号化・ハッシュアルゴリズム変更)