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服务器,即可连接成功。

相关推荐
该昵称用户已存在2 小时前
能碳数据治理与建模引擎:MyEMS 开源方案打造企业能源管理数字底座
开源
米高梅狮子3 小时前
03.网络类服务实践
linux·运维·服务器·网络·kubernetes·centos·openstack
June`3 小时前
网络编程时内核究竟做了什么???
linux·服务器·网络
楼兰公子4 小时前
RK3588 + Linux7.0.3 网络工程调试错误速查手册
linux·网络·3588
Elnaij4 小时前
Linux系统与系统编程(9)——自设计shell与基础IO
linux·服务器
IpdataCloud4 小时前
稳定的企业级IP数据接口怎么选?可用性指标+离线库高可用方案
运维·网络·tcp/ip
IMPYLH4 小时前
Linux 的 unexpand 命令
linux·运维·服务器·bash
万里侯4 小时前
GitOps实战:用Git管理基础设施
微服务·容器·k8s
|_⊙5 小时前
Linux 文件知识 补充
linux·运维·服务器
冬奇Lab5 小时前
一天一个开源项目(第106篇):Claude Plugins Official - Anthropic 官方 Claude Code 插件生态全解析
人工智能·开源·资讯