About the Challenge
I manage a team of cloud developers, and one of the first things I teach them is understanding how AWS networks work. As cloud developers, we deploy our applications in Lambda and connect them with databases and other components inside our AWS VPC (virtual network in AWS). Because of this, it becomes imperative for them to know more about how VPCs work. They need to know how to navigate network issues they will encounter.
In this challenge, we would deploy an application to 2 servers inside a virtual network in AWS. The network will have two tiers: private and public. Our result will be:
Before we begin, here are a few helpful hints:
- This is a series of challenges that get progressively harder. It also meant to state what to do and what you should have learned. This is NOT a step-by-step guide on how to do the challenges.
- I have added links to AWS documentation to help you get started with the challenges.
- I have added guide questions to test your knowledge. It’s easy to follow documentation to make this all work. But what we are striving for is a true understanding of how these components work together for a secure, reliable, and working network.
[A] Basic VPC Skeleton
Let’s build the backbones of our VPC network. You’ll be creating:
- VPC (how)
- 2 Private Subnets (deployed in separate Availability Zones, how
- 2 Public Subnets (deployed in separate Availability Zones)
- 1 Internet Gateway (connected to the VPC we just created)
- 1 NACL for both subnets (with a rule that allows all traffic)
- 1 Route Table (for Private Subnets, how)
- 1 Route Table (for Public Subnets)
In this exercise, you must be able to answer the following guide questions:
- What makes a subnet private? What makes it public?
- What is an IPv4 CIDR block? What is the difference between /16, /20 and /24?
- Why do we deploy subnets in different availability zones?
Architecture Diagram for Exercise A:
[B] Setting up the instances
With the VPC backbone in place, let’s add more network components:
Here are a few guide questions to answer:
- DEMO: Be able to enter the CLI of the EC2 instance in the public subnet via SSH. Once inside, access the CLI of the EC2 instance in the private subnet.
- Why do we need a NAT Gateway? How does it operate?
- What is the difference between a NAT Gateway and an Internet Gateway?
- What is the difference between a security group and an NACL?
- Can a computer from the internet access the EC2 instance inside the private subnet? Why or why not?
- What is the difference between a NAT gateway and a NAT instance? When would you use a NAT instance? NAT gateway?
- What happens if you don’t assign a public IP Address to an EC2 instance?
Architecture Diagram for Exercise B:
What we achieved
We created our private network in the Cloud! We also created two EC2 instances, one in the private subnet and another in the public subnet.
[C] Setting up NGINX and load balancing
We’re getting close:
- EC2 instance (deployed in Private Subnet 1)
- EC2 instance (deployed in Private Subnet 2)
-
Install Nginx on both. Modify
/usr/share/nginx/html/index.html
to add “this is server one” for the 1st EC2 and “this is server two” for the second one. - Create an application load balancer
- Create a listener to receive HTTP traffic
- Create a target group that includes both EC2 instances as instance targets
Here are a few guide questions to answer:
- DEMO: Once the resources have been created, get the URL from the application load balancer and put it in your browser. It should alternate displaying “this is server one” and “this is server two”. This proves that the ALB is alternating sending traffic between the first and second EC2 instances.
- What is the difference between a NAT Gateway and an Application Load Balancer?
- Why put the EC2 instances in separate private subnets?
- Why put the EC2 instances in the private subnet instead of being exposed directly?
- Why add an application load balancer?
Architecture Diagram for Exercise C:
The result looks like this:
What we achieved
With Activity A-C, you have deployed your first VPC and have successfully deployed a simple app using a two-tier architecture. That’s honestly very close to how we deploy secure applications on the modern web.
There is one thing though. The application you accessed looked like something like this when typed in the browser:
http://jamby-alb-1962899873.ap-southeast-2.elb.amazonaws.com/
Two things come to mind when I see this:
First, the website is deployed on HTTP, not HTTPS, which leaves our end users insecure. As your end user browses your website, the data you send and receive goes across the internet unencrypted. The internet is made of thousands (or maybe millions) of routers connecting everyone in one big interconnected web. From your end user’s Macbook to your EC2 instance, there may be as many as 100 routers in between. if you leave your traffic as HTTP, any one of those 100 routers can see whatever you are sending between one another.
Second, as an e-commerce, I’d like to have a decent website name that my end users can easily remember. Something like:
jambyiscool.ecvphdevs.com
In exercise D, we will do just that.
Resources:
[D] Securing setup with HTTPS
Let’s take it a step further.
Architecture Diagram for Exercise D:
Here is the end result:
What’s next?
Congratulations on completing this exercise! You know have a full view on how VPC works, and have deployed your first application on a best practice version of a private network in AWS.
On the next challenge, we will be doing VPC peering, EC2 auto scaling, VPC endpoints and CI/CD. Stay tuned!
Photo by Nastya Dulhiier on Unsplash