简介

ZeroTier 是一个加密的虚拟骨干网。它的客户端和服务端都是开源且免费的,对于一般的用户,可以用它做内网穿透,将处于不同内网中的主机组成虚拟局域网。可以解决很多P2P联网游戏/应用的需求。但目前的官方搭建的服务端Planet有25个设备的限制,所以可以考虑自己的Planet来突破25个设备的限制。

内网穿透工具花生壳、神卓互联、FRP、Zerotier哪个访问速度快? - 知乎 (zhihu.com)

搭建服务器

目前的云服务器有很多,主流的有阿里云腾讯云华为云京东云等。这些服务器一般是按月收费,只是单纯测试可用性,可以申请退款。如果觉得退款麻烦,也可以考虑三丰云,可以申请一天的免费虚拟主机用于搭建网页,也可以申请一天免费云服务器用于运行自己的内容。(实际会需要充值1元,进行实名认证,使用哪一种需要自己斟酌),当然,如果自己有带固定公网IP的服务器,那更推荐使用自己的服务器。

购买/申请云服务器

大部分的云服务商都可以选择配置,一般来说,需要选择靠近客户端的节点。配置也不需要太高,只需要单核/1M带宽就行,内存512M~1G,硬盘5~10G都行。




zerotier搭建docker moon服务器 zerotier 服务端_Powered by 金山文档


安装系统

大部分的云服务商都可以自己选择安装操作系统,建议选择Ubuntu16.04以上的系统。


zerotier搭建docker moon服务器 zerotier 服务端_网络_02


连接云服务器

这里推荐使用mobaxtermr软件,该软件官方提供个人免费版本。用ssh连接服务器,后续可以利用该软件传输文件,不用再另外搭建FTP服务器等,具体可搜索mobaxterm教程。

安装Zerotier根服务器

升级云桌面的软件

apt-get upgrade
apt-get dist-upgrade

安装nlohmann-json-dev

若使用的是Ubuntu16.04,在编译Zerotier的时候会出现找不到nlohmann/json.h的问题,需要安装nlohmann-json-dev:

wget http://kr.archive.ubuntu.com/ubuntu/pool/universe/n/nlohmann-json/nlohmann-json-dev_2.1.1-1.1_all.deb && dpkg -i nlohmann-json-dev_2.1.1-1.1_all.deb

安装Zerotier 和 ZtnCui

ZtnCui是一个开源免费的Zerotier第三方控制器,用于呈现Web页面,方便配置Zerotier

Ubuntu:

wget https://gitee.com/opopop880/zerotier_planet/raw/master/zerotier_planet_debain.sh && chmod +x zerotier_planet_debain.sh && ./zerotier_planet_debain.sh

会在/root目录里生成 planet文件


zerotier搭建docker moon服务器 zerotier 服务端_客户端_03


参考:

构建Zerotier私有根服务器(Planet),实现比MOON更稳定的内网穿透 - 知乎 (zhihu.com)

检查安装结果

方法1:

netstat -tunlp

若出现zerotier-one和ztncui 的监听端口就算成功。

方法2:

在本地机的浏览器输入:http://云服务器IP:3000, 若出现以下界面则算成功


zerotier搭建docker moon服务器 zerotier 服务端_客户端_04


配置Zerotier服务端

访问 http://云服务器IP:3000,用户名admin 密码 password

创建网络


zerotier搭建docker moon服务器 zerotier 服务端_服务器_05


配置网络

点击网络按钮


zerotier搭建docker moon服务器 zerotier 服务端_网络_06


点击简易安装->生成网络->提交:


zerotier搭建docker moon服务器 zerotier 服务端_Powered by 金山文档_07


点击ipv4分配模式


zerotier搭建docker moon服务器 zerotier 服务端_云服务_08


点击ipv6分配模式


zerotier搭建docker moon服务器 zerotier 服务端_客户端_09


配置Zerotier客户端

windows端

  • 安装官方客户端

Download – ZeroTier 自动安装后在右下角有ZeroTierUI, 先退出。

  • 停止ZeroTier服务


zerotier搭建docker moon服务器 zerotier 服务端_服务器_10


  • 替换Planet

将服务端的Planet下载下来


zerotier搭建docker moon服务器 zerotier 服务端_云服务_11


打开 C:\ProgramData\ZeroTier\One,备份其中的planet,用服务端的 planet替换本地的planet。


zerotier搭建docker moon服务器 zerotier 服务端_网络_12


  • 重启ZeroTier服务

重新启动ZeroTier服务,等待服务状态变为运行中。

  • 连接私有网络

a) 打开服务端的管理页面http://云服务器IP:3000的网络界面,复制其中的网络ID


zerotier搭建docker moon服务器 zerotier 服务端_Powered by 金山文档_13


b) 打开ZeroTierUI,右键点击加入网络,输入其中的网络ID,点击确认


zerotier搭建docker moon服务器 zerotier 服务端_网络_14


c) 重新打开服务端界面,给本地客户端授权


zerotier搭建docker moon服务器 zerotier 服务端_Powered by 金山文档_15


在客户端可以看到状态为OK就表示连接成功


zerotier搭建docker moon服务器 zerotier 服务端_服务器_16


d) 将需要互相连接的客户端,都按之前操作即可。

测试网络

延迟测试

利用ping测试

服务端延迟测试:45ms

两客户端间延迟(两个客户端分别位于深圳和福建):39ms

带宽测试

云服务商的签约带宽为:5M

两个节点直接的带宽测试:43M(客户端的上行带宽上限,iperf测试)

总结

Zerotier 可以实现内网穿透,将多个设备组成虚拟局域网。利用官方的服务器,比较方便且稳定,但是最多只能支持25个客户端,并且存在进一步下降的可能。自己建立了服务器可以突破这个限制,但是需要一个具有固定公网IP的服务器。