76 lines
2.5 KiB
Markdown
76 lines
2.5 KiB
Markdown
|
|
# OpenClaw 特权模式设计
|
||
|
|
|
||
|
|
**日期**: 2026-03-26
|
||
|
|
|
||
|
|
## 目标
|
||
|
|
|
||
|
|
为运行在 `116.62.17.81` 上的 OpenClaw Docker 容器开启特权模式,并尽量保证应用重启或基于模板重生成编排后仍保留该配置。
|
||
|
|
|
||
|
|
## 现状
|
||
|
|
|
||
|
|
- 实际运行容器为 `openclaw-gateway-1`
|
||
|
|
- 容器由应用包 Compose 管理,而非当前仓库部署脚本管理
|
||
|
|
- 运行编排文件位于 `/volume1/@appstore/com.ugreen.docker.openclaw/docker-compose.yaml`
|
||
|
|
- 模板文件位于 `/volume1/@appstore/com.ugreen.docker.openclaw/docker-compose.tmpl`
|
||
|
|
- 当前 `docker inspect` 显示 `HostConfig.Privileged=false`
|
||
|
|
|
||
|
|
## 方案对比
|
||
|
|
|
||
|
|
### 方案一:仅修改运行中的 Compose 文件
|
||
|
|
|
||
|
|
只修改 `docker-compose.yaml` 并重建容器。
|
||
|
|
|
||
|
|
- 优点:生效最快
|
||
|
|
- 缺点:若应用按模板重新生成编排,配置容易丢失
|
||
|
|
|
||
|
|
### 方案二:同时修改 Compose 文件与模板
|
||
|
|
|
||
|
|
同时修改 `docker-compose.yaml` 与 `docker-compose.tmpl`,在 `gateway` 服务下新增 `privileged: true`。
|
||
|
|
|
||
|
|
- 优点:当前容器立刻生效,后续应用重启或重新生成编排时也更可能保留
|
||
|
|
- 缺点:若后续官方升级直接覆盖整个应用包目录,仍可能被重置
|
||
|
|
|
||
|
|
### 方案三:脱离 Compose 手工重建容器
|
||
|
|
|
||
|
|
绕过应用包编排,直接手工 `docker run --privileged` 或其他方式重建容器。
|
||
|
|
|
||
|
|
- 优点:理论上可实现
|
||
|
|
- 缺点:容易与现有应用包管理冲突,不符合最短路径
|
||
|
|
|
||
|
|
## 最终方案
|
||
|
|
|
||
|
|
采用方案二。
|
||
|
|
|
||
|
|
## 变更范围
|
||
|
|
|
||
|
|
只修改以下两个服务器文件:
|
||
|
|
|
||
|
|
- `/volume1/@appstore/com.ugreen.docker.openclaw/docker-compose.yaml`
|
||
|
|
- `/volume1/@appstore/com.ugreen.docker.openclaw/docker-compose.tmpl`
|
||
|
|
|
||
|
|
改动内容保持最小化,仅在 `services.gateway` 下增加:
|
||
|
|
|
||
|
|
```yaml
|
||
|
|
privileged: true
|
||
|
|
```
|
||
|
|
|
||
|
|
不调整挂载、网络模式、环境变量或业务配置。
|
||
|
|
|
||
|
|
## 实施步骤
|
||
|
|
|
||
|
|
1. 备份当前 Compose 文件与模板文件
|
||
|
|
2. 在两个文件的 `gateway` 服务下增加 `privileged: true`
|
||
|
|
3. 使用该 Compose 文件重建 `openclaw-gateway-1`
|
||
|
|
4. 使用 `docker inspect` 校验 `Privileged=true`
|
||
|
|
5. 再次读取模板文件,确认持久化来源也已同步更新
|
||
|
|
|
||
|
|
## 验证标准
|
||
|
|
|
||
|
|
- `docker inspect openclaw-gateway-1` 显示 `HostConfig.Privileged=true`
|
||
|
|
- `docker-compose.yaml` 含 `privileged: true`
|
||
|
|
- `docker-compose.tmpl` 含 `privileged: true`
|
||
|
|
|
||
|
|
## 风险说明
|
||
|
|
|
||
|
|
本方案已覆盖当前运行编排和当前模板,但若厂商升级时整体覆盖 `/volume1/@appstore/com.ugreen.docker.openclaw/`,特权配置仍可能被官方包重置。
|