AWS VPC IPv6 config
Description
Amazon Virtual Private Cloud (Amazon VPC) allows to launch AWS resources into a virtual network. VPC is very flexible and allows different scenarios to be defined/implemented based on custom needs. It closely resembles a traditional network that is operated in classic data center, with the benefits of using the scalable infrastructure of AWS.
Lab Schema
data:image/s3,"s3://crabby-images/85927/85927acbd5fcf7ea2d4577a01ae0451cedce3171" alt="schema"
Configs
1. Create VPC
Using AWS Console, select VPC service, next Your VPC and click "Create VPC"
data:image/s3,"s3://crabby-images/d0a4f/d0a4f57ca0121a67996f2f86a813b19267784d60" alt="1-Create VPC"
2. VPC IP configuration
Enter VPC Name tag, IPv4 address pool and select "Amazon provided IPv6 CIDR". AWS will reserve ::/56 network for VPC which can be splitted into ::/64 and assigned to the subnets
data:image/s3,"s3://crabby-images/2c2d9/2c2d95294bdfe80028a81accbebc0dbe890bc165" alt="2 VPC IP config"
3. Create subnets
Using AWS console (VPC service) create two subnets
data:image/s3,"s3://crabby-images/df149/df1499ce45ebc0bf5fd6d2d6a30a5d2af511575c" alt="3 Create Subnet"
4. Create public_1 subnet
Create first subnet (public_1) based on following:
Name: public_1
VPC: VPC created in #1
IPv4:10.0.0.0/24
IPv6: Custom (enter two hexes to define ::/64 network)
data:image/s3,"s3://crabby-images/e2fa9/e2fa96b86020a5986f48e9251fabbc409d4c7009" alt="4 Subnet public_1"
5. Create public_2 subnet
Create first subnet (public_2) based on following:
Name: public_2
VPC: VPC created in #1
IPv4:10.0.1.0/24
IPv6: Custom (enter two hexes to define ::/64 network)
data:image/s3,"s3://crabby-images/f2553/f255356786201b3b50f70c4137722a77c987f0c7" alt="5 Subnet public_2"
6. Set auto-assign IP settings
Subnets created in previous steps are not public, yet. To finish configuration process, IPv4 and IPv6 address auto-assign must be enabled
data:image/s3,"s3://crabby-images/77ba2/77ba22f552d220d8ea33b92bf4bd66a85692078f" alt="6 auto-assign IP"
7. Enable auto-assign for IPv4 and IPv6
For both subnets defined above, enable IPv4 and IPv6 auto-assign option
data:image/s3,"s3://crabby-images/14eb3/14eb3678a6d4dbc64265aafdcf5b3c2205a9f30c" alt="7 Enable auto-assign"
8. Subnet verification
Verify, if both subnets has been configured correctly (auto-assign option)
data:image/s3,"s3://crabby-images/c1191/c1191512f7cc98a5e2c0546f3d0e6df1560439e3" alt="8 Verify auto-assign for subnets"
9. Create Internet Gateway
Using AWS Console -> VPC service, create Internet Gateway
data:image/s3,"s3://crabby-images/e7d1c/e7d1cb3d5a2f260c9c4d93bbfdc8d3651fcea293" alt="9 Inet gateway"
10. Configure Internet Gateway
Enter Name tag for IGW
data:image/s3,"s3://crabby-images/ad2a1/ad2a1e051dca858a163bfed5d77ccbcfc2bcfa2e" alt="10 IGW - name tag"
11. Attach IGW to VPC (#1)
Use AWS Console to select "Attach to VPC" option for Internet Gateway
data:image/s3,"s3://crabby-images/22165/22165190f628665dda6b8d87f2271a2969a44929" alt="11 select VPC to be attached"
12. Attach IGW to VPC (#2)
Select previously created VPC to be attached to IGW
data:image/s3,"s3://crabby-images/6b4e9/6b4e9b285b0a0f77cb3494cfb82c9b9be6dbfad9" alt="12 Select VPC to be attached"
13. Verify Internet Gateway attachement
Using AWS Console verify, if IGW has been properly attached to VPC (it may take a while)
data:image/s3,"s3://crabby-images/6703b/6703bdbded683b32680a4acb7ea8dcc2f7a5e563" alt="13 Verify IGW attach"
14. Create Security Group
Using AWS Console -> VPC service, create security group
data:image/s3,"s3://crabby-images/3fedb/3fedb0de3dda6897e3f2ff704e364e3a6207a52c" alt="14 Security Group"
15. Security group details
Enter security group details including:
- name
- description
- VPC
data:image/s3,"s3://crabby-images/01cd3/01cd34acbefaa0999b4d0c54d771c8aa413979f2" alt="15 Security Group data"
16. Define Security group inbound rules
Use Edit button to start editing inbound rules
data:image/s3,"s3://crabby-images/a6ba0/a6ba0327a1a2a166b3e44fecb04da1d03b3379fa" alt="16 Inbound rules"
17. Edit Inbound rules
Using console, enter rules to define allowed traffic
data:image/s3,"s3://crabby-images/b06a1/b06a1bdeaefe6a2ba1290f8903a5719f2b9f0a4f" alt="17 Secusrity Groups rules"
18. Verify security group rules
Using AWS console, verify Inbound Rules
data:image/s3,"s3://crabby-images/c2623/c26230ad721dc90b90dfacb7de9dfb5ce75fb10f" alt="18 Verify Inbound rules"
19. Create route table
Using AWS console create route tables. In the example two route tables (one per each subnet) will be created
data:image/s3,"s3://crabby-images/cd562/cd5624664200b86605fd9f76f44d387a5e773f2f" alt="19 Create route table"
20. Create route table for public_1 subnet
Using AWS console create route table for public_1 subnet
data:image/s3,"s3://crabby-images/59f86/59f86c909406c75309b8b88017895c745fb5184f" alt="20 Route Table for subnet_1"
21. Create route table for public_2 subnet
Using AWS console create route table for public_2 subnet
data:image/s3,"s3://crabby-images/0364e/0364e56aed8dff25333c215ad745968364e59875" alt="21 Route Table for subnet_2"
22. Edit subnet associations for public_1
By default, all subnets are assocciated with the main route table. It can be changed by editing non-default route subnet associations
data:image/s3,"s3://crabby-images/f7762/f7762d6655054022c7e58d56c0cf997cd6b8feb3" alt="22 Subnet associations"
23. Select networks to be associated with public_1 route table
Different subnets can be associated with different route tables. In this example, pubic_1 will be associated with public_1_route_table
data:image/s3,"s3://crabby-images/7848b/7848bd63dcb5025f9c838cd037b66bdd85ade41d" alt="23 Select subnets to be assiciated with route table"
24. Select networks to be associated with public_2 route table
On following screen, pubic_2 will be associated with public_2_route_table
data:image/s3,"s3://crabby-images/1e16a/1e16a85ac5b3521fc347769cc9280ec58b2ca1d3" alt="24 Subnet associations"
25. Modify routes
Routes need to be added/modified, to allow communication with others (non-local) networks/subnets,
data:image/s3,"s3://crabby-images/f60c5/f60c5df1999cab20ea42e00b1ddd3b47fc25c7dd" alt="25 Edit routes"
26. Add default route for both IPv4 and IPv6
0.0.0.0/0 means anywhere for IPv4, the same can be defined as ::/0 for IPv6 traffic. Both routes need to be configured using previously created Internet Gateway as a target.
data:image/s3,"s3://crabby-images/34c46/34c4626fdf9d224dc04b2998970e3861dc6df26d" alt="26 Default routes"
27. Verify both routing tables
In both cases, default route for IPv4 and IPv6 should be passed via Internet Gateway
data:image/s3,"s3://crabby-images/4a5a3/4a5a34c6cff6389fa180a9e6df739c8871af44be" alt="27 Verify route tables"
Test Area
28. Deploy first test EC2 instance
Deploy first test machine in public_1 subnet. Both public IPv4 and IPv6 will be assigned (based on subnet setting)
data:image/s3,"s3://crabby-images/fcf96/fcf96da08f6aa53260c572c4451756a02d4b69c8" alt="28 Deploy 1st test machine"
29. Deploy second test EC2 instance
Deploy first test machine in public_2 subnet. Both public IPv4 and IPv6 will be assigned (based on subnet setting)
data:image/s3,"s3://crabby-images/1d535/1d535ac72fdc2caf1bffeb2013594bde634ca8fc" alt="30 Deploy test EC2"
30. EC2 Security Groups
Assign to both created test EC2 instances, previously configured security groups
data:image/s3,"s3://crabby-images/d84b0/d84b07a631929fafbf8adae4fd11a8f4f82b068a" alt="29 Assign security groups"
31. Verify IPv4 and IPv6 address
Verify, if both IPv4 and IPv6 has been properly assigned to each instance
data:image/s3,"s3://crabby-images/9e834/9e834f37131f603dfafa14f4ebc67e3a5abf9347" alt="32 Verify IP"
32. Check IPv6 conectivity (inside VPC)
Execute ping6 command from first to second test EC2 instance
data:image/s3,"s3://crabby-images/877fe/877fe5303a18f9a41c9ecb55b39a02c9951cdfd1" alt="Internal ping6"
33. Check IPv6 conectivity (AWS -> Internet)
Execute ping6 command from first EC2 instance to external address (www.google.com)
data:image/s3,"s3://crabby-images/e4942/e49423ed9f7bced34d24de3505c7d91cea83fb34" alt="36 AWS to Internet ping"
34. Check IPv6 conectivity (Internet -> AWS)
Execute ping6 command from external location to EC2 instance
data:image/s3,"s3://crabby-images/48737/4873743f674285b6e58de9e73b4e69f4f0fff566" alt="37 Internet 2 AWS ping"