ネットワーク構成
下記の構成でAWSのサイト間VPNを構築しました。
data:image/s3,"s3://crabby-images/cb2dd/cb2dd85595240907973f3ab8c1bbecbcc1fc2cf3" alt="CMLとAWSのネットワーク構成"
AWS CLI によるVPN接続の作成と削除
VPN接続を作成すると、利用時間により課金されます。費用を抑えるためには、検証時のみVPN接続を作成する必要があります。都度、AWSコンソール画面からの作成は手間がかかるため、AWS CLI によるコマンドラインからの作成と削除方法を説明します。
ユーザーの作成
AWS CLI を利用するためのAWSユーザーを作成します。
検索窓に”IAM”と入力し、表示される「IAM」をクリックします。
data:image/s3,"s3://crabby-images/747bc/747bc30b3bb791cb1d95a91eac3769d346f66e6c" alt="IAM画面への遷移方法"
左のメニューで「ユーザー」を選択し、「ユーザーを追加」をクリックします。
data:image/s3,"s3://crabby-images/acf31/acf3151380f84013871b2fb667405bca7d51b832" alt="IAMのユーザー作成の開始"
ユーザー名に任意の名前を入力します。(ここでは、”cliadmin”としています。)
認証情報タイプに関しては、CLI専用のユーザーとするため、「アクセスキー – プログラムによるアクセス」にチェックを入れます。
data:image/s3,"s3://crabby-images/01618/016181449a6a1ce35ee8c5319196b27ca3502c59" alt="ユーザー名とアクセス種類の設定"
アクセス権限に関しては、「既存のポリシーを直接アタッチ」を選択し、必要なアクセス権限を追加します。ここでは、管理者として全権限を付与するため、「AdministratorAccess」を追加しています。
data:image/s3,"s3://crabby-images/a70e8/a70e8c5cf02bbda76cacc142836f5c93e39d238c" alt="アクセス権弦の設定"
必要に応じてタグを追加します。(必須ではありません。)
data:image/s3,"s3://crabby-images/d6255/d6255bf6e592b27a88211b78fae5bbe4cac6ca38" alt="タグの設定"
設定内容を確認し、「ユーザーの作成」をクリックします。
data:image/s3,"s3://crabby-images/ef569/ef5692d4b0cc5c0517694a24a23a0b5fccbb2374" alt="設定内容の確認"
「シークレットアクセスキー」を表示します。
data:image/s3,"s3://crabby-images/86283/862839c49b3fb97514c231e150f4e7d8edb3f6f1" alt="シークレットアクセスキーの表示"
“アクセスキーID”と”シークレットアクセスキー”をコピーするか、CSVをダウンロードして保存します。
data:image/s3,"s3://crabby-images/6abd3/6abd334531448fab2479d714fbc9bf0b3b7ed2ee" alt="アクセスキーIDとシークレットアクセスキーの保存"
AWS CLI の設定
EC2のマシンイメージで「Amazon Linux」を選択している場合、AWS CLIのインストールは不要なため、設定を行えばすぐに利用ができます。
初期設定を確認するために、EC2上で下記のコマンドを実施します。
aws configure list
何も設定されていないことがわかります。
[ec2-user@ip-10-0-0-100 ~]$ aws configure list
Name Value Type Location
---- ----- ---- --------
profile <not set> None None
access_key <not set> None None
secret_key <not set> None None
region <not set> None None
作成したユーザーのプロファイルを設定します。
aws configure --profile cliadmin
下記を設定します。
AWS Access Key ID [None]:アクセスキーIDを入力
AWS Secret Access Key [None]: シークレットアクセスキーを入力
Default region name [None]: ap-northeast-1を入力(EC2を配置しているリージョン)
Default output format [None]: 入力不要(デフォルトでjson形式)
設定したユーザーをデフォルトとして永続的に利用するために、環境変数を変更します。
sudo vi /etc/environment
下記を追記します。
AWS_DEFAULT_PROFILE=cliadmin
設定を反映するために、一度ログアウトして、再度ログインします。
再ログイン後、設定が反映されていることを確認します。
aws configure list
[ec2-user@ip-10-0-0-100 ~]$ aws configure list
Name Value Type Location
---- ----- ---- --------
profile cliadmin manual --profile
access_key ******************** shared-credentials-file
secret_key ******************** shared-credentials-file
region ap-northeast-1 config-file ~/.aws/config
カスタマーゲートウェイIDの確認
カスタマーゲートウェイのIDを確認します。(CustomerGatewayIdの値をメモします。)
aws ec2 describe-customer-gateways
[ec2-user@ip-10-0-0-100 ~]$ aws ec2 describe-customer-gateways
{
"CustomerGateways": [
{
"Tags": [
{
"Value": "aws-vpn-test-cgw",
"Key": "Name"
}
],
"IpAddress": "xxx.xxx.xxx.xxx",
"State": "available",
"CustomerGatewayId": "cgw-xxxxxxxxxxxxxxxxx",
"BgpAsn": "65000",
"Type": "ipsec.1"
}
]
}
仮想プライベートゲートウェイIDの確認
仮想プライベートゲートウェイのIDを確認します。(VpnGatewayIdの値をメモします。)
aws ec2 describe-vpn-gateways
[ec2-user@ip-10-0-0-100 ~]$ aws ec2 describe-vpn-gateways
{
"VpnGateways": [
{
"Tags": [
{
"Value": "aws-vpn-test-vgw",
"Key": "Name"
}
],
"VpcAttachments": [
{
"State": "attached",
"VpcId": "vpc-xxxxxxxxxxxxxxxxx"
}
],
"AmazonSideAsn": 64512,
"State": "available",
"VpnGatewayId": "vgw-xxxxxxxxxxxxxxxxx",
"Type": "ipsec.1"
}
]
}
クラウドフォーメーションのテンプレート作成
テンプレート作成用のディレクトリを作成します。
mkdir CloudFormation
cd CloudFormation
テンプレートファイルを作成します。
vi VPNConnection.yaml
下記を記述します。
AWSTemplateFormatVersion: '2010-09-09'
Resources:
# VPNConnection
VPNConnection1:
Type: AWS::EC2::VPNConnection
Properties:
Type: ipsec.1
StaticRoutesOnly: true
VpnTunnelOptionsSpecifications:
- TunnelInsideCidr: 169.254.173.148/30 ※トンネル1の内部 IPv4 CIDR
PreSharedKey: ******************************** ※トンネル1の事前共有キー
CustomerGatewayId: cgw-xxxxxxxxxxxxxxxxx ※カスタマーゲートウェイID
VpnGatewayId: vgw-xxxxxxxxxxxxxxxxx ※仮想プライベートゲートウェイID
Tags:
- Key: Name
Value: aws-vpn-test
VPNConnectionRoute1:
Type: AWS::EC2::VPNConnectionRoute
Properties:
DestinationCidrBlock: 192.168.1.0/24
VpnConnectionId:
!Ref VPNConnection1
VPNConnectionRoute2:
Type: AWS::EC2::VPNConnectionRoute
Properties:
DestinationCidrBlock: 172.16.0.0/24
VpnConnectionId:
!Ref VPNConnection1
クラウドフォーメーションのスタック作成
クラウドフォーメーションのスタックを作成し、テンプレートに記述したサイト間VPN接続を作成します。
aws cloudformation create-stack --stack-name vpnteststack --template-body file://VPNConnection.yaml
[ec2-user@ip-10-0-0-100 CloudFormation]$ aws cloudformation create-stack --stack-name vpnteststack --template-body file://VPNConnection.yaml
{
"StackId": "arn:aws:cloudformation:ap-northeast-1:xxxxxxxxxxxx:stack/vpnteststack/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
}
作成したスタックを確認します。
aws cloudformation describe-stacks
ステータスが”CREATE_IN_PROGRESS”となっていて、作成中であることがわかります。
[ec2-user@ip-10-0-0-100 CloudFormation]$ aws cloudformation describe-stacks
{
"Stacks": [
{
"StackId": "arn:aws:cloudformation:ap-northeast-1:xxxxxxxxxxxx:stack/vpnteststack/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"DriftInformation": {
"StackDriftStatus": "NOT_CHECKED"
},
"Tags": [],
"CreationTime": "xxxx-xx-xxT22:23:16.497Z",
"StackName": "vpnteststack",
"NotificationARNs": [],
"StackStatus": "CREATE_IN_PROGRESS",
"DisableRollback": false,
"RollbackConfiguration": {}
}
]
}
AWSの画面でも確認します。検索窓に”cloudformation”と入力し、表示される「CloudFormation」をクリックします。
data:image/s3,"s3://crabby-images/61a1a/61a1a0ad4da7ec10cb4002050de497e2eb44b43b" alt="CloudFormationの画面への遷移"
左のメニューで「スタック」を選択し、作成したスタックが表示されていることを確認します。
data:image/s3,"s3://crabby-images/457b3/457b3d530975a26caa31c7104c8431388724e90e" alt="スタックの確認"
対象のスタックをクリックすると詳細が表示されます。
data:image/s3,"s3://crabby-images/f7455/f745580c853594282c363ade5a54b822addf7e8b" alt="スタック詳細の確認"
「イベント」タブでスタック内のリソースの作成状況が確認できます。
data:image/s3,"s3://crabby-images/69582/69582cd88c62df55096f53eeadb30587c1bf4582" alt="スタックのイベントの確認"
数分後にもう一度確認すると、ステータスが”CREATE_COMPLETE”となり、スタックの作成が完了していることがわかります。
aws cloudformation describe-stacks
[ec2-user@ip-10-0-0-100 CloudFormation]$ aws cloudformation describe-stacks
{
"Stacks": [
{
"StackId": "arn:aws:cloudformation:ap-northeast-1:xxxxxxxxxxxx:stack/vpnteststack/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"DriftInformation": {
"StackDriftStatus": "NOT_CHECKED"
},
"Tags": [],
"CreationTime": "xxxx-xx-xxT22:23:16.497Z",
"StackName": "vpnteststack",
"NotificationARNs": [],
"StackStatus": "CREATE_COMPLETE",
"DisableRollback": false,
"RollbackConfiguration": {}
}
]
}
data:image/s3,"s3://crabby-images/52c66/52c662662ca739afdceb1c71bf603e8c272ba1ab" alt="スタック作成完了の確認"
サイト間VPN接続の確認
クラウドフォーメーションにより作成されたサイト間VPN接続を確認します。
aws ec2 describe-vpn-connections
[ec2-user@ip-10-0-0-100 CloudFormation]$ aws ec2 describe-vpn-connections
{
"VpnConnections": [
{
"Category": "VPN",
"VpnConnectionId": "vpn-xxxxxxxxxxxxxxxxx",
"Tags": [
{
"Value": "vpnteststack",
"Key": "aws:cloudformation:stack-name"
},
{
"Value": "VPNConnection1",
"Key": "aws:cloudformation:logical-id"
},
{
"Value": "arn:aws:cloudformation:ap-northeast-1:xxxxxxxxxxxx:stack/vpnteststack/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"Key": "aws:cloudformation:stack-id"
},
{
"Value": "aws-vpn-test",
"Key": "Name"
}
],
〜・〜・〜・〜・〜 中略 〜・〜・〜・〜・〜
"Routes": [
{
"DestinationCidrBlock": "172.16.0.0/24",
"State": "available"
},
{
"DestinationCidrBlock": "192.168.1.0/24",
"State": "available"
}
],
"State": "available",
"VpnGatewayId": "vgw-xxxxxxxxxxxxxxxx",
"CustomerGatewayId": "cgw-xxxxxxxxxxxxxxxxx",
"Type": "ipsec.1",
"Options": {
"RemoteIpv4NetworkCidr": "0.0.0.0/0",
"EnableAcceleration": false,
"TunnelInsideIpVersion": "ipv4",
"TunnelOptions": [
{
"TunnelInsideCidr": "169.254.173.148/30",
"PreSharedKey": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"OutsideIpAddress": "xxx.xxx.xxx.xxx"
},
{
"TunnelInsideCidr": "169.254.209.216/30",
"PreSharedKey": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"OutsideIpAddress": "xxx.xxx.xxx.xxx"
}
],
"StaticRoutesOnly": true,
"LocalIpv4NetworkCidr": "0.0.0.0/0"
},
}
]
}
AWSの画面でも確認します。
“aws-vpn-test”が作成され、使用可能となっています。
data:image/s3,"s3://crabby-images/d04a9/d04a910ede76f5a93e98386e61b7e7c58ab0c5e7" alt="サイト間VPN接続の確認"
指定した内部 IPv4 CIDR でトンネル1が作成されています。
data:image/s3,"s3://crabby-images/00c77/00c7785dca99a6ef5c010d3e8d8897cc479e1966" alt="サイト間VPN接続のトンネル設定確認"
指定した静的ルートも追加され、使用可能となっています。
data:image/s3,"s3://crabby-images/35cf7/35cf77ecc9c0cf80fa6a157cfe1af753a216d60d" alt="サイト間VPN接続の静的ルート設定確認"
サイト間VPN接続の削除
対象のスタックを削除することにより、自動的にサイト間VPN接続を削除することができます。
AWS CLIを利用して、スタックを削除するには下記のコマンドを実行します。
aws cloudformation delete-stack --stack-name vpnteststack
コマンド実行直後にスタックのステータスを確認すると、”DELETE_IN_PROGRESS”となっています。
aws cloudformation describe-stacks
[ec2-user@ip-10-0-0-100 CloudFormation]$ aws cloudformation describe-stacks
{
"Stacks": [
{
"StackId": "arn:aws:cloudformation:ap-northeast-1:xxxxxxxxxxxx:stack/vpnteststack/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"DriftInformation": {
"StackDriftStatus": "NOT_CHECKED"
},
"DeletionTime": "xxxx-xx-xxT22:53:08.707Z",
"Tags": [],
"CreationTime": "xxxx-xx-xxT22:23:16.497Z",
"StackName": "vpnteststack",
"NotificationARNs": [],
"StackStatus": "DELETE_IN_PROGRESS",
"DisableRollback": false,
"RollbackConfiguration": {}
}
]
}
AWSの画面上で確認すると、対象のスタックが削除されています。
data:image/s3,"s3://crabby-images/d0a1a/d0a1a69684590787737f8aa8ac146c13cd0a5bd6" alt="スタックが削除されたことを確認"
サイト間VPN接続に関しても、削除されていることがわかります。
data:image/s3,"s3://crabby-images/495e2/495e2f934ae8fc734909e9d68186d1d5f3f2c032" alt="サイト間VPN接続が削除されたことを確認"
これで、AWSサイト間VPNの構築(7.AWS CLI によるVPN接続の作成)の説明は完了です!