BAKRE JAMIU
Posted on October 17, 2024
Project: Creating Amazon Web Service (AWS) Virtual Private Cloud (VPC)
What is AWS VPC? Definition?
A VPC is a virtual network that closely resembles a traditional network that you'd operate in your own data center. After you create a VPC, you can add subnets.
How It Works?
A VPC provides a customizable, software-defined network (SDN) within the cloud, enabling:
Key Features:
- Resource Management: Provision and manage EC2 instances, RDS databases, and S3 storage.
- Network Segmentation: Define CIDR blocks, create subnets, and organize resources.
- Traffic Control: Configure gateways, route tables, and network ACLs for secure traffic flow.
- Access Control: Establish security groups, NACLs, and firewall rules for protected resource access.
Benefits:
- Logical isolation from other networks
- Enhanced data and application security
- Customizable network configurations
- Regulated inter-resource communication
VPC Implementation:
Follow along as we deploy this project in steps:
Section A: Create VPC
Section B: Provision resources (EC2)
Section C: Create Python application and run the project.
Get ready to secure your cloud infrastructure with VPC!
This example showcases creating a resilient VPC for production servers:
First login to your AWS console.
Section A: Setting up VPC on AWS console.
Step 1: Locate the search bar and type “VPC”
Step 2: This is how VPC will look like in Dashboard and click on VPC.
Step 3: name your project to VPC
Step 4: set it as default
Step 5: click on create VPC, this is how successful VPC is created.
Step 6: Click on view VPC, and go to resource map.
Section B: create an EC2 Instance. Login and connect with your terminal.
Step 1: Search for EC2
Step 2: Selecting the right region and name your EC2 instance, select preferred Linux distribution (Ubuntu)
Step 3: select free tier option for AMI (preferred) and select your pem key or create one.
Step 4: click on edit in network settings and select the option in the diagram, make sure you select the demo-VPC created and you can rename your security group name for easy identification.
Step 5: Leave the rest as default and click on launch instances.
Section C: Install the python application and the test run the security / vpc we created using terminal.
Step 1: Go to your new instance created, Click on connect.
Step 2: Open your terminal (Git Bash) and connect your EC2 instance.
Comments:
Make sure you change your directory where your pem key then connect using this cmd line:
ssh –i key.pem username@host
ssh –i cloud-jay-key.pem Ubuntu@34.236.38.205
step 3: update the packages this cmd line:
sudo apt update
Step 4: check if python is installed with cmd line:
“Python3 –version”
Step 5: run the application the cmd line:
python3 –m http.server 8000
Step 6: Run the python application on web run it with the ip
http:// 54.236.38.205:8000
You can see it is not accessible
Step 7: Go to vpc and check for Network NACL under security.
Step 8: You can see it is set and okay, let’s go security group.
Step 9: Go to Security groups, make sure you select the right security group id for demo-vpc, open it and check if the right port is open, which Custom TCP port 8000
Step 10: Edit the inbound rules.
Step 11: Under Inbound rules, add a new rule name custom TCP, add port 8000, under source select ip version 4 and save it and open the Python app again.
Step 12: Congratulation, Python app is accessible now.
Glossary
VPC: A VPC is a virtual network that closely resembles a traditional network that you'd operate in your own data center. After you create a VPC, you can add subnets.
Subnet: A subnet is a range of IP addresses in your VPC. A subnet must reside in a single Availability Zone. After you add subnets, you can deploy AWS resources in your VPC.
IP addressing: You can assign IP addresses, both IPv4 and IPv6, to your VPCs and subnets. You can also bring your public IPv4 and IPv6 GUA addresses to AWS and allocate them to resources in your VPC, such as EC2 instances, NAT gateways, and Network Load Balancers.
Network Access Control List (NACL): A Network Access Control List is a stateless firewall that controls inbound and outbound traffic at the subnet level. It operates at the IP address level and can allow or deny traffic based on rules that you define. NACLs provide an additional layer of network security for your VPC.
Security Group (SG): A security group acts as a virtual firewall for instances (EC2 instances or other resources) within a VPC. It controls inbound and outbound traffic at the instance level. Security groups allow you to define rules that permit or restrict traffic based on protocols, ports, and IP addresses.
Route table: Use route tables to determine where network traffic from your subnet or gateway is directed.
Gateway: A gateway connects your VPC to another network. For example, use an internet gateway to connect your VPC to the internet. Use a VPC endpoint to connect to AWS services privately, without the use of an internet gateway or NAT device.
Peering connections: Use a VPC peering connection to route traffic between the resources in two VPCs.
Traffic Mirroring: Copy network traffic from network interfaces and send it to security and monitoring appliances for deep packet inspection.
Transit gateways: Use a transit gateway, which acts as a central hub, to route traffic between your VPCs, VPN connections, and AWS Direct Connect connections.
VPC Flow Logs: A flow log captures information about the IP traffic going to and from network interfaces in your VPC.
VPN connections: Connect your VPCs to your on-premises networks using AWS Virtual Private Network (AWS VPN).
Resources:
VPC with servers in private subnets and NAT
https://docs.aws.amazon.com/vpc/latest/userguide/vpc-example-private-subnets-nat.html
Posted on October 17, 2024
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.