背景
我之前已经使用 Nezha 监控 一段时间,但发现一些痛点:
- Nezha 默认只能查看 1 分钟的机器信息 和 24 小时的延迟数据。
- 如果想通过公网访问,需要额外配置 Nginx 反代,过程繁琐。
而 Komari 原生支持 Cloudflare Tunnel (CF Tunnel),可以直接通过 Cloudflare 提供的隧道进行访问,免去手动配置反代的烦恼。
因此我的目标是:
- 保留 Nezha(不修改、不影响现有部署);
- 新增 Komari,通过 子域名 + Cloudflare Tunnel 部署。
官方文档参考
部署步骤
1. 准备 Docker Compose 文件
在服务器上新建 docker-compose.yml:
version: '3.8'services: komari: image: ghcr.io/komari-monitor/komari:latest container_name: komari ports: - "25774:25774" volumes: - ./data:/app/data environment: ADMIN_USERNAME: admin ADMIN_PASSWORD: 123456 KOMARI_ENABLE_CLOUDFLARED: "true" # 在 Cloudflare Tunnel 中获取的 Token KOMARI_CLOUDFLARED_TOKEN: eyJXXXX restart: unless-stopped2. 在 Cloudflare Zero Trust 创建 Tunnel
进入 Access → Tunnels。
点击 Create a tunnel → 选择 Cloudflare → 复制生成的 Token。
将复制的 Token 填写到
docker-compose.yml中KOMARI_CLOUDFLARED_TOKEN字段。tunnel中对接的是容器里面的
http:127.0.0.1:25774,这一部没有截图
3. 启动 Komari
在项目目录下执行:
docker compose up -d启动后,Komari 会自动通过 Cloudflare Tunnel 建立连接,你可以在 Cloudflare 中为该 Tunnel 绑定一个 子域名(比如我的 https://komari.groovydeng.eu.org),即可在公网访问。
总结
通过 Docker Compose + Cloudflare Tunnel 部署 Komari,可以做到:
- 免去额外的 Nginx/反代配置;
- 安全稳定地通过子域名访问监控面板;
- 与现有 Nezha 监控 并行使用,互不影响。
评论 (0)