...
| Excerpt | 
|---|
| Not like architectural diagram, setting up a VPC environment is not that easy. It requires to follow more steps after creating VPC.simple, because it requires to click lots of menus in AWS Console after creating that VPC. Based on my experience, that is not easy to remember, because it's rarely happening process and its complex clicking labors. So I think easy video guide is good enough. | 
Followings are overall steps associated with AWS Management Console -> Services from Top menu -> type "vpc" -> select VPC (isolated service) -> Create VPC
STEP 1. Create
...
two Elastic IP addresses for connection
https://ap-northeast-2.console.aws.amazon.com/ec2/v2/home?region=ap-northeast-2#Addresses:
- Allocate Elastic IP address and name it
STEP 2. Create
...
VPC
1) Create internet gateway: initial state will be "detached"
2) Attach to VPC
STEP 3. Create "Public Subnet"
1) Select VPC: it will automatically set set VPC CIDRs
2) set Availability Zone
3) set IPv4 CIDR block*: 10.0.1.0/24
STEP 4. Create "Private Subnet"
...
AWS Management Console → Services from Top menu → type "vpc". You can directly connect to that menu at https://ap-northeast-2.console.aws.amazon.com/vpc/home?region=ap-northeast-2
2) Launch VPC wizard: https://ap-northeast-2.console.aws.amazon.com/vpc/home?region=ap-northeast-2#wizardSelector:
- Select VPC with Public and Private Subnets
- Put proper name to VPC Name, Public subnet, Private subnet associated with Availability Zone1.
- Assign Elastic IP designed at STEP 1
- Leave other values as default like IPv4 CIDR block, Hardware tenancy, and etc.
STEP 3. Create internet gateway
- Your gateway would be automatically created. Just name it.
STEP 4. Create Subnets
https://ap-northeast-2.console.aws.amazon.com/vpc/home?region=ap-northeast-2#subnets:sort=SubnetId
| Name | IPv4 CIDR | Availability Zone | 
|---|---|---|
| PublicSubnet-az1 | 10.0.0.0/24 | az1 | 
| PrivateSubnet-app-az1 | 10.0.1.0/24 | az1 | 
| PrivateSubnet-db-az1 | 10.0.2.0/24 | 
STEP 5. Set Public Route Tables
1) Usually automatically generated, and requires renaming like "Public RT" for you
2) Select your route table -> move tap to "Routes" -> add route -> add "0.0.0.0/0" and set target to internet gateway definded at STEP 2
3) move tap to "Subnet Associations" -> Edit subnet associations -> Select only "public subnets" -> Save
STEP 6. Set Private Route Tables
1) Create Private Route Table and name it like "Private RT" for you
2) move tap to "Subnet Associations" -> Edit subnet associations -> Select only "private subnets" defined at STEP 4 -> Save
| az1 | ||
| PublicSubnet-az2 | 10.0.3.0/24 | az3 | 
| PrivateSubnet-app-az2 | 10.0.4.0/24 | az3 | 
| PrivateSubnet-db-az2 | 10.0.5.0/24 | az3 | 
STEP 5. Set Route Tables
Name Route Table ID by "Elplicit subnet association" and "Main" like below:
| Name | Explicit subnet association | Main | 
|---|---|---|
| PublicRT | subnet-**** | No | 
| PrivateRT | Yes | 
STEP 8
...
. Create security group
1) One default inbound rule will be listed
2) Add one more a rule : set Type to "SSH"  -> set →  set Protocol to "TCP"  -> set →  set Port Range to 22  -> set →  set Source to "My IP"  -> Your →  Your IP will be automatically assigned or your can simply assign 0.0.0.0/0
STEP 
...
9. Create network ACL
1) One default ACL will be listed, and just rename it in your own way
2) Set Inbound Rules
STEP 11. Create Load Balancer
Required for scalable service design. You will need to assign VPC Availability Zone that you created at STEP 2 like below:
STEP 10. Creating instances
https://ap-northeast-2.console.aws.amazon.com/ec2/v2/home?region=ap-northeast-2#Instances:
1) Launching Instances → Choose an AMI (Amazon Machine Image) → Free Tier only (if you are new)
2) Select Network by VPC designed at STEP 2
3) Select Subnet designed at STEP 3 and STEP 5
4) Enable "Auto Assign Public IP"
5) Configure Security Group based on you created at STEP 8
6) Download key Pair for secure connection → Launch Instances
Reference: https://www.youtube.com/watch?v=gUesnoDzNr4

