windows通过docker compose部署oktopus服务

Oktopus 是一个开源的 TR-069(CWMP)(v1.0/v1.1/v1.2)自动配置服务器 (ACS)、TR369服务器 ,用 Go 语言实现,侧重 轻量、可嵌入、脚本化,适合运营商/企业做 CPE 远程管理、批量升级、参数监控。

一、虚拟机ubuntu系统通过ssh执行命令

虚拟机的终端界面并不是很友好,日志颜色、查看日志、拷贝日志等都不够便捷。可以通过ssh方式访问虚拟机ip地址:

bash 复制代码
安装ssh server:
sudo apt-get openssh-server
启动ssh:
sudo systemctl start ssh
查看虚拟机ip:
ifconfig
通过mobaxterm等工具访问ssh:
地址:ip:22
用户名密码同virtualbox账户

二、安装docker compose

oktopus服务通过docker compose一键部署,需要先安装docker。

1. 下载docker

bash 复制代码
# 官方脚本下载
curl -fsSL https://get.docker.com -o get-docker.sh
sudo sh get-docker.sh --mirror Aliyun

2.docker配置

bash 复制代码
# 添加当前用户到docker组
sudo usermod -aG docker $USER

# 配置镜像加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": [
    "https://docker.mirrors.ustc.edu.cn",
    "https://hub-mirror.c.163.com",
    "https://mirror.baidubce.com"
  ]
}
EOF

# 重启Docker
sudo systemctl daemon-reload
sudo systemctl restart docker

# 检查Docker版本
docker --version
# 输出示例: Docker version 24.0.7, build afdd53b

# 检查Docker Compose
docker compose version
# 输出示例: Docker Compose version v2.23.0

三、启动oktopus服务

1. 拉取oktopus并配置

bash 复制代码
# 克隆代码
git clone https://github.com/OktopUSP/oktopus.git

# 进入部署目录
cd oktopus/deploy/compose

# 创建 .env.nats
cat > .env.nats << 'EOF'
NATS_URL=nats://msg_broker:4222
EOF

# 创建 .env.controller
cat > .env.controller << 'EOF'
MONGO_URI=mongodb://mongo_usp:27017
NATS_URL=nats://msg_broker:4222
PORT=8000
CONTROLLER_EID=oktopusController
EOF

# 创建 .env.mqtt
cat > .env.mqtt << 'EOF'
MQTT_PORT=:1883
MQTT_TLS_PORT=:8883
MQTT_NO_TLS=true
MQTT_TLS=false
AUTH_ENABLE=false
REDIS_ENABLE=false
NATS_URL=nats://msg_broker:4222
LOG_LEVEL=0
EOF

# 创建 .env.ws
cat > .env.ws << 'EOF'
WS_PORT=:8080
WS_NO_TLS=true
WS_TLS=false
CONTROLLER_EID=oktopusController
NATS_URL=nats://msg_broker:4222
AUTH=false
EOF

# 创建 .env.mqtt-adapter
cat > .env.mqtt-adapter << 'EOF'
NATS_URL=nats://msg_broker:4222
MONGO_URI=mongodb://mongo_usp:27017
EOF

# 创建 .env.ws-adapter
cat > .env.ws-adapter << 'EOF'
NATS_URL=nats://msg_broker:4222
MONGO_URI=mongodb://mongo_usp:27017
EOF

# 创建 .env.adapter
cat > .env.adapter << 'EOF'
NATS_URL=nats://msg_broker:4222
MONGO_URI=mongodb://mongo_usp:27017
EOF

# 创建 .env.socketio
cat > .env.socketio << 'EOF'
NATS_URL=nats://msg_broker:4222
PORT=5000
EOF

# 创建 .env.file-server
cat > .env.file-server << 'EOF'
PORT=8004
EOF

# 赋予脚本执行权限
chmod +x run.sh

2. 启动服务

bash 复制代码
# 启动服务
./run.sh

# 或者手动指定要启动的服务
COMPOSE_PROFILES=nats,controller,mqtt,ws,adapter,frontend docker compose up -d

直到容器都创建成功即可,启动过程:

bash 复制代码
# 查看服务状态
docker compose ps

# 查看日志
docker compose logs -f

# 只查看特定服务的日志
docker compose logs -f mqtt
docker compose logs -f controller
docker compose logs -f frontend

查看到服务状态均为UP:

通过mqttfx或者官方测试服务obuspa连接至ip:1883的mqtt服务器,即可连接成功。

相关推荐
Doro再努力1 小时前
Vim 快速上手实操手册:从入门到生产环境实战
linux·编辑器·vim
wypywyp1 小时前
8. ubuntu 虚拟机 linux 服务器 TCP/IP 概念辨析
linux·服务器·ubuntu
Doro再努力1 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
senijusene1 小时前
Linux软件编程:IO编程,标准IO(1)
linux·运维·服务器
忧郁的橙子.2 小时前
02-本地部署Ollama、Python
linux·运维·服务器
大大大反派2 小时前
CANN 生态未来展望:统一框架 `CANN Unified` 与开源协同演进
开源
醇氧2 小时前
【linux】查看发行版信息
linux·运维·服务器
lpruoyu2 小时前
【Docker进阶-03】存储原理
docker·容器
酷酷的崽7982 小时前
CANN 开源生态实战:端到端构建高效文本分类服务
分类·数据挖掘·开源
晚霞的不甘2 小时前
CANN 在工业质检中的亚像素级视觉检测系统设计
人工智能·计算机视觉·架构·开源·视觉检测