初めに
最近流行りというわけではないですが、AWSをついに学びました。
自分はフロントのあれやこれやが好みで、インフラは避けて生きていたのですが
今回学ぶ機会があり、いろいろ調べて実際に構築してみたのでそれを書いていきたいと思います。
すごいですねAWS(小並感)
全体で3部構成の記事になります。
第1部 「AWSを避けていたPGがALBとEC2を利用してWEBアプリケーション環境を構築してみた」←今ここ
第2部 「LambdaとCloud WatchによるEC2の夜間停止」
第3部 「ALBによるパスルーティング」
前置き
0から始めるAWS入門:概要を基本的に参考にして構築をしております。
解釈や説明の誤りなど、コメント欄に記載していただけると幸いです。
構成図
自分が今回構築するのは下記のような環境です。
VPC内にEC2を構築し、ALBによるルーティング制御を行います。
VPC
まず初めにVPCの構築をしていきたいと思います。
最近HOME画面が変わったのかわかりませんがHOME画面からVPCを選択。
左のメニューから「Your VPCs」を選択して「Create VPC」ボタンをクリック。
data:image/s3,"s3://crabby-images/582fc/582fc46fb8c07828c86b5e6c937e188710b2dbe4" alt="スクリーンショット 2016-11-23 16.46.10.png"
Create VPCというポップアップが出るので項目を埋めていきます。
data:image/s3,"s3://crabby-images/b9359/b93598d0e07c3a3b08590e68b68279cf5b7f137e" alt="スクリーンショット 2016-11-23 17.02.34.png"
項目 | 値 |
---|---|
Name Tag | 適当に |
CIDR block | 10.0.0.0/16 |
tenancy | Default |
埋め終わったら「Yes,Create」をクリックして完了。
Internet Gateways
VPCはAWSにある独立した環境なのでこのままではインターネット等でアクセスができません。
そのためインターネットとVPCを繋げるInternet Gatewaysを作成します。
VPCの画面の左のメニューから「Internet Gateways」を選択し、「Create Internet Gateways」ボタンをクリック。
data:image/s3,"s3://crabby-images/e5501/e550188c1b3506d98d7c44ad645e94346cef9f6b" alt="スクリーンショット 2016-11-23 17.22.05.png"
Create Internet Gatewaysというポップアップが出るので項目を埋めていきます。
data:image/s3,"s3://crabby-images/42edd/42edd25651e3eaa73d7bd08485b2f15ab7d1e8eb" alt="スクリーンショット 2016-11-23 17.23.44.png"
項目 | 値 |
---|---|
Name Tag | 適当に |
埋め終わったら「Yes,Create」をクリックして完了。
その後、「Attach to VPC」ボタンをクリック。
data:image/s3,"s3://crabby-images/60e63/60e639a265c6c003f9503e5339117a6b0e340871" alt="スクリーンショット 2016-11-23 17.26.09.png"
Attach to VPCポップアップが出るので項目を埋めていきます。
data:image/s3,"s3://crabby-images/89734/897348301c6242d386e9a194132db5d2068cb998" alt="スクリーンショット 2016-11-23 17.27.26.png"
項目 | 値 |
---|---|
VPC | 先程作成したVPC |
埋め終わったら「Yes,Attach」をクリックして完了。
Route Tables
最後にRoute Tablesにルーティングの設定をして、インターネットの接続が完了します。
data:image/s3,"s3://crabby-images/ade03/ade037b9f5f1763da7c8f0393102ad921672feff" alt="スクリーンショット 2016-11-26 19.50.39.png"
VPCの画面の左のメニューから「Route Tables」を選択し、先程作成したVPCのRoute Tablesを選択し、下部に表示されるタブから「Routes」を選択し、「Edit」をクリックします。
data:image/s3,"s3://crabby-images/727d6/727d67917832e833d264846689971c9eab739a3b" alt="スクリーンショット 2016-12-04 14.54.28.png"
「Edit」をクリック後ルーティングの追加ができるため、項目を埋めていきます。
項目 | 値 |
---|---|
Destination | 0.0.0.0/0 |
Target | 先程作成したInternet Gateways(補完で出るかと思います) |
埋めたら「Save」をクリックして完了。
Subnet
VPCの構築が終わったら次にSubnetを作成します。
SubnetはALBで2つ紐付けるのが必須のため、Availability Zoneで分けて2つ作成します。
VPCの画面の左のメニューから「Subnets」を選択し、「Create Subnet」ボタンをクリック。
data:image/s3,"s3://crabby-images/79acd/79acdeab003ab1f40ef34cdac2ce5e1282eeb5c6" alt="スクリーンショット 2016-11-23 17.05.02.png"
Create Subnetというポップアップが出るので項目を埋めていきます。
data:image/s3,"s3://crabby-images/c06c3/c06c38cd85a984d74ff9a7183f2c07f2cd1d47d5" alt="スクリーンショット 2016-11-23 17.10.23.png"
1つ目
項目 | 値 |
---|---|
Name tag | 適当に |
VPC | 先程作成したVPC |
Availability Zone | ap-northeast-1a |
CIDR | 10.0.0.0/24 |
2つ目
項目 | 値 |
---|---|
Name tag | 適当に |
VPC | 先程作成したVPC |
Availability Zone | ap-northeast-1c |
CIDR | 10.0.1.0/24 |
埋め終わったら「Yes,Create」をクリックして完了。
EC2
VPCとSubnetの作成が終わったらいよいよEC2を作成します。
HOME画面からEC2を選択します。
data:image/s3,"s3://crabby-images/d53c0/d53c0397dbe9bde94e6d19a0b99e5ee5fc0d52b1" alt="スクリーンショット 2016-11-27 23.25.25.png"
左のメニューから「Instances」を選択して「Launch Instance」をクリックします。
data:image/s3,"s3://crabby-images/66444/66444576796107a47c61f26e915192d10d34c901" alt="スクリーンショット 2016-11-27 23.29.33.png"
Step 1: Choose an Amazon Machine Image (AMI)
Step 1でOSを選択します。
Amazon Linuxの右側の「Select」ボタンをクリック。
data:image/s3,"s3://crabby-images/7786a/7786a68f8523d2dd81e33f4933f6e1dca186a35f" alt="スクリーンショット 2016-11-27 23.31.23.png"
Step 2: Choose an Instance Type
次にStep 2としてインスタンスタイプを選択します。
デフォルトでチェックがついていると思いますが、t2.microの左側にチェックをいれ右下の「Next: Configure Instance Details」をクリック。
data:image/s3,"s3://crabby-images/6990f/6990ff58632b9e04af34dc2ce5c5d0f4f885759c" alt="スクリーンショット 2016-11-27 23.34.01.png"
Step 3: Configure Instance Details
次にStep 3としてEC2の詳細設定をしていきます。
下記項目と値を埋めていきます。
項目 | 値 |
---|---|
Number of instances | 1 |
Purchasing option | オフ |
Network | 先程作成したVPC |
Subnet | 先程作成したSubnet |
Auto-assign Public IP | Enable |
IAM role | None |
Shutdown behavior | Stop |
Enable termination protection | オフ |
Monitoring | オフ |
Tenancy | Shared |
下部のNetwork interfacesやAdvanced Detailsはそのままで右下の「Next: Add Storage」をクリック。
data:image/s3,"s3://crabby-images/f3d8c/f3d8c923060cdb9e94537d5a1c5a2ff92f0388cc" alt="スクリーンショット 2016-11-27 23.45.48.png"
Step 4: Add Storage
次にStep 4としてストレージを設定します。
下記項目と値を埋めていきます。
SizeもVolume Typeもデフォルトのまま右下の「Next: Add Tags」をクリック。
項目 | 値 |
---|---|
Size (GiB) | 8 |
Volume Type | General Purpose(SSD) |
data:image/s3,"s3://crabby-images/d8260/d8260e9719124a9a960535060c0399c02a452682" alt="スクリーンショット 2016-11-28 0.13.28.png"
Step 5: Add Tags
次にStep 5としてタグを指定します。
KeyはデフォルトのままNameにして、Valueにわかりやすいインスタンス名を入力して右下の「Next: Configure Security Group」をクリック。
項目 | 値 |
---|---|
Key | Name |
Value | 適当に |
data:image/s3,"s3://crabby-images/7cc01/7cc014b04c642ed41a1ac587a41bc892fd8e8b6d" alt="スクリーンショット 2016-11-28 21.47.44.png"
Step 6: Configure Security Group
次にセキュリティグループの設定をします。
今回EC2はALBからのみHTTPアクセスを受け付け、インターネット経由で直接アクセスされた場合はブロックするよう設定していきます。
また、SSHは自分のPCからのみ受け付けるよう設定します。
デフォルトではルールは一つだけのため「Add Rule」をクリックしてルールを増やします。
入力したら右下の「Review and Launch」をクリック。
※開発者がテストのため直接HTTPでアクセスしたい場合はHTTPのルールをMY IPに変更してください
SSH
項目 | 値 |
---|---|
Type | SSH |
Protocol | TCP |
Port Range | 22 |
Sorce | My IP (自動でIPが設定されます) |
HTTP
項目 | 値 |
---|---|
Type | HTTP |
Protocol | TCP |
Port Range | 80 |
Sorce | Custom (10.0.0.0/16) |
data:image/s3,"s3://crabby-images/2602a/2602a731631a744b28636c398d5dd8a65b87e0ee" alt="スクリーンショット 2016-11-28 22.08.56.png"
Step 7: Review Instance Launch
設定の確認をして、右下の「Launch」をクリック。
※画像は各タブを全て閉じています。
data:image/s3,"s3://crabby-images/d7279/d72793310ddabb7b82b58613d11133ce649d588c" alt="スクリーンショット 2016-11-28 22.24.44.png"
公開鍵、秘密鍵
最後にEC2のSSH接続のための公開鍵、秘密鍵の設定をします。
「Create a new key pair」を選択して新しい公開鍵、秘密鍵を作成します。
「Key pair name」に適当に名前を入力して「Download Key Pair」をクリックして、秘密鍵をダウンロードしてください。
秘密鍵は失くすと再発行はできないため、絶対に失くさないでください。
秘密鍵をダウンロードしたら「Launch Instances」をクリックして完了です。
data:image/s3,"s3://crabby-images/53b11/53b11e21d016fcf3843fb3ad39a38061bf5b12f8" alt="スクリーンショット 2016-11-28 22.34.35.png"
SSH
インスタンスはEC2の左のメニューのInstancesから一覧で見れます。
作成したEC2を選択して「Description」タブで詳細な情報が見れます。
SSHに必要なIPは右下の「Public IP」に記載されています。
data:image/s3,"s3://crabby-images/a8880/a88806b4ff2c6386700c5ff01a911322c1ca8586" alt="スクリーンショット 2016-11-28 23.08.56.png"
SSHは秘密鍵があるディレクトリに移動して下記コマンドを叩きます。
ssh ec2-user@【EC2のIP】 -i hoge.pem
初回時は「Are you sure you want to continue connecting (yes/no)?」と聞かれるため「yes」と入力して、SSH接続をします。
※「WARNING: UNPROTECTED PRIVATE KEY FILE!」と聞かれたら「sudo」をつけてSSHコマンドを叩いてみてください。
無事アクセスできたら、nginxをインストールして実際にEC2が起動しているのをブラウザからテストします。(テストのためセキュリティグループのHTTPにMy IPを付与している場合)
sudo yum install -y nginx
sudo /etc/init.d/nginx start
インストールして、起動したらブラウザにEC2のIPを入力して下記画面が出たらテスト完了です。
data:image/s3,"s3://crabby-images/974a7/974a746ab733b5ec69aef4ed395be34c22064b1d" alt="スクリーンショット 2016-11-28 23.30.33.png"
ALB
EC2も作成できたので次はALBを構築していきます。
ALBはApplication Load Balancerと呼ばれ最近発表された新しい機能です。
ELBと比べ、L7の機能が強化されています(HTTP2やWeb Socketに対応していたり、URLのパスによるルーティングを実装していたり)
ALBはELBと違ってロードバランサーにEC2を紐付けるのではなく、EC2をターゲットグループというグループでグループ化して、ターゲットグループをロードバランサーに紐付けます。
そのため、まずはターゲットグループを作成していきます。
Target Group
EC2の左のメニューから「Target Group」を選択し、「Create Target group」をクリック。
data:image/s3,"s3://crabby-images/93f33/93f33d34254cc3b45559cad1893ae7a5ca0f9a95" alt="スクリーンショット 2016-11-28 23.42.18.png"
Create target groupというポップアップが出るので項目を埋めていきます。
Health check settingsとAdvanced health check settingsはそのままで「Create」をクリックして完了です。
項目 | 値 |
---|---|
Target group name | 適当に |
Protocol | TCP |
Port | 80 |
VPC | 先程作成したVPC |
data:image/s3,"s3://crabby-images/756d5/756d54e5f90ebde24d86fdbcb19d2abcdfaec1c1" alt="スクリーンショット 2016-12-04 15.03.41.png"
ターゲットグループを作成したらターゲットグループにEC2を紐付けます。
ターゲットグループを選択してTargetsタブから「Edit」をクリック。
data:image/s3,"s3://crabby-images/f0f58/f0f58c089e870d1df345f9e8336d62434f0a2105" alt="スクリーンショット 2016-12-04 15.05.15.png"
Register and deregister instancesポップアップが出ます。
上部リストには現在紐付いているEC2の一覧、下部リストには現在起動してるEC2の一覧が表示されます。
data:image/s3,"s3://crabby-images/a8e96/a8e964c108f8e5f6d1ae6d5ead75f7525e091040" alt="スクリーンショット 2016-12-04 15.08.17.png"
下部リストから紐付けるEC2を選択して「Add to registerd」をクリックします。(下記画像はAdd to registerdクリック後)
EC2を紐付けたら右下の「Save」をクリックして完了です。
data:image/s3,"s3://crabby-images/651df/651df834baa9c7e1fcb0bf076c4d54aebfa9430c" alt="スクリーンショット 2016-12-04 15.10.28.png"
ALB
最後にALBを作成してALBにターゲットグループを紐付けて環境構築は完了です。
EC2の左のメニューから「Load Balancers」を選択し、「Create Load Balancer」をクリック。
data:image/s3,"s3://crabby-images/0d767/0d7672f4f1a392f2638ca29d8f44bf9c1efa6172" alt="スクリーンショット 2016-12-04 15.14.19.png"
ALBかELB(Classic Load Balancer)のどちらか聞かれるのでALBを選択して「Continue」をクリック(デフォルトでALBが選択されていると思います)
data:image/s3,"s3://crabby-images/373fc/373fce74657d9f997344818d68028b48139c6b1c" alt="スクリーンショット 2016-12-04 15.15.43.png"
Step 1: Configure Load Balancer
まず、NameとSchemeを埋めます。
項目 | 値 |
---|---|
Name | 適当に |
Scheme | internet-facing |
ListenersはHTTPを選択します。
項目 | 値 |
---|---|
Load Balancer Protocol | HTTP |
Load Balancer Port | 80 |
data:image/s3,"s3://crabby-images/f9f8d/f9f8db43e58747c0a68cbd40ab1d7f01d196ce3b" alt="スクリーンショット 2016-12-04 15.19.28.png"
Availability Zonesはまず、先程作成したVPCを選択します。
項目 | 値 |
---|---|
VPC | 先ほど作成したVPC |
VPCを選択すると、Available subnetsに先ほど作成したSubnetが2つ表示されます。
subnetの左側の「+」アイコンをクリックしてサブネットをSelected subnetsに移動させます。
data:image/s3,"s3://crabby-images/4e31f/4e31f51f0532c2e8db38489711440c8f10e696c1" alt="スクリーンショット 2016-12-04 15.22.51.png"
移動後
data:image/s3,"s3://crabby-images/13bdb/13bdb608fd55eebdb73aa24bd7fcdde3ca72bf3d" alt="スクリーンショット 2016-12-04 15.24.57.png"
移動させたら右下の「Next: Configure Security Settings」をクリック。
Step 2: Configure Security Settings
ここはListenersでHTTPSを選択した際の証明書を設置するところです。
今回はHTTPを選択しているので何もせず右下の「Next: Configure Security Groups」をクリック。
data:image/s3,"s3://crabby-images/04a2a/04a2a422fdf6f6f6de9d1f7d54d8cd059348f818" alt="スクリーンショット 2016-12-04 15.27.33.png"
Step 3: Configure Security Groups
次にALB用のセキュリティグループを設定します。
今回はテストのため自分のIPのみ許可します。(Anywhere 0.0.0.0/0で誰からも受け付けたり良しなに変えてください)
項目 | 値 |
---|---|
Type | HTTP |
Protocol | TCP |
Port Range | 80 |
Sorce | My IP (自動でIPが設定されます) |
作成したら右下の「Next: Configure Routing」をクリック。
data:image/s3,"s3://crabby-images/ee40e/ee40e33a4d5f00a1e69062922a25c0e790facf82" alt="スクリーンショット 2016-12-04 15.31.25.png"
Step 4: Configure Routing
次にALBにターゲットグループを紐付けます。
項目 | 値 |
---|---|
Target group | Existing target group |
Name | 先程作成したターゲットグループ |
Protocol | HTTP |
Port | 80 |
Health checksとAdvanced health check settingsはそのままで右下の「Next: Register Targets」をクリック。
data:image/s3,"s3://crabby-images/f7efe/f7efeeae21a8ff6ae7ba7ff986de50b08f061d95" alt="スクリーンショット 2016-12-04 15.33.07.png"
Step 5: Register Targets
ここでは登録されたEC2の一覧が表示されます。
ターゲットグループに登録されているEC2が表示されているのを確認したら右下の「Next: Review」をクリック。
data:image/s3,"s3://crabby-images/5a4c9/5a4c913d88c78c2ea29081ee7da606d04cf36d22" alt="スクリーンショット 2016-12-04 15.36.56.png"
Step 6: Review
最後に設定の確認をして、右下の「Create」をクリックしてALBの作成は完了です。
data:image/s3,"s3://crabby-images/07520/075204e42cdc244629620c2c65c882780f35c582" alt="スクリーンショット 2016-12-04 15.38.07.png"
確認
ALBのStateがactiveになっているのを確認したらALBのDescriptionタブのDNS nameをブラウザから叩けば先程作成したEC2にアクセスにでき、nginxのwelcomeページが表示されると思います。
data:image/s3,"s3://crabby-images/eabcc/eabcc8aaba3e3a74bedc06888c8329196ec2b2f2" alt="スクリーンショット 2016-12-04 15.45.00.png"
最後に
長くなりましたがこれで、基本的なWEBアプリケーション環境の構築は完了です。
まだ、サーバー構成などの知識はないですが、この環境にSSHの踏み台としてEC2を立ち上げたり、現状ALBがあまり役に立っていないのでターゲットグループに2つ目のEC2を紐付けたりいろいろやれることはありそうだなと実感しました。
次回はLambdaによるEC2の夜間停止を書いていきたいと思います〜。
※EC2やALBは起動していると料金が発生するので立ち上げたEC2は停止し、ALBは削除してください