用docker来安装openclaw
前言
虽然最近openclaw火的不行,但是他依然是一个高速发展和成长中的系统或者说软件,还不是很成熟:看看他开源代码,一天一个release也常见。
所以,遇到各种bug,各种与插件的兼容性问题,也不奇怪。
如果安装在裸机中,回退升级都是很麻烦的事情,所以,我想把他安装在docker中,方便升级和回退。
安装
我习惯用2中方式来在docker中安装openclaw:
- 启动一个基础镜像,把他当作一个VPS来安装openclaw
- 使用Dockerfile,编辑一个镜像,然后使用docker compose 编排来启动
第一种方式更灵活,适合测试和实验新版本,开发新插件。
第二种方法可以封装系统,适合用来分享镜像
现在来体验一下这俩种方式吧:
在基础镜像内手工安装
根据官方文档推荐使用node 22+,所以选择使用node:22-trixie作为基础镜像:
启动脚本:
bash
docker run -it --net=host -v ./openclaw:/root/.openclaw --name openclaw node:22-trixie bash
简单解释:
bash
--net=host #直接使用主机网络,简化测试
-v ./openclaw:/root/.openclaw #这个是openclaw的数据目录,持久化下来
--name openclaw #为这个实例起个名字
bash #启动bash
安装
bash
npm install -g openclaw@latest
安装成功:

初始化配置
第一次启动可以选择使用:openclaw onboard
这个命令会使用引导方式去配置所有的信息并最后启动openclaw gateway,我们使用这种方式:

以上图,红色的就是每一步,灰色的就是我们选择或者填入的信息,其他特别要注意以下这步:

飞书的这个插件已经被集成在openclaw中了,但是如果这里你再选择安装,就会出现2个版本,会冲突。
当你看到这个页面的适合,就已经完成了配置,且已经启动了:

但是这时候其实是无法访问的:
我们安装选择的快速配置,没有配置网络,所以他目前监听本地网络,且禁止非https访问,所以实际无法访问。(如果是部署一个生产用的,准备放在一个caddy或者nginx等反向代理服务器后面,倒是可以的。)
使用ctrl+c终止程序运行,然后直接使用vim编辑:
bash
vim ~/.openclaw/openclaw.json
找到gateway部分,修改mode、bind、controlUi部分,最终如下:
yaml
"gateway": {
"port": 18789,
"mode": "local",
"bind": "lan",
"controlUi": {
"enabled": true,
"allowInsecureAuth": true
},
"auth": {
"mode": "token",
"token": "1876cbd181533358223674dab4841f60c252f62c206a53f9"
},
"tailscale": {
"mode": "off",
"resetOnExit": false
}
}
另:如果你还没用大模型API,可以先看看这篇:
保存后启动:
bash
openclaw gateway
当你看到这个页面的时候,就可以啦:

访问地址:
http://你的IP:18789/?token=你的token
测试一下:
你可以看到这个页面,先给他起个名字:

保存镜像
在主机下执行查询,可以看到运行的容器,直接使用commit来保存成镜像:
docker ps
docker commit f0bd197aec12 openclaw:0.0.1

这样使用docker来安装openclaw就完成啦,就保存了一个指定的版本,也不影响我尝试安装其他的版本。
使用Dockerfile构建openclaw镜像
现在来试试打包发布的方式,来安装openclaw:
openclaw官方是支持使用docker来安装的,所以他的源码中有docker的所有配置,且官方文档也有相关内容。
所以我准备以他为基础,简化一下,将一些模板化的配置改成我需要的写死的信息,可以简化很多.
先下载代码:
bash
git clone --depth 1 https://github.com/openclaw/openclaw
打开dockerfile,主要修改了三个地方:

- 安装了git、curl、jq
- 修改为root用户运行
- 删除自带的飞书软件
步骤3不是必须的,而是因为我习惯了用了很久的一个第三方飞书插件,而系统俩个飞书插件是会冲突的。
编译:
bash
docker build -t openclaw:local -f Dockerfile .
构建完成后使用docker compose 编排:
yaml
services:
openclaw:
image: openclaw:local
container_name: openclaw
restart: unless-stopped
env_file:
- ./env.file
environment:
TZ: Asia/Shanghai
HOME: /root
TERM: xterm-256color
volumes:
- /home/openclaw:/root
- ./logs:/tmp/openclaw
command: ["node","dist/index.js","gateway","--port","18789",]
简单解释:
-
/home/openclaw:/root :将运行用户全部持久化下来
-
./logs:/tmp/openclaw :openclaw默认的输出日志位于/tmp/openclaw 刚开始测试我希望能更方便的查看
-
command : 启动脚本,但是第一次运行的时候不要添加,因为还没配置,是无法执行的,可以不填
这样就会使用dockefile里面的默认命令,使用无配置文件启动
初始化配置
可以启动容器后,接入容器后来配置,也可以直接运行命令配置:
bash
# 进入运行的容器配置:
docker exec -it openclaw bash
node /app/disk/index.js onboard
# 直接启动命令配置
docker compose run --rm openclaw onboard
启动配置后的步骤,和第一种方式一样的,就不赘述了。
注意:
使用官方dockerfile构建的镜像,不像使用npm全局安装的,命令只能使用node去运行,例如:
安装飞书插件的俩这差别:
bash
#使用npm全局安装的时候
openclaw plugins install @m1heng-clawd/feishu
# 使用官方dockerfile构建的镜像
node /app/dist/index.js plugins install @m1heng-clawd/feishu
小结
openclaw真的给ai带来了翻天覆地的变化,给一个只会嘴活的ai,添加了一双手!
但是目前也是在告诉发展期间,版本更迭太快,使用docker的方式能更好的隔离环境,更快的更新或者回退版本。
欢迎关注:
https://mp.weixin.qq.com/s/7ExVbQHcd8v9CxA8nL_XWg?token=210876465\&lang=zh_CN