搜索
缓存时间08 现在时间08 缓存数据 生活不能等待别人来安排。你想要什么样的生活只有你自己知道。自已去规划和设计,自己去争取和奋斗,自己去调整和改变,你才能一点一点距离理想生活越来越近。纵使不会事事如意,但你可以骄傲地说,我曾用尽全力,所以不会遗憾。早安!
查看: 166|回复: 0

将 akile_monitor 服务端和客户端打包到Docker部署

[复制链接]
发表于 2024-12-7 20:00:50 | 显示全部楼层 |阅读模式

厌倦了滚动浏览相同的帖子?当您创建帐户后,您将始终回到您离开的地方。注册帐户,不仅可以享受无广告的清爽界面!

您需要 登录 才可以下载或查看,没有账号?注册

×
https://github.com/niliovo/akile_monitor_docker
Docker 部署介绍
将前端akile_monitor_fe和主控服务ak_monitor打包进一个容器,被控客户端ak_client单独打包进另一个容器,并利用 GitHub Actions 自动构建Docker镜像并推送至Docker Hub
前端端口 80 主控服务端 端口 3000 可自行映射到宿主机或反向代理TLS加密
前端配置文件 主控服务端配置文件 被控客户端配置文件 共三个配置文件需要修改
支持架构
linux/amd64
linux/arm64
准备工作
以下所有
/CHANGE_PATH
替换为你的宿主机路径, 提前创建以下文件避免Docker自动创建文件夹导致失败
Docker 安装

前端+主控服务端
前端配置文件
/CHANGE_PATH/akile_monitor/caddy/config.json
参考如下
{
  "socket": "ws://192.168.31.64:3000/ws",
  "apiURL": "http://192.168.31.64:3000"
}
主控服务端配置文件
/CHANGE_PATH/akile_monitor/config.json
SQLite数据库
/CHANGE_PATH/akile_monitor/ak_monitor.db
被控客户端
被控客户端配置文件
/CHANGE_PATH/akile_monitor/client.json
主控服务端+前端 部署
Docker Cli 部署
docker run -it --name akile_monitor_server --restart always -v /CHANGE_PATH/akile_monitor/server/config.json:/app/config.json -v /CHANGE_PATH/akile_monitor/server/ak_monitor.db:/app/ak_monitor.db -v /CHANGE_PATH/akile_monitor/caddy/config.json:/usr/share/caddy/config.json -p 80:80 -p 3000:3000 -e TZ "Asia/Shanghai" niliaerith/akile_monitor_server
Docker Compose 部署
cat <<EOF > compose.yml
services:
  akile_monitor_server:
    image: niliaerith/akile_monitor_server
    container_name: akile_monitor_server
    hostname: akile_monitor_server
    restart: always
    ports:
      - 80:80 #前端 端口
      - 3000:3000 #主控服务端 端口
    volumes:
      - /CHANGE_PATH/akile_monitor/server/config.json:/app/config.json 
      - /CHANGE_PATH/akile_monitor/server/ak_monitor.db:/app/ak_monitor.db
      - /CHANGE_PATH/akile_monitor/caddy/config.json:/usr/share/caddy/config.json
    environment:
      TZ: "Asia/Shanghai"
EOF
docker compose up -d
被控客户端 部署
必须添加
host
网络模式,否则识别的流量为容器内的
必须添加
/var/run/docker.sock
卷,否则识别的系统为容器内的
Docker Cli 部署
docker run -it --name akile_monitor_client --restart always -v /CHANGE_PATH/akile_monitor/client/client.json:/app/client.json -v /var/run/docker.sock:/var/run/docker.sock --net host -e TZ "Asia/Shanghai" niliaerith/akile_monitor_client
Docker Compose 部署
cat <<EOF > compose.yml
services:
  akile_monitor_client:
    image: niliaerith/akile_monitor_client
    container_name: akile_monitor_client
    hostname: akile_monitor_client
    restart: always
    network_mode: host
    volumes:
      - /CHANGE_PATH/akile_monitor/client/client.json:/app/client.json
      - /var/run/docker.sock:/var/run/docker.sock
    environment:
      TZ: "Asia/Shanghai"
EOF
docker compose up -d
Docker Build 自建镜像
git clone https://github.com/akile-network/akile_monitor
cd akile_monitor
docker build --tag akile_monitor_server .
已知问题
因为被控客户端在Docker alpine容器内,所以虚拟化始终显示为docker。

解决方法1: 被控客户端采用 二进制部署,详见 被控端
解决方法2: 忽略虚拟化
爱生活,爱奶昔~

Powered by Nyarime. Licensed

GMT+8, 2025-1-9 08:45 , Processed in 0.037548 second(s), 13 queries , Gzip On, Redis On
发帖际遇 ·手机版 ·小黑屋 ·RSS ·奶昔网 | 沪ICP备13020230号-1 |  沪公网安备 31010702007642号

登录切换风格
快速回复 返回顶部 返回列表