近日受夜空推荐发现了 ZeroTier 这个可以组建虚拟局域网的工具,由于利用的是类似 P2P 的原理因此可以用来进行内网穿透,在家中无公网 IP 的情况下建立 IPv6 隧道
首先,你需要一台 VPS,并注册一个 ZeroTier 帐号:https://my.zerotier.com
编辑/etc/sysctl.conf
,加入
net.ipv4.conf.all.forwarding = 1
net.ipv6.conf.all.disable_ipv6 = 0
net.ipv6.conf.default.disable_ipv6 = 0
net.ipv6.conf.lo.disable_ipv6 = 0
net.ipv6.conf.default.forwarding = 1
net.ipv6.conf.all.forwarding = 1
net.ipv6.conf.all.proxy_ndp = 1
net.ipv6.conf.all.accept_ra = 2
然后执行sysctl -p
更新系统配置
机器需要有/48
的地址块,否则后续无法成功打通隧道(我也并不是很明白具体缘由)
最简单的方法是将 VPS 接入 HE 的 IPv6 Tunnel Broker
https://tunnelbroker.net/
注册帐号后点击左侧“User Functions”中的“Create Regular Tunnel”,在“IPv4 Endpoint”中填入你 VPS 的 IP 地址,“Available Tunnel Servers”是自行选择一个隧道入口,就近选择即可,然后点最下方”Create Tunnel“,耐心等待
创建成功后你会来到隧道详情页面,你会看到”Routed /48“右侧有个”Assign /48“,点一下,申请/48
地址块,并记录下这个地址块①
接着点击上方”Example Configurations“,选择你 VPS 的系统
/etc/network/interfaces
文件中,然后执行/etc/init.d/networking restart
重载网络配置/etc/rc.local
中之后执行ifconfig
或者ip addr
,此时你应该可以看到多了一个叫 he-ipv6 的 interface,尝试ping6 google.com
可以确认是否成功接入HE的v6隧道
直接在 VPS 上执行
curl -s https://install.zerotier.com/ | sudo bash
安装完成后会显示一个 10 位的网络ID,请记下来②
在注册了 ZeroTier 帐号后,创建一个网络
进入这个网络的详情界面后,首先看到“Settings“,记下左上角的 Network ID ③;找到右侧的“IPv6 Auto-Assign”,勾选“ZeroTier RFC4193”,取消勾选“ZeroTier 6PLANE”
接着往下找到“Members”,在最下方“Manually Add Member”处输入我们之前记下的 ②,然后“+ Add New Member”,这时你会看到你的 VPS 出现在了网络成员列表中,并记下灰色的 fd35 开头的 IPv6 地址④
回到 VPS,执行此命令,用③替换<NetworkID>
zerotier-cli set <NetworkID> allowGlobal=true
回到网页上的“Settings“,在”Managed Routes“中添加两条路由
::0/0
,第二个空填④然后在”IPv6 Auto-Assign“处勾选”Auto-Assign from Range“,第一个空填①,然后别动,等待一会,会自动帮你填写好 v6 地址范围
以 Windows 为例:
前往 http://www.zerotier.com/download.shtml 下载客户端,安装
首次运行会让你登录 ZeroTier,登陆完后应该会自动帮你加入你在前面建立的那个虚拟局域网(Win10会提示发现新网络之类的),然后右击托盘图标,”Show Networks“,将”Allow Global IP“、”Allow Managed IP“、”Allow Default Route“这三个全部打勾
如果”Show Networks“中什么也没有,就右击托盘图标退出程序,再重开一次,这是 ZeroTier Windows 客户端的问题,重启才会更新网络信息
如果没有自动加入,就右击托盘图标,”Join Network“,输入框中填写③,并打勾所有勾,然后”Join“
接着我们需要设置 IPv6 DNS,打开 控制面板->所有控制面板项->网络和共享中心,点击”ZeroTier One [xxxxxxx]“的连接,属性,Internet 协议版本 6,设置 DNS 为谷歌 IPv6 DNS2001:4860:4860::8888
和2001:4860:4860::8844
,一路确定保存
尝试在命令提示符中ping -6 google.com
,Ping 通就说明成功接入 IPv6 了
https://lantian.pub/article/modify-computer/zerotier-one-own-ipv6-tunnel.lantian