# Ansible 安装

将 Clawdbot 部署到生产服务器的推荐方式是通过 **[clawdbot-ansible](https://github.com/jiulingyun/openclaw-cn-ansible)** — 一个安全优先架构的自动化安装器。

## 快速开始

一条命令安装：

```bash
curl -fsSL https://raw.githubusercontent.com/clawdbot/clawdbot-ansible/main/install.sh | bash
```

> **📦 完整指南：[github.com/jiulingyun/openclaw-cn-ansible](https://github.com/jiulingyun/openclaw-cn-ansible)**
>
> clawdbot-ansible 仓库是 Ansible 部署的权威来源。本页面只是快速概述。

## 您将获得

- 🔒 **防火墙优先安全**：UFW + Docker 隔离（仅 SSH + Tailscale 可访问）
- 🔐 **Tailscale VPN**：安全远程访问，无需公开暴露服务
- 🐳 **Docker**：隔离的沙箱容器，仅绑定 localhost
- 🛡️ **纵深防御**：4 层安全架构
- 🚀 **一条命令设置**：几分钟内完成部署
- 🔧 **Systemd 集成**：开机自启动并带有安全加固

## 要求

- **操作系统**：Debian 11+ 或 Ubuntu 20.04+
- **访问权限**：Root 或 sudo 权限
- **网络**：用于安装软件包的互联网连接
- **Ansible**：2.14+（由快速启动脚本自动安装）

## 安装内容

Ansible playbook 安装和配置：

1. **Tailscale**（用于安全远程访问的 mesh VPN）
2. **UFW 防火墙**（仅 SSH + Tailscale 端口）
3. **Docker CE + Compose V2**（用于代理沙箱）
4. **Node.js 22.x + pnpm**（运行时依赖）
5. **Clawdbot**（基于主机，非容器化）
6. **Systemd 服务**（带安全加固的自动启动）

注意：网关 **直接在主机上** 运行（不在 Docker 中），但代理沙箱使用 Docker 进行隔离。详见 [沙箱](/gateway/sandboxing)。

## 安装后设置

安装完成后，切换到 clawdbot 用户：

```bash
sudo -i -u clawdbot
```

安装后脚本将引导您完成：

1. **引导向导**：配置 Clawdbot 设置
2. **提供商登录**：连接 WhatsApp/Telegram/Discord/Signal
3. **网关测试**：验证安装
4. **Tailscale 设置**：连接到您的 VPN 网格

### 快速命令

```bash
# 检查服务状态
sudo systemctl status clawdbot

# 查看实时日志
sudo journalctl -u clawdbot -f

# 重启网关
sudo systemctl restart clawdbot

# 提供商登录（以 clawdbot 用户运行）
sudo -i -u clawdbot
openclaw-cn channels login
```

## 安全架构

### 4 层防御

1. **防火墙 (UFW)**：仅公开暴露 SSH (22) + Tailscale (41641/udp)
2. **VPN (Tailscale)**：网关仅可通过 VPN 网格访问
3. **Docker 隔离**：DOCKER-USER iptables 链防止外部端口暴露
4. **Systemd 加固**：NoNewPrivileges、PrivateTmp、非特权用户

### 验证

测试外部攻击面：

```bash
nmap -p- YOUR_SERVER_IP
```

应该显示 **仅端口 22** (SSH) 打开。所有其他服务（网关、Docker）都被锁定。

### Docker 可用性

Docker 是为 **代理沙箱**（隔离的工具执行）安装的，而不是用于运行网关本身。网关仅绑定到 localhost，可通过 Tailscale VPN 访问。

详见 [多代理沙箱与工具](/multi-agent-sandbox-tools) 了解沙箱配置。

## 手动安装

如果您更喜欢手动控制而非自动化：

```bash
# 1. 安装先决条件
sudo apt update && sudo apt install -y ansible git

# 2. 克隆仓库
git clone https://github.com/jiulingyun/openclaw-cn-ansible.git
cd clawdbot-ansible

# 3. 安装 Ansible collections
ansible-galaxy collection install -r requirements.yml

# 4. 运行 playbook
./run-playbook.sh

# 或者直接运行（然后手动执行 /tmp/clawdbot-setup.sh）
# ansible-playbook playbook.yml --ask-become-pass
```

## 更新 Clawdbot

Ansible 安装器设置 Clawdbot 进行手动更新。详见 [更新](/install/updating) 了解标准更新流程。

要重新运行 Ansible playbook（例如，配置更改）：

```bash
cd clawdbot-ansible
./run-playbook.sh
```

注意：这是幂等的，可以安全地多次运行。

## 故障排除

### 防火墙阻止我的连接

如果您被锁定：
- 确保您可以先通过 Tailscale VPN 访问
- SSH 访问（端口 22）始终允许
- 网关 **仅** 可通过 Tailscale 访问，这是设计使然

### 服务无法启动

```bash
# 检查日志
sudo journalctl -u clawdbot -n 100

# 验证权限
sudo ls -la /opt/clawdbot

# 测试手动启动
sudo -i -u clawdbot
cd ~/openclawot
pnpm start
```

### Docker 沙箱问题

```bash
# 验证 Docker 正在运行
sudo systemctl status docker

# 检查沙箱镜像
sudo docker images | grep clawdbot-sandbox

# 如果缺少沙箱镜像则构建
cd /opt/clawdbot/clawdbot
sudo -u clawdbot ./scripts/sandbox-setup.sh
```

### 提供商登录失败

确保您以 `clawdbot` 用户运行：

```bash
sudo -i -u clawdbot
openclaw-cn channels login
```

## 高级配置

详细的安全架构和故障排除：
- [安全架构](https://github.com/jiulingyun/openclaw-cn-ansible/blob/main/docs/security.md)
- [技术细节](https://github.com/jiulingyun/openclaw-cn-ansible/blob/main/docs/architecture.md)
- [故障排除指南](https://github.com/jiulingyun/openclaw-cn-ansible/blob/main/docs/troubleshooting.md)

## 相关

- [clawdbot-ansible](https://github.com/jiulingyun/openclaw-cn-ansible) — 完整部署指南
- [Docker](/install/docker) — 容器化网关设置
- [沙箱](/gateway/sandboxing) — 代理沙箱配置
- [多代理沙箱与工具](/multi-agent-sandbox-tools) — 每代理隔离
