Skip to content

4to6 Tunnel

The 4to6 tunnel is similar to the 6to4 tunnel with the following advantages:

  1. Your effective IP address between two servers will be IPv6.
  2. IPv6 is inexpensive and can be changed easily if blocked.
  3. Your IPv4 addresses on both sides will be protected from blocking.

Technical Overview

The setup involves two nodes, A and B:

Tehran ------------------GFW----------------- Tokyo 
   A <---------------------------------------> B

A tunnel is created between these two nodes:

Tehran ------------------------------------------GFW----------------------------------------- Tokyo 
   A                                                                                          B
| virtual IPv4 <---- 4to6 ----> real IPv6 | <------IPv6-----> | real IPv6 <---- 4to6 ----> virtual IPv4 |

IPv4 packets are encapsulated within IPv6 packets and transmitted over an IPv6 network. If an IP is blocked, it will be an IPv6 address and can be easily replaced, as IPv6 addresses are generally more cost-effective than IPv4 addresses.

How to Use

You will need two servers with IPv6.

Server A

curl -o /tmp/4to6install.sh https://raw.githubusercontent.com/meshya/4to6-tunnel/main/scripts/install.sh; sudo bash /tmp/4to6install.sh; rm /tmp/4to6install.sh
Field Value
E0 Server A IPv6
E2 Server B IPv6
E4 192.168.1.1/24

Server B

curl -o /tmp/4to6install.sh https://raw.githubusercontent.com/meshya/4to6-tunnel/main/scripts/install.sh; sudo bash /tmp/4to6install.sh; rm /tmp/4to6install.sh
Field Value
E0 Server B IPv6
E2 Server A IPv6
E4 192.168.1.2/24

Testing

On Server A

ping 192.168.1.2

On Server B

ping 192.168.1.1

Warning

If one of your servers is already using a 192.168.x.x network, you may need to use 172.16.x.x/12 (e.g., 172.16.0.1/12 and 172.16.0.2/12) instead. If you are unsure, open an issue and include the output of ip addr.

Use Options

There are three methods to use the tunnel:

  1. IP/Port Forwarding
  2. Use Xray on Both Servers
  3. Use Custom Tunneling Methods

IP/Port Forwarding

For those unfamiliar with IP/Port forwarding, it is recommended to read more about it and perform the configuration manually.

This article provides guidance on setting up port forwarding.

Here is a quick setup guide:

To forward a single port (e.g., port 80), use the following settings (assuming virtual IPs of 192.168.1.1 for Server A and 192.168.1.2 for Server B).

Step 1

Server A

iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to-destination 192.168.1.2:80 
iptables -t nat -A POSTROUTING -j MASQUERADE 

Step 2

If the setup works, add the commands to local.rc.

Use Xray on Both Servers

Install the Xray service on both servers and configure Server A to route data through a proxy on Server B. This configuration can be simplified using 3x-ui. For assistance, contact me (I am available as meshya everywhere and meshyah on Telegram).

Note: Use 192.168.1.2 instead of the real IP of Server B when configuring Xray on Server A.

Use Custom Tunneling Methods

While not recommended, you can use custom tunneling methods such as Reverse TLS or Fake TLS on top of the 4to6 tunnel if you are familiar with these techniques.

Note: Use virtual IPs (192.168.x.x) instead of real IPs.

Tip

When using Method 2, consider adjusting routing rules and utilizing the Iran Hosted Domain Project to direct traffic for Iran-hosted websites and services, especially Shaparak and payment services, from an Iranian IP. This setup will prevent users from needing to toggle their proxies.

References

  1. 4to6 tunneling - Meshya

  2. Linux document project - ip4 in ip6 tunneling

  3. RFC2437




Article and main repo by Meshya


Last update: November 18, 2024

Comments