目录

给轻量应用腾讯云服务器或阿里云服务器加上IPV6地址隧道(2023)

给轻量应用腾讯云服务器加上IPV6地址隧道

这里使用6in4方法解决宿主机本身没有IPV6地址的问题。

给宿主机附加免费的IPV6地址段

有的机器本身没有IPV6的/64子网,这里给出一个方法免费附加IPV6的子网。

这里是使用6in4方法解决宿主机本身没有IPV6地址的问题。

以下是2023年目前还在运行的免费提供IPV6子网的平台

支持的平台 对应需要的安装包 协议 通道/子网数量
tunnelbroker.net ifupdown 或 ifupdown2 v4tunnel 或 sit 3✖/64 或 5✖/64
tunnelbroker.ch ifupdown 或 ifupdown2 v4tunnel 或 sit 3✖/64
ip4market.ru ifupdown 或 ifupdown2 v4tunnel 或 sit 1✖/64
netassist.ua ifupdown 或 ifupdown2 v4tunnel 或 sit 1✖/64
https://github.com/oneclickvirt/6in4 ifupdown2 sit、gre、ipip 自定义

免费的平台只解决IPV6有没有的问题,不提供优质的IPV6带宽。

如需优质的带宽,请自建隧道,当ifupdown和ifupdown2都可时,先尝试ifupdown是否可安装成功,否则就安装ifupdown2.

安装完毕后,安装了哪个包后面就选择哪个包进行格式转换。

初始环境修改

执行

1
touch /etc/cloud/cloud-init.disabled

关闭cloud-init的自动化覆写先,然后查看本机使用什么管理网络,执行

1
systemctl is-active systemd-networkd

1
systemctl is-active networking

看看属于哪种情况,如果是前者active,后者inactive,你需要重装/DD一个不是这样配置的系统,或者切换本机使用ifupdown/ifupdown2管理网络

1
2
3
4
5
# 是否需要禁用原网络管理自行评判
# systemctl stop systemd-networkd
# systemctl disable systemd-networkd
# systemctl stop systemd-networkd.socket
# systemctl disable systemd-networkd.socket

如果需要安装的是ifupdown控制网络,这个工具一般的主流linux系统都有

1
apt-get install ifupdown -y

如果需要安装的是ifupdown2进行网络管理,而这个工具一般只在debian系上可安装使用

1
apt-get install ifupdown2 -y

安装完毕后,安装了哪个包后面就选择哪个包进行格式转换。

1
2
systemctl start networking
systemctl enable networking

然后重启服务器,检验机器的网络是否会因为修改出现重启失联的情况,且执行uptime观察启动已超过1分钟后,再进行后续步骤

如果是是前者inactive,后者active,则不需要切换网络管理程序,直接进行后续操作即可。

由于部分服务器存在默认的内网IPV6路由会与隧道冲突,此时可使用以下命令删除默认的IPV6路由

1
default_route=$(ip -6 route show | awk '/default via/{print $3}') && [ -n "$default_route" ] && ip -6 route del default via $default_route dev eth0

这里假设了你的客户端的服务器的默认网卡是eth0,你可以使用ip -6 route查看默认的路由并替换它,默认路由以default via开头,使用dev指定默认网卡,你只需要按照这个规则找到它即可

tunnelbroker_net

结合一键开设带IPV6地址的容器的脚本,就能给每个容器附加来自he的IPV6地址了

缺点是地址比较黑/脏,cloudflare的cdn极有可能套不上,自行测试

  1. https://tunnelbroker.net/ 注册账户,并点击左边的 Create Regular Tunnel

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/35923be5-821f-45c8-8401-962ea3f97726

  1. 红框处填写你的服务器的IPV4地址,选择物理距离近的连接点,比如机器在美国洛杉矶,就选美国西海岸的连接点,然后显示绿框提示,点Create Tunnel创建即可

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/cab04113-4d6a-4d6f-9952-d3851057fc4a

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/518dc62a-c8d0-48e3-bb13-befc39348990

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/6188de3f-e83c-400e-9594-dd3f73aaf46a

  1. 等待出以下界面,点击Example Configurations然后选择对应的系统,比如LXD的宿主机那肯定就是Debian/Ubuntu了

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/9f0045fc-b1ac-4954-9ecd-1fba47d07d8a

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/2fb7c951-371c-452c-b775-78f69b980a2c

  1. 框住的部分就是要修改的文件和需要复制的内容了

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/c0156902-b4c0-4001-823e-50f611215393

复制的时候不要带空行

  1. 转换格式后给你的网络配置文件附加IPV6的设置

然后打开 https://ipv6tunnel.spiritlhl.top/ 选择OptionTunnelBrokerNet,另一个下拉选择框选择你之前安装成功的包名,然后在输入框内粘贴你复制的内容

然后点击Covert转换格式,等待页面刷新显示转换格式后的配置文件内容

然后用vim或者vi命令修改/etc/network/interfaces文件增加内容,或者修改以下命令新增

1
2
3
tee -a /etc/network/interfaces <<EOF
# 这里修改复制粘贴一下转换格式后的配置文件内容,然后执行此命令
EOF

然后你可以使用cat /etc/network/interfaces查看配置文件是否正常写入了

  1. 如果上面都没问题,就需要启用网络接口即可
1
2
apt-get install net-tools iproute2 -y
systemctl restart networking
  1. 然后你就可以测试IPV6网络是否已附加

执行ifconfig命令,这时应该有一个 he-ipv6 接口,类似下面这样:

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/1760af85-2b60-4352-ad8c-3c69e49fc1e4

或者执行:

1
curl ipv6.ip.sb

回传你绑定IPV6地址

  1. NAT VPS 的额外设置

IPv4 NAT VPS 除了前面提到的替换 IP 操作以外,可能还需要一些额外的设置,否则可能还是无法访问 IPv6 网络。

1
2
apt-get install ufw -y
ufw allow 41

添加相关的路由规则

1
route -A inet6 add ::/0 dev he-ipv6
  1. 如果不需要该IPV6网络了,想要删除

删除 he-ipv6 网络接口配置(若没有删除重启后会自动启用),记得修改/etc/network/interfaces文件,删除之前红框添加的内容

然后重启服务器,就删除了

tunnelbroker_ch

类似上述的操作,先在 https://www.tunnelbroker.ch/ 注册一个账户先,注册后点击激活的邮件

然后就是填写你的服务器IPV4地址

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/e018c7bc-e73c-4c68-88b6-b073f0dbd150

创建后需要进入Config页面而不是详情页面

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/d919dda7-571d-45b1-9d2f-03f29866269e

见到以下页面千万别使用,先刷新一下本页面,不要弹那个浅蓝色框后再停止刷新

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/aefd1477-d5f5-4a4e-a66c-80ef5f9250c6

记录以下页面的最后一个红框的内容,准备修改宿主机配置文件

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/9329974c-9549-4ff2-a8a0-a53c00e2863d

页面的最后一个红框框住的部分复制下来,不要带空行

然后打开 https://ipv6tunnel.spiritlhl.top/ 选择OptionTunnelBrokerCh,另一个下拉选择框选择你之前安装成功的包名,然后在输入框内粘贴你复制的内容

然后点击Covert转换格式,等待页面刷新显示转换格式后的配置文件内容

然后用vim或者vi命令修改/etc/network/interfaces文件增加内容,或者修改以下命令新增

1
2
3
tee -a /etc/network/interfaces <<EOF
# 这里修改一下
EOF

然后你就需要重启一下系统,或者执行

1
2
apt-get install net-tools iproute2 -y
systemctl restart networking

保证环境无问题再进行别的操作了

ip4market_ru

类似上述的操作,先在 https://tb.ip4market.ru 注册一个账户先,注册邮箱得是非常见邮箱,电话可随便写不验证的,IP填上你要附加的宿主机的IPV4地址

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/24df37f2-12fe-49b6-87df-f07213346fbe

然后就是过Recaptcha的人机验证,点击注册

邮箱会收到激活邮件,里面附带有你的密码,记住它

然后在首页进行登录

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/38b3f5a7-a5e1-47e0-b13e-8570e946c61c

然后就会进入这个页面

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/fc1d38b9-b45a-41de-a931-5dbe96e9791c

按住右键,然后复制红框框住的四行内容,也就是

1
2
3
4
Server IPv4:
Client IPv4
Server IPv6
Client IPv6

这四行内容,按ctrl+c复制或者右键复制

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/69c946e6-e82f-4665-b3c1-3c97e27f8487

然后打开 https://ipv6tunnel.spiritlhl.top/ 选择Optionip4market,另一个下拉选择框选择你之前安装成功的包名,然后在输入框内粘贴你复制的内容

然后点击Covert转换格式

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/b9ca3ee1-4f13-4e10-bdc8-1ed1cc23ab05

然后就会自动刷新页面出现需要自己用vim或者vi命令修改/etc/network/interfaces文件增加的内容了,或者修改以下命令新增

1
2
3
tee -a /etc/network/interfaces <<EOF
# 这里修改一下
EOF

然后你就需要重启一下系统,或者执行

1
2
apt-get install net-tools iproute2 -y
systemctl restart networking

保证环境无问题再进行别的操作了

netassist_ua

这个平台你在切换网络管理时务必使用ifupdown2而不是ifupdown2安装包,该平台使用sit协议,而sit协议需要在ifupdown2控制的环境中使用

类似上述的操作,先在 https://tb.netassist.ua/ 注册一个账户先,注册后点击激活的邮件,激活页面会有密码显示,记得记录

然后就是填写你的服务器IPV4地址,这个后面可以自己修改,先随便填一个都没问题

然后就到了这个页面了

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/4af680d4-3b01-495a-91d1-3cf4f187d0df

第一个红框是你宿主机的IPV4地址需要填写的位置,要修改就修改那里,然后点change保存

第二个下拉红框选择Linux,然后点击show

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/099d43a0-0397-4e02-9275-9ec3099c0ff1

会出现上面的内容,全选框住的部分复制下来,不要带空行

然后打开 https://ipv6tunnel.spiritlhl.top/ 选择OptionNetAssist,另一个下拉选择框选择你之前安装成功的包名,然后在输入框内粘贴你复制的内容

然后点击Covert转换格式

https://github.com/oneclickvirt/oneclickvirt.github.io/assets/103393591/7324c7ff-d22f-4c17-b3c2-b5338ca6dfee

然后就会自动刷新页面出现需要自己用vim或者vi命令修改/etc/network/interfaces文件增加的内容了,或者修改以下命令新增

1
2
3
tee -a /etc/network/interfaces <<EOF
# 这里修改一下
EOF

然后你就需要重启一下系统,或者执行

1
2
apt-get install net-tools iproute2 -y
systemctl restart networking

保证环境无问题再进行别的操作了

转移不同服务器之间的IPV6子网

相关仓库:https://github.com/oneclickvirt/6in4

该方法将提供一种方式,将A上的IPV6网段拆分一个子ipv6网段的出来,附加到B上使用

你需要在B所在的服务器上使用本套脚本给容器一键配置IPV6地址

功能

  • 自建sit/gre/ipip协议的IPv6隧道
  • 支持自定义要切分出来的IPV6子网大小,将自动计算出合适的CIDR格式的IPV6子网信息
  • 自动识别服务端的IPV6子网大小
  • 将自动设置隧道服务端并打印客户端需要执行的命令
  • 设置IPV6隧道的方法简单易懂,易于删除

环境准备

VPS(A) VPS(B)
一个IPV4地址(server_ipv4) 一个IPV4地址(clinet_ipv4)
一个IPV6子网 无IPV6地址
以下称之为服务端 以下称之为客户端

使用方法

下载脚本

1
curl -L https://raw.githubusercontent.com/oneclickvirt/6in4/main/6in4.sh -o 6in4.sh && chmod +x 6in4.sh

执行命令

1
./6in4.sh client_ipv4 <mode_type> <subnet_size> 
选项 可选的选项1 可选的选项2 可选的选项3
<mode_type> gre sit ipip
<subnet_size> 64 80 112

<mode_type>暂时只支持那三种协议,越靠前的越推荐,不填则默认为sit协议

<subnet_size>只要比原系统子网掩码大就行,且是8的倍数,不填则默认为80

记得client_ipv4替换为需要附加IPV6的机器的IPV4地址,执行完毕后会回传你需要在客户端执行的命令,详见执行后的说明即可

为防止忘记复制命令,命令本身也将写入到当前路径下的6in4.log文件中,可使用cat 6in4.log查询客户端需要执行的命令

复制下来的命令,务必在 https://ipv6tunnel.spiritlhl.top/ 中选择选项6in4后进行转换

然后就会自动刷新页面出现需要自己用vim或者vi命令修改/etc/network/interfaces文件增加的内容了,或者修改以下命令新增

1
2
3
tee -a /etc/network/interfaces <<EOF
# 这里修改一下
EOF

然后你就需要重启一下系统,或者执行

1
2
apt-get install net-tools iproute2 -y
systemctl restart networking

保证环境无问题再进行别的操作了

检测服务端

1
systemctl status ndpresponder
1
ip addr show

检测客户端

1
ip addr show
1
curl ipv6.ip.sb

删除隧道

服务端

1
2
ip link set server-ipv6 down
ip tunnel del server-ipv6

客户端

1
2
ip link set user-ipv6 down
ip tunnel del user-ipv6

以上删除的方式只是临时删除,永久删除务必修改删除/etc/network/interfaces文件中你之前增加的内容