Ansible 安装
将 OpenClaw 部署到生产服务器的推荐方式是通过 openclaw-ansible — 一个以安全为优先的自动化安装器。
快速开始
一条命令安装:
bash
curl -fsSL https://raw.githubusercontent.com/openclaw/openclaw-ansible/main/install.sh | bash完整指南:github.com/openclaw/openclaw-ansible
openclaw-ansible 仓库是 Ansible 部署的权威来源。本页面仅为快速概览。
你将获得
- 防火墙优先的安全策略:UFW + Docker 隔离(仅 SSH + Tailscale 可访问)
- Tailscale VPN:无需公开暴露服务即可安全远程访问
- Docker:隔离的沙箱(Sandbox)容器,仅绑定 localhost
- 纵深防御:4 层安全架构
- 一键部署:几分钟内完成全部部署
- Systemd 集成:开机自启动并进行安全加固
系统要求
- 操作系统:Debian 11+ 或 Ubuntu 20.04+
- 权限:Root 或 sudo 权限
- 网络:用于安装软件包的互联网连接
- Ansible:2.14+(快速启动脚本会自动安装)
安装内容
Ansible playbook 会安装并配置以下内容:
- Tailscale(用于安全远程访问的 mesh VPN)
- UFW 防火墙(仅开放 SSH + Tailscale 端口)
- Docker CE + Compose V2(用于智能体沙箱)
- Node.js 22.x + pnpm(运行时依赖)
- OpenClaw(基于主机安装,非容器化)
- Systemd 服务(带安全加固的自动启动)
注意:网关(Gateway)直接运行在主机上(非 Docker 内),但智能体(Agent)沙箱(Sandbox)使用 Docker 进行隔离。详见 沙箱。
安装后设置
安装完成后,切换到 openclaw 用户:
bash
sudo -i -u openclaw安装后脚本将引导你完成:
- 引导向导:配置 OpenClaw 设置
- 提供商登录:连接 WhatsApp/Telegram/Discord/Signal
- 网关测试:验证安装
- Tailscale 设置:连接到你的 VPN 网络
常用命令
bash
# 检查服务状态
sudo systemctl status openclaw
# 查看实时日志
sudo journalctl -u openclaw -f
# 重启网关
sudo systemctl restart openclaw
# 提供商登录(以 openclaw 用户运行)
sudo -i -u openclaw
openclaw channels login安全架构
4 层防御
- 防火墙(UFW):仅公开暴露 SSH (22) + Tailscale (41641/udp)
- VPN(Tailscale):网关(Gateway)仅通过 VPN 网络可访问
- Docker 隔离:DOCKER-USER iptables 链阻止外部端口暴露
- Systemd 加固:NoNewPrivileges、PrivateTmp、非特权用户
验证
测试外部攻击面:
bash
nmap -p- YOUR_SERVER_IP应该仅显示端口 22(SSH)开放。所有其他服务(网关、Docker)均已锁定。
Docker 可用性
Docker 用于智能体沙箱(隔离的工具执行),而非运行网关本身。网关仅绑定到 localhost,通过 Tailscale VPN 访问。
参见 多智能体沙箱与工具 了解沙箱配置。
手动安装
如果你更希望手动控制而非自动化:
bash
# 1. 安装前置依赖
sudo apt update && sudo apt install -y ansible git
# 2. 克隆仓库
git clone https://github.com/openclaw/openclaw-ansible.git
cd openclaw-ansible
# 3. 安装 Ansible 集合
ansible-galaxy collection install -r requirements.yml
# 4. 运行 playbook
./run-playbook.sh
# 或直接运行(然后手动执行 /tmp/openclaw-setup.sh)
# ansible-playbook playbook.yml --ask-become-pass更新 OpenClaw
Ansible 安装器会将 OpenClaw 设置为手动更新。参见 更新 了解标准更新流程。
要重新运行 Ansible playbook(例如用于配置变更):
bash
cd openclaw-ansible
./run-playbook.sh注意:此操作是幂等的,可安全多次运行。
故障排除
防火墙阻止了我的连接
如果你被锁在外面:
- 确保你可以先通过 Tailscale VPN 访问
- SSH 访问(端口 22)始终被允许
- 网关(Gateway)仅通过 Tailscale 访问,这是设计使然
服务无法启动
bash
# 检查日志
sudo journalctl -u openclaw -n 100
# 验证权限
sudo ls -la /opt/openclaw
# 测试手动启动
sudo -i -u openclaw
cd ~/openclaw
pnpm startDocker 沙箱问题
bash
# 验证 Docker 是否运行
sudo systemctl status docker
# 检查沙箱镜像
sudo docker images | grep openclaw-sandbox
# 如果缺少沙箱镜像则构建
cd /opt/openclaw/openclaw
sudo -u openclaw ./scripts/sandbox-setup.sh提供商登录失败
确保你以 openclaw 用户身份运行:
bash
sudo -i -u openclaw
openclaw channels login高级配置
有关详细的安全架构和故障排除:
相关链接
- openclaw-ansible — 完整部署指南
- Docker — 容器化网关设置
- 沙箱 — 智能体沙箱配置
- 多智能体沙箱与工具 — 按智能体隔离