Kiến trúc xây dựng gồm các thành phần sau:
- VPC
- 2 Public subnet
- 2 Private subnet
- Internet Gateway
- NAT Gateway
- S3 VPC Endpoint
- Public Route Table
- Private Route Table
- Bastion host
- Web server
Sau khi xây dựng xong chúng ta sẽ tiến hành ssh đến Bastion host sau đó ssh đến Web server
Tại Web server ở Private Subnet, chúng ta thực hiện
- Test đi ra Internet
- Access đến S3 thông qua VPC Gateway Endpoint
Lưu ý
1. Create VPC
Chúng ta sẽ tạo VPC với các thành phần như: VPC + IGW + Subnet + Route Table + NAT
Tại Console VPC -> Click Create VPC
VPC settings
- Resources to create:
VPC and more
- Auto-generate:
check
- Tên:
d-vpc-saa-001
- IPv4 CIDR block:
10.0.0.0/16
- Number of Availability Zones (AZs) :
2
- Number of public subnets:
2
- Number of private subnets:
2
- NAT gateways ($):
In 1 AZ
- VPC endpoints:
S3 Gateway
- Còn lại để default
data:image/s3,"s3://crabby-images/01613/01613c3dfcf789850cb6fce56719db40b9990ed9" alt="Images"
Đợi 1 lúc để việc create VPC hoàn thành. data:image/s3,"s3://crabby-images/a4cef/a4cefbf1d1db2ce4bab9ae521bb0745ec49698fb" alt="Images"
2. Create Bastion host
Bastion host là EC2
- Đặt ở Public subnet
- Cho phép SSH từ local
- Có vai trò là máy trung gian để ssh đến các EC2 khác trong Private subnet
data:image/s3,"s3://crabby-images/98524/985241257fb6afaee8e1de62061d0ebb66b17188" alt="Images"
2.1 Create Security Group cho Bastion host
- Name:
d-sg-SAA-vpc-basion-host
- Description:
Allow ssh from internet
- VPC:
d-vpc-saa-001-vpc
- Inbound rules
Type | Protocol | Port range | Source |
---|
SSH | TCP | 22 | 0.0.0.0/0 |
- Outbound rules
Type | Protocol | Port range | Source |
---|
All traffic | All | All | 0.0.0.0/0 |
- Tags
Key | value |
---|
Name | d-sg-SAA-vpc-basion-host |
2.2 Create EC2
- Name:
d-ec2-SAA-vpc-bastion-host
- OS: Default (Amazon Linux 2023)
- Instance type: Default (t2.micro)
- Key pair:
d-key-SAA-common
(Nếu chưa có thì tạo mới) - Network Setting:
- VPC:
d-vpc-saa-001-vpc
- Subnet:
d-vpc-saa-001-subnet-public1-us-east-1a
- Auto-assign public IP:
Enable
- Select existing security group:
d-sg-SAA-vpc-basion-host
data:image/s3,"s3://crabby-images/3f442/3f442db5e9c72c2d0ca49a97712f65ac68d52ee9" alt="Images"
3. Create Web server đặt ở Private Subnet
3.1 Create Security Group cho private instance
- Name:
d-sg-SAA-vpc-private-instance
- Description:
Allow ssh from bastion host
- VPC:
d-vpc-saa-001-vpc
- Inbound rules
Type | Protocol | Port range | Source |
---|
SSH | TCP | 22 | Chọn SG của bastion host |
- Outbound rules
Type | Protocol | Port range | Source |
---|
All traffic | All | All | 0.0.0.0/0 |
- Tags
Key | value |
---|
Name | d-sg-SAA-vpc-private-instance |
3.2 Create private EC2
- Name:
d-ec2-SAA-vpc-private-instance
- OS: Default (Amazon Linux 2023)
- Instance type: Default (t2.micro)
- Key pair:
d-key-SAA-common
(Nếu chưa có thì tạo mới) - Network Setting:
- VPC:
d-vpc-saa-001-vpc
- Subnet:
d-vpc-saa-001-subnet-private1-us-east-1a
- Auto-assign public IP:
Disable
- Select existing security group:
d-sg-SAA-vpc-private-instance
data:image/s3,"s3://crabby-images/b09d1/b09d1c1b0a52804bb238c4a8e1a321adcd0322e7" alt="Images"
4. Đứng ở Bastion host ssh qua private instance
4.1 ssh đến bastion host
data:image/s3,"s3://crabby-images/93a7a/93a7a257ea05065bd963d3c811357d80b7ee30d7" alt="Images"
4.2 Tạo Keypair pem file để access tới private instance
4.3 ssh đến private instance:
Đứng tại bastion và run lệnh dưới: (nhớ thay giá trị web server private instance IP)
ssh -i "d-key-SAA-common.pem" ec2-user@{web server private instance IP}
data:image/s3,"s3://crabby-images/b22f1/b22f120c271a7ed241c2635228a11331f4939457" alt="Images"
5. Testing: "curl google.com"
Tại Web server, run lệnh:
Kết quả trả về như hình bên dưới xem như private instance đã đi dc Internet data:image/s3,"s3://crabby-images/4f94d/4f94d1ad95ba063ba0836bccab7a0b076b95ead5" alt="Images"
6. Modify IAM role để có thể access tới S3 từ private instance
Sử dụng lại role: SAAEC2S3FullAccessRole
đã tạo ở Bài EC2 Fundamentals data:image/s3,"s3://crabby-images/6dd99/6dd9972de4580ad5640041b0d771fdeb0db720d5" alt="Images"
7. Testing: "aws s3 ls"
Confirm access dc đến S3
data:image/s3,"s3://crabby-images/4d6c0/4d6c0069eca92a6ff1f58ea120de5d411d252894" alt="Images"
Clean up
Xóa lần lượt các resource theo thứ tự sau:
Delete NAT Gateway: d-vpc-saa-001-nat-public1-us-east-1a
Terminated 2 EC2: d-ec2-SAA-vpc-bastion-host
và d-ec2-SAA-vpc-private-instance
Release Elastic IP address: d-vpc-saa-001-eip-us-east-1a
(NAT Gateway phải ở status Deleted
thì mới Release dc EIP)
data:image/s3,"s3://crabby-images/5a9fc/5a9fcdcc4ab9f117c7b3f796e90d7fcf93a5570a" alt="Images"
Delete VPC
data:image/s3,"s3://crabby-images/fc7b3/fc7b3bbc4e4858b87e2f81fe5b66b6a10ef1db36" alt="Images"