Contents
ネットワークACLを試してみる
今回はセキュリティグループ(Security Group)での通信制御について確認してみます。
構成は下記をベースにしています。
data:image/s3,"s3://crabby-images/5db3c/5db3c8472601c10d4c17ac37925be25ae14eb300" alt=""
(1)EC2でApacheを動かして自分のパソコンからアクセスする
(2)パブリックのEC2からプライベートのEC2にPingを打つ
最初はネットワークACLとセキュリティグループの違いがややこしかったり、
一番最初に設定されている状態がどうで、新規に作成した時の状態がどうとか少し覚えるのが大変ですが、少しずつ慣れていきましょう。
EC2でApacheを動かして自分のパソコンからアクセスする
data:image/s3,"s3://crabby-images/2fec9/2fec9c777f80695f9a59ecaf028c823905b667e5" alt=""
パブリックIPを確認してSSHでEC2にログインする。
EC2でapacheを動かす
data:image/s3,"s3://crabby-images/4815f/4815fdc2e407672539c059785e5a0376887cf322" alt=""
Apacheをインストールします。
data:image/s3,"s3://crabby-images/a3357/a335708695faaa0f344425a2ea9cee2249164390" alt=""
Apacheを起動します。
data:image/s3,"s3://crabby-images/19c77/19c77064220c1226e2a5669ff4170e9d5e8611a6" alt=""
ブラウザにパブリックIPを入力しましたが、
アクセスできない状態です。
data:image/s3,"s3://crabby-images/9a4ac/9a4ac6ce6e2a88ecbbb968b906a76d3a9117561f" alt=""
まずネットワークACLの状態を確認します。
インバウンドで全ての通信を許可しています。
つまりネットワークACLでは拒否していないことが分かります。
次にセキュリティグループの設定を確認します。
data:image/s3,"s3://crabby-images/66108/661085294b1de4b7f9de9a1f0d968b9c48b72f93" alt=""
パブリック用のEC2を選択して、右下のセキュリティグループのlaunch-wizard-1をクリックします。
data:image/s3,"s3://crabby-images/3a4be/3a4befa69a76aa5a24f180ff4f6895b144ad46d9" alt=""
インバウンドルールのタブをクリックします。
SSHで使用する22番ポートのみ許可しています。
つまりHTTPで使用する80番ポートは許可していない事が分かります。
data:image/s3,"s3://crabby-images/a98df/a98dff36b7b5dab219e74df8ab16d8256ea99587" alt=""
インバウンドルールの編集をクリックします。
data:image/s3,"s3://crabby-images/9b15a/9b15aab730d3cc88de9bf143bfdd709aae865437" alt=""
ルールを追加するをクリックします。
data:image/s3,"s3://crabby-images/e28a9/e28a99de74c09e88023476ca7c03de4e5752413b" alt=""
HTTPの通信をどこからでも許可する設定を追加します。
data:image/s3,"s3://crabby-images/fd60e/fd60e5c20de838c3b7ca7de7d0ef425179fc9712" alt=""
HTTPを許可するルールが追加されました。
data:image/s3,"s3://crabby-images/85c95/85c95db6bbdbb1c8312626c34a9095b3adef36f5" alt=""
再度パブリックIPをブラウザに入力し、Apacheのデフォルトのページが表示されることを確認します。
EC2間でPingを打つ
data:image/s3,"s3://crabby-images/27cd3/27cd33c1d25fe020acede35023b3848ff4fca33a" alt=""
プライベートサブネットに設置したEC2のIPアドレスを確認します。
data:image/s3,"s3://crabby-images/594a1/594a11cb5766fd7d8f87022899d8377d968ff97b" alt=""
パブリックサブネットにあるEC2からプライベートサブネットにあるEC2にPingを実行し、
通らないことを確認します。
data:image/s3,"s3://crabby-images/d709e/d709ec456faec90a809680721b7c419291d63943" alt=""
プライベートサブネットに適用されているセキュリティグループをクリックします。
data:image/s3,"s3://crabby-images/ebf36/ebf3671727a6df6ff28e4e406f58f5be8d699f9d" alt=""
インバウンドルールのタブを選択し、Pingを許可するルールが無い事を確認してインバウンドのルールの編集をクリックします。
data:image/s3,"s3://crabby-images/1e273/1e273aaf3c6211df2cd1c52be6618b478c7a36ff" alt=""
全てのICMP-IPv4を許可します。
ソース(送信元)はパブリックサブネットのNWアドレスである10.0.100.0/24を指定。
data:image/s3,"s3://crabby-images/e57b7/e57b741bbf6247e7d5af0742b371d44eb6e8f085" alt=""
これでPingが通るようになりました。
セキュリティグループのおさらい
今回はパブリックサブネットのEC2にはHTTP通信の許可を、
プライベートサブネットのEC2にはICMP通信の許可の設定をしました。
セキュリティ関係はセキュリティグループの他にもネットワークACLやIAMポリシーなどもあり、曖昧にしていると混乱してくる可能性があります。
一つずつ簡単な設定を繰り返し行っていくことで、少しずつ整理できてくると思います。