Blog

Connect to an EC2 Instance Using IPv6 (with SSH)

Cover Image for Connect to an EC2 Instance Using IPv6 (with SSH)
Vicens Fayos

Introduction

In this post, I’d like to explain an issue I encountered recently. When connecting to my AWS services, I experienced a problem after my current ISP switched to IPv6.

While it’s great that the ISP finally made this step forward, my SSH access to my EC2 instances stopped working.

Previously, I was using a command like this:

ssh -i ~/.ssh/id_rsa vicens@my-amazon-dns.eu-west-3.compute.amazonaws.com

But it suddenly stopped working, and I received a timeout error.

Below, you’ll find the steps I followed to get it working again. You can, of course, refer to an LLM model for a similar explanation. In my case, it took some trial and error to resolve the issue, and I’d like to share what I learned with you

LLMs are great, but they can lead to significant time loss if you follow their instructions blindly without fully understanding what you're doing!

What is the problem?

The problem is that if you have a public IPv6 address, you can only connect to machines that are also using IPv6. Therefore, you need to enable IPv6 on the EC2 instance, as this is not done by default.

In a typical EC2 setup, you need to check and configure the following:

- Check if the VPC has IPv6 enabled and configure it properly if it does not.

- Check if the subnet has an IPv6 block (or more than one, as in my case) and configure it properly if it does not.

- Ensure the EC2 instance has an IPv6 address and configure it properly if it does not.

- Configure the security group associated with your instance to accept SSH requests (port 22) from your local public IPv6 address.

- Verify that the VPC is linked to the correct routing tables, and add the necessary route table for IPv6.

You can see the steps outlined in this public chat:

https://chatgpt.com/share/ad5070bc-c2b0-4c7c-a4c0-ea2218d3c29c

Since the routing table setup can be a bit tricky, I’ve summarized the commands I had to run below:

# verify VPC ID
`aws ec2 describe-vpcs --query 'Vpcs[*].{VpcId:VpcId,IsDefault:IsDefault}' --output json`

# List All Route Tables Without Filtering (important!) I got empty list when I ran other commands with filtering
`aws ec2 describe-route-tables --query 'RouteTables[*].{RouteTableId:RouteTableId,Associations:Associations}' --output json`

# Create a new route table (I did not need to do that because I had one)
aws ec2 create-route-table --vpc-id <vpc-id>

# Create the new route table
aws ec2 create-route --route-table-id <route-table-id> --destination-ipv6-cidr-block ::/0 --gateway-id <internet-gateway-id>

# associate it to your subnet
aws ec2 associate-route-table --route-table-id <route-table-id> --subnet-id <subnet-id>

## and just for your convinience the command to retrieve the subnet ID
aws ec2 describe-subnets --query 'Subnets[*].[SubnetId, VpcId]' --output text
```

Don't Use DNS with IPv6 (out of the box)

Since switching to IPv6, DNS resolution no longer works, as it is mapped to an IPv4 address such as `my-amazon-dns.eu-west-3.compute.amazonaws.com`.

# This does not work anymore
ssh -i ~/.ssh/id_rsa vicens@my-amazon-dns.eu-west-3.compute.amazonaws.com

# This work (IPv6 direcly)
ssh -i ~/.ssh/id_rsa vicens@1020:d013:7820:39e:9fc:440a:120e:66aa

It is possible to map a DNS to your IPv6 address, although I haven’t explored this option yet. It shouldn’t be too difficult to set up.

Additional Troubleshooting Steps

The setup I described worked for my _standard_ EC2 installation, given my local configuration. However, if you're still experiencing issues, you can try the following extra checks:

Can Your Local Machine Ping IPv6 Public Addresses?

Open a terminal and run this command, which pings Google’s IPv6 address:

ping6 2001:4860:4860::8888

Check the AWS NACL

NACL (Network Access Control List) is another layer of protection between the outside world and your EC2 instances. It acts as a subnet-level firewall. Normally, you don’t need to adjust anything here since it allows all inbound and outbound traffic by default. However, if you're still facing issues, double-check your NACL settings using your LLM.

Typically, security rules are managed through AWS security groups (the AWS logical layer) and in the EC2 instance itself if it has a firewall (as in my case).

Summary

I hope this post helps if you encounter the same issue. I’m experimenting with writing posts that truly provide value in our modern times, where LLMs often serve as a primary source of information. I’d love to hear your feedback!


Más historias

Cover Image for D4D - You Build it You Run it - Add Database Support

D4D - You Build it You Run it - Add Database Support

Integrating database support into your Next.js app with Kubernetes is simpler than you think!

Vicens Fayos
Cover Image for You build it, you run it

You build it, you run it

After being tasked with modernizing our CI/CD process, we developed a straightforward approach that significantly improved efficiency. Using a simple "Hello World" Next.js app as a reference, I realized this method could be applied across multiple technologies

Vicens Fayos