神代綺凜

[ZeroTier] 组建虚拟局域网,建立 IPv6 隧道
近日受夜空推荐发现了 ZeroTier 这个可以组建虚拟局域网的工具,由于利用的是类似 P2P 的原理因此可以用来...
扫描右侧二维码阅读全文
29
2018/12

[ZeroTier] 组建虚拟局域网,建立 IPv6 隧道

近日受夜空推荐发现了 ZeroTier 这个可以组建虚拟局域网的工具,由于利用的是类似 P2P 的原理因此可以用来进行内网穿透,在家中无公网 IP 的情况下建立 IPv6 隧道

Head Pic: 「WS.QE Xmas.ver★」/「ねめ猫⑥」のイラスト [pixiv]

使用 ZeroTier 建立 IPv6 隧道

首先,你需要一台 VPS,并注册一个 ZeroTier 帐号:https://my.zerotier.com

VPS 上的准备工作

系统配置

编辑/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更新系统配置

IPv6 环境

机器需要有/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 的系统

  • 如果是 Debian 或者 Ubuntu 就直接将展示的配置内容追加到/etc/network/interfaces文件中,然后执行/etc/init.d/networking restart重载网络配置
  • 如果是 CentOS,选择”Linux-route2“,直接执行配置中的命令,不过需要注意的是执行命令所建立的隧道是临时的,你可能需要把这些命令也添加到/etc/rc.local

之后执行ifconfig或者ip addr,此时你应该可以看到多了一个叫 he-ipv6 的 interface,尝试ping6 google.com可以确认是否成功接入HE的v6隧道

安装 ZeroTier

直接在 VPS 上执行

curl -s https://install.zerotier.com/ | sudo bash

安装完成后会显示一个 10 位的网络ID,请记下来②

ZeroTier 上的实际操作

在注册了 ZeroTier 帐号后,创建一个网络

  1. 进入这个网络的详情界面后,首先看到“Settings“,记下左上角的 Network ID ③;找到右侧的“IPv6 Auto-Assign”,勾选“ZeroTier RFC4193”,取消勾选“ZeroTier 6PLANE”

  2. 接着往下找到“Members”,在最下方“Manually Add Member”处输入我们之前记下的 ②,然后“+ Add New Member”,这时你会看到你的 VPS 出现在了网络成员列表中,并记下灰色的 fd35 开头的 IPv6 地址④

  3. 回到 VPS,执行此命令,用③替换<NetworkID>

    zerotier-cli set <NetworkID> allowGlobal=true
  4. 回到网页上的“Settings“,在”Managed Routes“中添加两条路由

    1. 第一个空填①,第二个空不填
    2. 第一个空填::0/0,第二个空填④

    然后在”IPv6 Auto-Assign“处勾选”Auto-Assign from Range“,第一个空填①,然后别动,等待一会,会自动帮你填写好 v6 地址范围

将设备接入虚拟局域网以获取 IPv6

以 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::88882001:4860:4860::8844,一路确定保存

尝试在命令提示符中ping -6 google.com,Ping 通就说明成功接入 IPv6 了

参考教程

https://lantian.pub/article/modify-computer/zerotier-one-own-ipv6-tunnel.lantian

搬瓦工VPS优惠套餐,建站稳如狗,支持支付宝,循环出账94折优惠码BWH26FXH3HIQ
年付$28CN2线路,1核/512M内存/10G硬盘/500GB@1Gbps【点击购买】(经常售罄,请抓紧机会)
年付$47CN2线路,1核/1G内存/20G硬盘/1T@1Gbps【点击购买
我的文章对您有帮助吗?
我很可爱 请给我钱
扫一扫拿红包 → 扫商家收款码 → 花呗支付比红包多1分钱的金额
既可免费赞赏,又可完成支付宝支付任务!
Last modification:December 29th, 2018 at 05:37 pm
If you think my article is useful to you, please feel free to appreciate

Leave a Comment

12 comments

  1. 小沨  Windows 7 x64 Edition(Windows 7 x64 Edition) / Google Chrome 72.0.3626.121(Google Chrome 72.0.3626.121)

    win客户端获取到地址,dns也设置了,可惜没网络,求教

    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.75(Google Chrome 73.0.3683.75)
      @小沨

      IPv4 那边是不用管的,是内网v4
      如果你能ping -6 google.com通就行,不通的话……我也帮不上忙

  2. emmm  Mac OS X 10.14.2(Mac OS X 10.14.2) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)

    |´・ω・)ノ

  3. Noob  GNU/Linux x64(GNU/Linux x64) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)

    有公网ip是不是可以直接弄ipv6呢?

    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
      @Noob

      可以,但是 HE 的隧道入口到大陆很多都是绕美的(比如jp),直接隧道使用网络体验不一定好

      如果是家宽公网IP基本都是动态的,重启一次猫就换一个,这样还得考虑用 HE 的 API 来更新公网IP设置

      1. Noob  Windows 8.1 x64 Edition(Windows 8.1 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
        @神代綺凜

        博主,我看到了你的console,我问一下,console里面能用css吗?

        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
          @Noob

          但是有局限性

        2. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
          @Noob

      2. Noob  Windows 8.1 x64 Edition(Windows 8.1 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
        @神代綺凜

        我路由器里面好像有这个功能,我去研究研究

  4. 小萌羽  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)

    OωO IPv6 5G时代快来了

  5. Zero  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)

    ∠( ᐛ 」∠)_

    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
      @Zero

      ∠( ᐛ 」∠)_你这沙发速度有点快