OpenClaw Docker Compose 部署完整指南

news2026/4/2 8:22:03
目录前置要求快速部署推荐手动部署步骤配置通讯渠道健康检查高级配置常用管理命令故障排查安全加固持久化说明一、前置要求必需软件Docker DesktopWindows/macOS或Docker EngineDocker Compose v2Linux系统资源至少 2GB RAM防止构建时 OOM10GB 可用磁盘空间网络需要访问 GitHub Container Registry 和 npm 仓库可选但推荐Node.js 24用于本地开发和 CLI 操作pnpm 10.23.0包管理器二、快速部署推荐这是最简单的方式脚本会自动完成所有配置# 1. 克隆项目gitclone https://github.com/openclaw/openclaw.gitcdopenclaw# 2. 运行设置脚本./scripts/docker/setup.sh脚本会自动✅ 构建 Docker 镜像✅ 生成 Gateway Token✅ 运行 Onboarding 向导✅ 启动 Gateway 服务✅ 配置必要的环境变量访问控制 UI打开浏览器访问http://127.0.0.1:18789/将终端显示的 token 粘贴到 Settings 中即可。三、手动部署步骤如果您想完全控制部署过程步骤 1构建 Docker 镜像方式 A本地构建cdopenclawdockerbuild-topenclaw:local-fDockerfile.方式 B使用预构建镜像exportOPENCLAW_IMAGEghcr.io/openclaw/openclaw:latestdockerpull$OPENCLAW_IMAGE 预构建镜像地址https://github.com/openclaw/openclaw/pkgs/container/openclaw[main](file://d:\project\openclaw\scripts\ui.js#L161-L193) - 主分支最新[latest](file://d:\project\openclaw\src\cli\gateway-cli\register.ts#L76-L76) - 最新稳定版version- 特定版本如2026.2.26步骤 2准备环境变量创建 [.env](file://d:\project\openclaw\openclaw.podman.env) 文件# 基础配置OPENCLAW_CONFIG_DIR$HOME/.openclawOPENCLAW_WORKSPACE_DIR$HOME/.openclaw/workspaceOPENCLAW_GATEWAY_PORT18789OPENCLAW_BRIDGE_PORT18790OPENCLAW_GATEWAY_BINDlanOPENCLAW_TZAsia/Shanghai# 认证 Token可选不设置则自动生成OPENCLAW_GATEWAY_TOKENyour-secret-token-here# 镜像配置OPENCLAW_IMAGEopenclaw:local# 沙箱配置可选OPENCLAW_SANDBOXOPENCLAW_DOCKER_SOCKET/var/run/docker.sock# 额外配置可选OPENCLAW_EXTRA_MOUNTSOPENCLAW_HOME_VOLUMEOPENCLAW_DOCKER_APT_PACKAGESOPENCLAW_EXTENSIONS步骤 3初始化配置目录# 创建目录结构mkdir-p$OPENCLAW_CONFIG_DIRmkdir-p$OPENCLAW_WORKSPACE_DIRmkdir-p$OPENCLAW_CONFIG_DIR/identitymkdir-p$OPENCLAW_CONFIG_DIR/agents/main/agentmkdir-p$OPENCLAW_CONFIG_DIR/agents/main/sessions步骤 4运行 Onboardingdockercompose run--rm--no-deps--entrypointnodeopenclaw-gateway\dist/index.js onboard--modelocal--no-install-daemon按照提示完成选择 AI 提供商OpenAI、Anthropic 等输入 API Key配置模型偏好步骤 5配置 Gateway# 设置 Gateway 模式为 localdockercompose run--rm--no-deps--entrypointnodeopenclaw-gateway\dist/index.js configsetgateway.modelocal# 设置绑定地址为 lan允许主机访问dockercompose run--rm--no-deps--entrypointnodeopenclaw-gateway\dist/index.js configsetgateway.bind lan# 配置 Control UI 允许的源重要dockercompose run--rm--no-deps--entrypointnodeopenclaw-gateway\dist/index.js configsetgateway.controlUi.allowedOrigins\[http://localhost:18789,http://127.0.0.1:18789]--strict-json步骤 6启动 Gatewaydockercompose up-dopenclaw-gateway步骤 7验证安装# 查看日志dockercompose logs-fopenclaw-gateway# 健康检查curl-fsShttp://127.0.0.1:18789/healthz# 就绪检查curl-fsShttp://127.0.0.1:18789/readyz看到 [ok](file://d:\project\openclaw\ui\src\ui\app-chat.ts#L107-L107) 表示成功四、配置通讯渠道WhatsApp二维码登录dockercompose run--rmopenclaw-cli channels login扫描二维码后WhatsApp 设备即连接成功。TelegramBot Token在 BotFather 创建 Bot获取 Tokendockercompose run--rmopenclaw-cli channelsadd\--channeltelegram\--token123456:ABCDEF-GHIJKLMNOPQRSTUVWXYZDiscordBot Token在 Discord Developer Portal 创建应用创建 Bot 并获取 Token邀请 Bot 到您的服务器dockercompose run--rmopenclaw-cli channelsadd\--channeldiscord\--tokenMTIzNDU2Nzg5MDEyMzQ1Njc4OQ.GJKLmN.OpQrStUvWxYzAbCdEfGhIjKlMnOpQrStUvWxSlack# 需要设置两个环境变量exportSLACK_BOT_TOKENxoxb-your-bot-tokenexportSLACK_APP_TOKENxapp-your-app-tokendockercompose run--rmopenclaw-cli channelsadd\--channelslackSignal需要先安装signal-cli然后配置dockercompose run--rmopenclaw-cli channelsadd\--channelsignal\--phone1234567890五、健康检查基础检查无需认证# Liveness probe存活检查curl-fsShttp://127.0.0.1:18789/healthz# Readiness probe就绪检查curl-fsShttp://127.0.0.1:18789/readyz深度检查需要认证dockercomposeexecopenclaw-gatewaynodedist/index.js health\--token$OPENCLAW_GATEWAY_TOKEN获取 Dashboard URLdockercompose run--rmopenclaw-cli dashboard --no-open六、高级配置选项1. 启用 Agent 沙箱推荐生产环境沙箱可以让非主会话在隔离的 Docker 容器中运行提高安全性exportOPENCLAW_SANDBOX1exportOPENCLAW_DOCKER_SOCKET/var/run/docker.sock ./scripts/docker/setup.sh对于 rootless DockerexportOPENCLAW_SANDBOX1exportOPENCLAW_DOCKER_SOCKET/run/user/1000/docker.sock ./scripts/docker/setup.sh2. 自定义 apt 包构建时安装exportOPENCLAW_DOCKER_APT_PACKAGESgit curl jq wgetdockerbuild\--build-argOPENCLAW_DOCKER_APT_PACKAGES$OPENCLAW_DOCKER_APT_PACKAGES\-topenclaw:local\-fDockerfile\.3. 预安装扩展exportOPENCLAW_EXTENSIONSdiagnostics-otel matrix tavilydockerbuild\--build-argOPENCLAW_EXTENSIONS$OPENCLAW_EXTENSIONS\-topenclaw:local\-fDockerfile\.支持的扩展在extensions/目录下。4. 安装 Playwright 浏览器用于浏览器自动化exportOPENCLAW_INSTALL_BROWSER1dockerbuild\--build-argOPENCLAW_INSTALL_BROWSER1\-topenclaw:local\-fDockerfile\.或在运行时安装dockercompose run--rmopenclaw-cli\node/app/node_modules/playwright-core/cli.jsinstallchromium5. 额外挂载访问宿主机文件exportOPENCLAW_EXTRA_MOUNTS/host/data:/container/data:ro,/host/logs:/container/logs格式source:target[:options]多个用逗号分隔。6. 使用命名卷持久化而非 bind mountexportOPENCLAW_HOME_VOLUMEopenclaw_home这会将/home/node整个目录持久化到 Docker 卷中。7. 配置示例openclaw.json编辑$OPENCLAW_CONFIG_DIR/openclaw.json{ agent: { model: anthropic/claude-opus-4-6, defaults: { sandbox: { mode: non-main, // off | non-main | all scope: agent, // session | agent | shared workspaceAccess: none } } }, gateway: { auth: { mode: token, token: your-token-here }, bind: lan, controlUi: { allowedOrigins: [ http://localhost:18789, http://127.0.0.1:18789 ] } }, channels: { whatsapp: { allowFrom: [*], dmPolicy: pairing }, telegram: { botToken: 123456:ABCDEF, allowFrom: [*] } } }七、常用管理命令日志查看# 实时查看日志dockercompose logs-fopenclaw-gateway# 查看最近 100 行dockercompose logs--tail100openclaw-gateway服务管理# 停止服务dockercompose down# 重启服务dockercompose restart openclaw-gateway# 完全清理包括数据卷dockercompose down-v# 重新构建并启动dockercompose up-d--buildopenclaw-gateway设备配对# 列出待批准的设备dockercompose run--rmopenclaw-cli devices list# 批准设备dockercompose run--rmopenclaw-cli devices approverequestId# 拒绝设备dockercompose run--rmopenclaw-cli devices rejectrequestId发送消息测试# 发送测试消息dockercompose run--rmopenclaw-cli message send\--to1234567890\--messageHello from OpenClaw!# 与 Agent 对话dockercompose run--rmopenclaw-cli agent\--messageShip checklist\--thinkinghigh配置管理# 查看当前配置dockercompose run--rmopenclaw-cli config get# 修改配置dockercompose run--rmopenclaw-cli configsetgateway.bind loopback# 重置配置dockercompose run--rmopenclaw-cli config reset技能管理# 列出已安装技能dockercompose run--rmopenclaw-cli skills list# 安装新技能dockercompose run--rmopenclaw-cli skillsinstallskill-name# 更新技能dockercompose run--rmopenclaw-cli skills updateskill-name八、故障排查问题 1权限错误EACCES症状容器内无法写入配置文件解决sudochown-R1000:1000$OPENCLAW_CONFIG_DIR$OPENCLAW_WORKSPACE_DIR问题 2Gateway 无法从主机访问症状浏览器无法打开 http://127.0.0.1:18789/解决# 检查绑定地址配置dockercompose run--rmopenclaw-cli config get gateway.bind# 如果不是 lan修改dockercompose run--rmopenclaw-cli configsetgateway.bind lan# 重启服务dockercompose restart openclaw-gateway问题 3沙箱容器未启动症状Agent 工具执行失败提示找不到 sandbox解决# 构建沙箱镜像./scripts/sandbox-setup.sh# 或指定自定义镜像# 编辑 openclaw.json设置 agents.defaults.sandbox.docker.image问题 4构建时 OOMexit 137症状pnpm install过程中容器被杀死解决增加 Docker 内存限制到至少 2GB或使用更大的虚拟机或分步构建减少并发依赖安装问题 5Dashboard 显示配对请求症状Control UI 显示需要配对设备解决# 获取 Dashboard 链接dockercompose run--rmopenclaw-cli dashboard --no-open# 在浏览器打开链接并批准设备# 或直接通过 CLI 批准dockercompose run--rmopenclaw-cli devices listdockercompose run--rmopenclaw-cli devices approverequestId问题 6WebSocket 连接失败症状macOS/iOS App 无法连接解决# 重置 Gateway 模式dockercompose run--rmopenclaw-cli configsetgateway.modelocaldockercompose run--rmopenclaw-cli configsetgateway.bind lan# 确保防火墙允许 18789 端口# macOS: 系统设置 网络 防火墙# Linux: sudo ufw allow 18789/tcp问题 7渠道消息不响应症状WhatsApp/Telegram 消息发送后无回复排查步骤# 1. 检查渠道状态dockercompose run--rmopenclaw-cli channels list# 2. 查看渠道日志dockercompose logs openclaw-gateway|grep-ichannel\|whatsapp\|telegram# 3. 检查 DM 策略是否启用了 pairingdockercompose run--rmopenclaw-cli config get channels.whatsapp.dmPolicy# 4. 如果是 pairing 模式需要批准发送者dockercompose run--rmopenclaw-cli pairing listdockercompose run--rmopenclaw-cli pairing approve whatsappcode九、安全加固1. DM私信安全策略默认行为DM 配对模式dmPolicypairing未知发送者会收到配对码Bot 不会处理未配对的私信防止垃圾消息和提示注入攻击批准流程# 查看待批准的配对dockercompose run--rmopenclaw-cli pairing list# 批准dockercompose run--rmopenclaw-cli pairing approvechannelcode开放模式仅限可信环境{ channels: { whatsapp: { dmPolicy: open, allowFrom: [*] // 允许所有人 } } }2. 网络暴露安全如果在 VPS 上部署Docker 防火墙规则# 添加 DOCKER-USER 链规则iptables-ADOCKER-USER-ieth0-ptcp--dport18789-jACCEPT iptables-ADOCKER-USER-ieth0-ptcp--dport18790-jACCEPT iptables-ADOCKER-USER-ieth0-jDROP使用 Tailscale推荐{ gateway: { tailscale: { mode: serve, // serve尾网| funnel公开| off resetOnExit: true }, bind: loopback, // 必须保持 loopback auth: { mode: token } } }3. Token 认证强化生成强 Token# 使用 openssl 生成openssl rand-hex32# 或使用 Pythonpython3-cimport secrets; print(secrets.token_hex(32))设置密码认证替代 Token{ gateway: { auth: { mode: password, password: your-strong-password-here } } }4. 容器安全Docker Compose 已经配置了以下安全措施services:openclaw-cli:cap_drop:-NET_RAW-NET_ADMINsecurity_opt:-no-new-privileges:true进一步加固services:openclaw-gateway:read_only:truetmpfs:-/tmpcap_drop:-ALLcap_add:-NET_BIND_SERVICE5. 沙箱隔离启用沙箱后非主会话的工具执行会在隔离容器中进行{ agents: { defaults: { sandbox: { mode: non-main, // 非主会话启用沙箱 scope: agent, workspaceAccess: none, // 禁止访问工作区 allowTools: [ bash, process, read, write, edit, sessions_list, sessions_history, sessions_send ], denyTools: [ browser, canvas, nodes, cron, discord, gateway ] } } } }十、持久化说明数据持久化策略Docker Compose 使用bind mount持久化关键数据宿主机路径容器路径内容$OPENCLAW_CONFIG_DIR/home/node/.openclaw配置、凭证、身份$OPENCLAW_WORKSPACE_DIR/home/node/.openclaw/workspace技能、会话、媒体目录结构~/.openclaw/ ├── openclaw.json # 主配置文件 ├── identity/ # 身份和密钥存储 │ └── default/ ├── credentials/ # 渠道凭证加密存储 ├── agents/ # Agent 配置 │ └── main/ │ ├── agent/ # Agent 专属文件 │ └── sessions/ # 会话历史 └── workspace/ ├── skills/ # 已安装技能 ├── media/ # 媒体文件缓存 └── cron/ └── runs/ # 定时任务记录磁盘增长监控以下目录可能快速增长需定期清理# 查看各目录大小dockercomposeexecopenclaw-gatewaydu-sh\/home/node/.openclaw/workspace/media\/home/node/.openclaw/agents/main/sessions\/home/node/.openclaw/workspace/cron/runs\/tmp/openclaw# 清理旧会话保留最近 7 天dockercompose run--rmopenclaw-cli sessions prune --older-than 7d# 清理媒体缓存dockercomposeexecopenclaw-gatewayrm-rf/home/node/.openclaw/workspace/media/*备份策略完整备份# 停止服务dockercompose down# 备份配置和工作区tar-czvfopenclaw-backup-$(date%Y%m%d).tar.gz\~/.openclaw# 重新启动dockercompose up-d增量备份仅配置文件cp~/.openclaw/openclaw.json ~/backups/openclaw-$(date%Y%m%d).json恢复备份# 停止服务dockercompose down# 解压备份tar-xzvfopenclaw-backup-20260401.tar.gz-C~/# 重新启动dockercompose up-d 下一步部署完成后建议访问 Control UIhttp://127.0.0.1:18789/配置 AI 模型在 Settings 中选择您的首选模型连接通讯渠道至少配置一个渠道WhatsApp/Telegram 等安装技能根据需求安装扩展技能测试对话发送一条测试消息验证功能详细使用文档请参考Channels 配置Skills 系统Gateway 配置安全指南祝您部署顺利

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2474766.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…