Building a VPC in AWS
For our very last lab about the network, we were given the following customer environment to build. By virtue of the fact the AWS management console GUI is constantly updated it meant that our task instructions were wholly out of date. However, this actually proved to only make it a far more involved and fun process - necessitating lots of troubleshooting when things had not spun up as expected.
I felt like I had learnt a lot more this way and for the benefit of my future self, I thought I would make some step by step notes (not necessarily in reference to the diagram above) to serve as prompts for any future cloud VPC's I'll be spinning up. Our challenge was to build the VPC as the diagram above.
- Create an elastic IP.
We will associate this later with our NAT gateway. - Launch your VPC with a private class IP range without forgetting to specific how many availability zones (AZ) you want.
- Create and label your subnets, again specifying what AZ, as none are public at the point of creation!
- Create an Internet Gateway (IGW).
- Associate your IGW with the desired VPC.
- Create your NAT Gateway and put it in the subnet you labelled as public.
Now you can associate the elastic IP we created at step one with our NAT Gateway. - We now need to make two different route tables, distinguishing between our intentions with the subnets - public and private.
- For the private subnets, we set our route table to point towards the NAT Gateway.
- For the public subnets, we set our route table to point towards the IGW.
- Now make sure to associate each route table to the relevant subnets.
- Create security group allowing http traffic from anywhere on the internet (0.0.0.0/0).
- Associate your security group with your instance.
- Launch an EC2 instance with auto public-IP and insert user data to auto-install the apache webserver app! Simples 😆