如何使用 Docker 安全地部署 OpenClaw (龙虾)

OpenClaw (龙虾) 是一个强大的个人 AI 助手,它可以连接各种消息平台并执行工具。本文介绍如何通过 Docker Compose 安全地部署 OpenClaw,并解析其中的关键配置。

OpenClaw 提供了强大的 AI 能力,但也意味着它需要访问你的文件、工具和 API 密钥。因此,安全性是部署时的首要考量。

参考这个 GitHub 仓库:wangyucode/openclaw-docker-compose

部署步骤

1. 克隆仓库与配置环境

首先,克隆部署配置仓库:

bash 复制代码
git clone https://github.com/wangyucode/openclaw-docker-compose.git
cd openclaw-docker-compose

复制并编辑 .env 文件,填入你的 API 密钥和其他配置:

bash 复制代码
cp .env.example .env
vi .env

2. 执行初始化 (Onboarding)

在启动网关之前,需要运行一次初始化命令来生成必要的配置文件:

bash 复制代码
docker compose run --rm openclaw-cli onboard

3. 启动 OpenClaw

一切就绪后,启动 Docker 容器:

bash 复制代码
docker compose up -d

关键配置解析

为什么我们要这样编写 docker-compose.yml?以下是几个关键的安全配置点:

非 Root 用户运行

yaml 复制代码
user: "1000:1000"

默认情况下,Docker 容器以 root 用户运行。如果容器被攻破,攻击者可能获得宿主机的 root 权限。通过指定 user: "1000:1000"(通常是宿主机的第一个普通用户),我们可以最小化权限。

禁用权限提升

yaml 复制代码
security_opt:
  - no-new-privileges:true

这项配置可以防止容器内的进程通过 setuidsetgid 二进制文件获得新的权限。即使攻击者在容器内找到了漏洞,也无法提升权限。

移除不必要的 Capability

yaml 复制代码
cap_drop:
  - ALL

Linux Capabilities 将 root 的特权细分为多个小的权限。默认情况下,Docker 会保留一些常用的权限。通过 cap_drop: [ALL],我们移除了所有特权,只保留最基础的运行环境。

持久化存储与权限

yaml 复制代码
volumes:
  - ./.openclaw:/home/node/.openclaw

将配置文件和工作区映射到宿主机目录,方便备份和管理。注意宿主机目录的权限应与 user 配置一致(例如 chown -R 1000:1000 .openclaw)。

访问控制

OpenClaw 默认运行在 18789 端口。访问 Dashboard 时需要一个 Token,你可以通过以下命令获取:

bash 复制代码
docker compose run --rm openclaw-cli dashboard --no-open

总结

通过 Docker 部署 OpenClaw 不仅简化了环境配置,更重要的是通过容器化技术提供了良好的安全隔离。遵循"最小权限原则",我们可以更放心地让 AI 助手为我们工作。

本文原始发表于 wycode.cn/blog/opencl...,转载请注明出处

相关推荐
2501_933329551 天前
媒介宣发技术实践:Infoseek舆情系统的AI中台架构与应用解析
开发语言·人工智能·架构·数据库开发
热爱生活的五柒1 天前
026主流三大模型(GPT / Gemini / Claude Code)总结
人工智能·gpt
DuHz1 天前
论文精读:大语言模型 (Large Language Models, LLM) —— 一项调查
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·语言模型
AI木马人1 天前
9.【AI任务队列实战】如何在高并发下保证系统不崩?(Redis + Celery完整方案)
数据库·人工智能·redis·神经网络·缓存
陈天伟教授1 天前
GPT Image 2-桂林山水
人工智能·神经网络·安全·架构
offer收割机小鹅1 天前
大学生求职必备:AI面试、AI写作与设计工具助力职场发展
人工智能·ai·面试·aigc·ai写作
乔江seven1 天前
【李沐 | 动手学深度学习】20 计算机视觉:数据增广(Data Augmentation)
人工智能·深度学习
冬奇Lab1 天前
Claude Code 接入 SonarQube 静态扫描:AI 写代码,质量闭环了
人工智能·ai编程·claude
冬奇Lab1 天前
一天一个开源项目(第84篇):free-claude-code —— 零费用运行 Claude Code 的代理黑魔法
人工智能·开源·claude
泡泡茶壶ᐇ1 天前
个人网站构建完全指南:从功能规划到技术实现与AI辅助开发
人工智能