docker方式部署Zerotier Planet(Zerotier根服务器)
1、ZeroTier 介绍
(参考:GitHub - xubiaolin/docker-zerotier-planet: 私有部署zerotier-planet服务)
ZeroTier
这一类 P2P VPN 是在互联网的基础上将自己的所有设备组成一个私有的网络,可以理解为互联网连接的局域网。最常见的场景就是在公司可以用手机直接访问家里的 NAS,而且是点对点直连,数据传输并不经由第三方服务器中转。
Zerotier 在多设备之间建立了一个 连接,如:在笔记本电脑、台式机、嵌入式设备、云资源和应用。这些设备只需要通过 ( 的客户端) 在不同设备之间建立直接连接,即使它们位于 之后。连接到虚拟 LAN 的任何计算机和设备通常通过 或路由器设备与 连接, 使用 和隧道来建立 后设备之间的 VPN 直连。Peer to Peer VPN(P2PVPN)
ZeroTier One
ZeroTier
NAT
NAT
Internet
ZeroTier One
STUN
NAT
简单一点说, 就是通过 等方式实现形如交换机或路由器上 设备的内网互联。Zerotier
P2P
LAN
专有名词 PLANET :行星服务器,Zerotier 根服务器 MOON :卫星服务器,用户自建的私有根服务器,起到代理加速的作用 LEAF :网络客户端,就是每台连接到网络节点。 我们本次搭建的就是 PLANET 行星服务器
2:为什么要自建PLANET 服务器
简单来讲就是官方的服务器在海外,我们连接的时候会存在不稳定的情况
3、开始安装
1、具有公网 ip 的服务器(需要开放 3443/tcp 端口,9994/tcp 端口,9994/udp 端口)[这里的9994需要你根据实际情况替换] 安装 docker、git, Debian10+,Ubuntu20+ 等内核大于5.0的系统均支持 CentOS不支持,内核太低了,可能需要手动升级内核
2、安装git
#debian/ubuntu等
apt update && apt install git -y
#centos等
yum update && yum install git -y
3、安装docker
curl -fsSL https://get.docker.com |bash
4、启动docker
service docker start
5、下载项目源码
官方地址:
git clone https://github.com/xubiaolin/docker-zerotier-planet.git
加速地址:
git clone https://ghproxy.imoyuapp.win/https://github.com/xubiaolin/docker-zerotier-planet.git
6、执行安装脚本
进入项目目录:
cd docker-zerotier-planet
运行 deploy.sh
脚本
./deploy.sh
根据提示来选择即可,操作完成后会自动部署
欢迎使用zerotier-planet脚本,请选择需要执行的操作:
1. 安装
2. 卸载
3. 更新
4. 查看信息
5. 退出
请输入数字:
整个脚本预计需要 1-3 分钟,具体需要看网络与机型
当您看到类似如下字样时,表示安装成功
下载 planet
文件
脚本运行完成后,会在 ./data/zerotier/dist
目录下有个 planet
和moon
文件
可以直接访问安装完成后的url下载,也可以用scp等其他方式下载
下载文件备用
1、新建网络
访问 http://ip:3443
进入controller页面
使用默认账号为:admin
默认密码为:password
创建网络
进入后创建一个网络,可以得到一个网络ID
创建网络,输入名称
得到网络 id
分配网络IP
选中easy setup
生成ip范围
客户端配置
客户端主要为Windows, Mac, Linux, Android
Windows 配置
首先去zerotier官网下载一个zerotier客户端
将 planet
文件覆盖粘贴到C:\ProgramData\ZeroTier\One
中(这个目录是个隐藏目录,需要运允许查看隐藏目录才行)
Win+S 搜索 服务
找到ZeroTier One,并且重启服务
加入网络
使用管理员身份打开PowerShell
执行如下命令,看到join ok字样就成功了
PS C:\Windows\system32> zerotier-cli.bat join 网络id(就是在网页里面创建的那个网络)
200 join OK
PS C:\Windows\system32>
登录管理后台可以看到有个个新的客户端,勾选Authorized
就行
IP assignment 里面会出现zerotier的内网ip
执行如下命令:
PS C:\Windows\system32> zerotier-cli.bat peers
200 peers
<ztaddr> <ver> <role> <lat> <link> <lastTX> <lastRX> <path>
fcbaeb9b6c 1.8.7 PLANET 52 DIRECT 16 8994 1.1.1.1/9993
fe92971aad 1.8.7 LEAF 14 DIRECT -1 4150 2.2.2.2/9993
PS C:\Windows\system32>
可以看到有一个 PLANTET 和 LEAF 角色,连接方式均为 DIRECT(直连)
到这里就加入网络成功了
Linux 客户端(openwrt可以参考这个)
步骤如下:
- 安装linux客户端软件
- 进入目录
/var/lib/zerotier-one
- 替换目录下的
planet
文件 - 重启
zerotier-one
服务(service zerotier-one restart
) - 加入网络
zerotier-cli join
网络id
- 管理后台同意加入请求
zerotier-cli peers
可以看到planet
角色
安卓客户端配置
MacOS 客户端配置
步骤如下:
-
- 进入
/Library/Application\ Support/ZeroTier/One/
目录,并替换目录下的planet
文件 - 重启 ZeroTier-One:
cat /Library/Application\ Support/ZeroTier/One/zerotier-one.pid | sudo xargs kill
- 加入网络
zerotier-cli join
网络id
- 管理后台同意加入请求
zerotier-cli peers
可以看到planet
角色
- 进入
参考链接
zerotier-虚拟局域网详解
五分钟自建 ZeroTier 的 Planet/Controller
管理面板SSL配置
管理面板的SSL支持需要自行配置,参考Nginx配置如下:
upstream zerotier {
server 127.0.0.1:3443;
}
server {
listen 443 ssl;
server_name {CUSTOME_DOMAIN}; #替换自己的域名
# ssl证书地址
ssl_certificate pem和或者crt文件的路径;
ssl_certificate_key key文件的路径;
# ssl验证相关配置
ssl_session_timeout 5m; #缓存有效期
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; #加密算法
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #安全链接可选的加密协议
ssl_prefer_server_ciphers on; #使用服务器端的首选算法
location / {
proxy_pass http://zerotier;
proxy_set_header HOST $host;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
server {
listen 80;
server_name {CUSTOME_DOMAIN}; //替换自己的域名
return 301 https://$server_name$request_uri;
}
卸载
docker rm -f zerotier-planet
Q&A:
为什么我ping不通目标机器?
请检查防火墙设置,Windows
系统需要允许 ICMP
入站,Linux
同理
IOS客户端怎么用?
iOS 客户端插件在这里,设备需要越狱: https://github.com/lemon4ex/ZeroTieriOSFix
为什么看不到官方的Planet
该项目剔除了官方服务器,只保留了自定义的Planet节点
我更换了IP需要怎么处理?
如果IP更换了,则需要重新部署,相当于全新部署
PVE lxc 容器没有创建网卡
需要修改lxc容器的配置,同时lxc容器需要取消勾选无特权
配置文件位置在/etc/pve/lxc/{ID}.conf
在Proxmox7.0之前的版本添加以下内容:
lxc.cgroup.devices.allow: c 10:200 rwm
lxc.mount.entry: /dev/net/tun dev/net/tun none bind,create=file
在Proxmox7.0之后的版本添加以下内容:
lxc.cgroup2.devices.allow: c 10:200 rwm
lxc.mount.entry: /dev/net/tun dev/net/tun none bind,create=file
管理后台忘记密码怎么办:
执行./deploy.sh
,选择重置密码即可
为什么连不上planet
请检查防火墙,如果是阿里云、腾讯云用户,需要在对应平台后台防火墙放行端口。linux机器上也要放行,如果安装了ufw等防火墙工具。
如何判断是直连还是中转
管理员权限执行终端,运行zerotier-cli peers
<ztaddr> <ver> <role> <lat> <link> <lastTX> <lastRX> <path>
69c0d507d0 - LEAF -1 RELAY
93caa675b0 1.12.2 PLANET -894 DIRECT 4142 4068 110.42.99.46/9994
ab403e2074 1.10.2 LEAF -1 RELAY
如果你的ztaddr是REPLAY, 就说明是中转
为什么我的zerotier传输不稳定
由于zerotier使用的是udp协议,部分地区可能对udp进行了qos, 可以考虑使用openvpn。
支持域名吗?
暂不支持
ARM服务器可以搭建吗
暂不支持, 但是ARM可以作为客户端使用
支持docker-compose启动部署吗
参考docker-compose文件如下
version: '3'
services:
myztplanet:
image: xubiaolin/zerotier-planet:latest
container_name: ztplanet
ports:
- 9994:9994
- 9994:9994/udp
- 3443:3443
- 3000:3000
environment:
- IP_ADDR4=[IPV4IP ADDRESS]
- IP_ADDR6=
- ZT_PORT=9994
- API_PORT=3443
- FILE_SERVER_PORT=3000
volumes:
- ./data/zerotier/dist:/app/dist
- ./data/zerotier/ztncui:/app/ztncui
- ./data/zerotier/one:/var/lib/zerotier-one
- ./data/zerotier/config:/app/config
restart: unless-stopped