docker搭建zerotier

使用Docker搭建Zerotier可以使部署和管理Zerotier网络变得更加简单和可靠。

先到官网申请账号, 并且创建一个网络, 创建网络后会得到一个ID

使用Docker CLI:

首先,确保已经安装并配置好Docker。然后,执行以下命令来创建一个Zerotier容器:

shell 复制代码
docker pull bltavares/zerotier
shell 复制代码
docker run --device=/dev/net/tun \
--name zerotier-one \
--net=host \
--restart=unless-stopped \
--cap-add=NET_ADMIN \
--cap-add=SYS_ADMIN \
-v /var/lib/zerotier-one:/var/lib/zerotier-one \
bltavares/zerotier:latest
shell 复制代码
docker exec zerotier-one zerotier-cli join [网络ID]

参数说明:

  • -d:将容器设置为后台运行。
  • --name zerotier-one:为容器指定一个名称。
  • --cap-add=NET_ADMIN:为容器授予网络管理的能力。
  • --device=/dev/net/tun:将宿主机的TUN设备映射到容器内。
  • -v /var/lib/zerotier-one:/var/lib/zerotier-one:将容器内的Zerotier数据目录映射到宿主机,以便数据持久化。
  • --restart=unless-stopped:配置容器在非停止状态下自动重启。
    注意事项:

确保替换 网络ID 为实际的Zerotier网络ID。

确保设置正确的访问权限和安全措施,以保护Zerotier容器的安全性。

配置宿主机的防火墙以允许Zerotier流量通过。

使用Docker Compose:

首先,在项目目录下创建一个名为 docker-compose.yml 的文件,并添加以下内容:

yaml 复制代码
version: '3.9'
services:
    zerotier:
        image: 'bltavares/zerotier:latest'
        volumes:
            - '/var/lib/zerotier-one:/var/lib/zerotier-one'
        cap_add:
            - SYS_ADMIN
            - NET_ADMIN
        restart: unless-stopped
        container_name: zerotier-one
        devices:
            - /dev/net/tun

然后,通过执行以下命令来启动Zerotier容器:

docker-compose up -d

注意事项:

确保替换 网络ID 为实际的Zerotier网络ID。

确保在项目目录下执行 docker-compose up -d 命令。

相关推荐
辉的技术笔记5 小时前
Dify 自部署为什么跑不动?6 层瓶颈诊断法教你定位
docker
程序员老赵1 天前
Docker 部署 Redmine:老牌开源项目管理部署实测记录
docker·开源·团队管理
程序员老赵1 天前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
lichenyang4533 天前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4533 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4533 天前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4533 天前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
Patrick_Wilson8 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy8 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭8 天前
运行你的第一个Docker容器
后端·docker·容器