In this tutorial, I am assuming that you have already created VPC with Public and Private subnets
data:image/s3,"s3://crabby-images/1c0d5/1c0d581ed5db3f8d14cc18adb13af6603928acc2" alt="modify vpc"
In the above scenario, we’ll create a micro instance inside the public subnet with an IP 10.100.10.0/24, which will act as the gateway for all the instance(s) inside the private subnet (10.100.20.0/24).
data:image/s3,"s3://crabby-images/59bd3/59bd31a9828ddf9644708f572e190c981ea6c930" alt="6"
Also, please create the separate Security Group for NAT instance:
data:image/s3,"s3://crabby-images/3218a/3218a7892ee1202dedd34fee73bd5237cd171973" alt="7"
After the creation of the NAT instance, you will notice, that it doesn’t have Public IP:
data:image/s3,"s3://crabby-images/ce94d/ce94de0760ce62f300c766024a007aaa8de5b765" alt="10"
To Fix this, select the Elastic IPs from the VPC console and click on “Allocate New Addresses“, select the VPC from “EIP used in” and click on “Yes,Allocate” :
data:image/s3,"s3://crabby-images/6275d/6275d84904bcb90b4211cd6f56cdc37123053b73" alt="11"
Assign the allocated Elastic IP to the NAT instance:
data:image/s3,"s3://crabby-images/c850b/c850b60e868d29d825682e6eee306800dc154562" alt="12"
Now, NAT instance has also Public IP:
data:image/s3,"s3://crabby-images/6ce0a/6ce0a67f95915c8c514022dc523e1d02882a1c54" alt="publicip"
From the EC2 console right click on NAT instance and select “Change Source / Dest. Check”:
data:image/s3,"s3://crabby-images/96729/9672973dbb5d6991534da00b7676d65475039598" alt="sd-check"
Click on “Yes,Disable”
data:image/s3,"s3://crabby-images/28234/28234aab71c3f1a8b2106638575654a9630d99d4" alt="Screen Shot 2014-04-23 at 10.51.21 am"
Connect to the NAT instance using terminal emulation software (i.e. putty), and allow the ip forwarding on it:
data:image/s3,"s3://crabby-images/30c04/30c044c22e544b34764f846c5eece2eb3e9034b4" alt="nat1"
Uncomment the following line:
net.ipv4.ip_forward=1
Issue the Iptables command for MASQUERADE:
iptables -t nat -A POSTROUTING -o eth0 -s 10.100.20.0/24 -j MASQUERADE
Modify the NAT instance security group to allow all or desired inbound traffic from private subnet (In my case, 10.100.20.0/24) or desired server.
data:image/s3,"s3://crabby-images/3bd75/3bd75eafe97016fe176bb37adf4c993285fb286e" alt="sg-1"
Create a custom route, associate your private subnet(s) to it and make a default route to use the NAT instance as a gateway:
data:image/s3,"s3://crabby-images/8f9ed/8f9ed094e24e2263506c72949925e989b83d50af" alt="rt-1"
data:image/s3,"s3://crabby-images/c3625/c362569ad4a22fcee17f6ad9c8ff2ee6f454a28b" alt="rt-2"
Testing from Server inside the Private Subnet:
data:image/s3,"s3://crabby-images/3462f/3462f4e17bace789dd43cc2e195c43398aaa625d" alt="ifconfig"
data:image/s3,"s3://crabby-images/85dbf/85dbfa7008e3e68ca6db31f3333ad7252ea4cf8c" alt="ping"
data:image/s3,"s3://crabby-images/76e2b/76e2b735acfb2fefda72fd7ea364a2ae6cabfca2" alt="traceroute_web"
Edit the /etc/rc.local file:
vi /etc/rc.local
data:image/s3,"s3://crabby-images/c735b/c735baedc3fe50681610b2140efefcdc2086454d" alt="pnat-1"
Add following to the rc.local before “exit 0“, so that, MASQUERADE will automatically enable at boot time:
iptables -t nat -A POSTROUTING -o eth0 -s 10.100.20.0/24 -j MASQUERADE
data:image/s3,"s3://crabby-images/7a345/7a345e34d3807f17dd8d62469c49cc2bc917ee2d" alt="pnat-2"
No comments :
Post a Comment