跳转到主要内容

OpenClaw on Oracle Cloud (OCI)

目标

在 Oracle Cloud 的 Always Free ARM 层上运行持久的 OpenClaw Gateway 网关。 Oracle 的免费层非常适合 OpenClaw(特别是如果您已经拥有 OCI 账户),但它也有折衷之处:
  • ARM 架构(大多数东西都可以运行,但某些二进制文件可能仅限 x86)
  • 容量和注册可能比较棘手

成本比较 (2026)

提供商方案规格价格/月备注
Oracle 云Always Free ARM最多 4 OCPU,24GB RAM$0ARM,容量有限
HetznerCX222 vCPU,4GB RAM~ $4最便宜的付费选项
DigitalOceanBasic1 vCPU,1GB RAM$6界面友好,文档完善
VultrCloud Compute1 vCPU,1GB RAM$6众多数据中心
LinodeNanode1 vCPU,1GB RAM$5现属于 Akamai

先决条件

1) 创建 OCI 实例

  1. 登录到 Oracle 云控制台
  2. 导航至 Compute → Instances → Create Instance
  3. 配置:
    • Name: openclaw
    • Image: Ubuntu 24.04 (aarch64)
    • Shape: VM.Standard.A1.Flex (Ampere ARM)
    • OCPUs: 2(或最多 4 个)
    • Memory: 12 GB(或最多 24 GB)
    • Boot volume: 50 GB(最多 200 GB 免费)
    • SSH key: 添加您的公钥
  4. 点击 Create
  5. 记录公网 IP 地址
提示: 如果创建实例时提示“Out of capacity”(容量不足),请尝试更换不同的可用性域或稍后重试。免费层的容量有限。

2) 连接并更新

# Connect via public IP
ssh ubuntu@YOUR_PUBLIC_IP

# Update system
sudo apt update && sudo apt upgrade -y
sudo apt install -y build-essential
注意: build-essential 是编译某些依赖项的 ARM 版本所必需的。

3) 配置用户和主机名

# Set hostname
sudo hostnamectl set-hostname openclaw

# Set password for ubuntu user
sudo passwd ubuntu

# Enable lingering (keeps user services running after logout)
sudo loginctl enable-linger ubuntu

4) 安装 Tailscale

curl -fsSL https://tailscale.com/install.sh | sh
sudo tailscale up --ssh --hostname=openclaw
这将启用 Tailscale SSH,因此您可以从 tailnet 上的任何设备通过 ssh openclaw 进行连接 — 无需公网 IP。 验证:
tailscale status
从现在开始,通过 Tailscale 连接: ssh ubuntu@openclaw (或使用 Tailscale IP)。

5) 安装 OpenClaw

curl -fsSL https://openclaw.ai/install.sh | bash
source ~/.bashrc
当提示“How do you want to hatch your bot?”(您希望如何孵化您的机器人?)时,选择 “Do this later”(稍后再做)。
注意:如果您遇到 ARM 原生构建问题,在尝试 Homebrew 之前,请先使用系统软件包(例如 sudo apt install -y build-essential)。

6) 配置 Gateway(网关) (loopback + token auth) 并启用 Tailscale Serve

默认使用令牌认证。这种方式可预测,且无需设置任何“不安全认证”控制 UI 标志。
# Keep the Gateway private on the VM
openclaw config set gateway.bind loopback

# Require auth for the Gateway + Control UI
openclaw config set gateway.auth.mode token
openclaw doctor --generate-gateway-token

# Expose over Tailscale Serve (HTTPS + tailnet access)
openclaw config set gateway.tailscale.mode serve
openclaw config set gateway.trustedProxies '["127.0.0.1"]'

systemctl --user restart openclaw-gateway

7) 验证

# Check version
openclaw --version

# Check daemon status
systemctl --user status openclaw-gateway

# Check Tailscale Serve
tailscale serve status

# Test local response
curl http://localhost:18789

8) 锁定 VCN 安全性

现在一切正常,请锁定 VCN 以阻止除 Tailscale 之外的所有流量。OCI 的虚拟云网络充当网络边缘的防火墙 —— 流量在到达您的实例之前即被阻止。
  1. 在 OCI 控制台中,转到 Networking → Virtual Cloud Networks(网络 → 虚拟云网络)
  2. 点击您的 VCN → Security Lists(安全列表)→ Default Security List(默认安全列表)
  3. 删除所有入站规则,除了:
    • 0.0.0.0/0 UDP 41641 (Tailscale)
  4. 保留默认的出站规则(允许所有出站流量)
这会在网络边缘阻断端口 22 上的 SSH、HTTP、HTTPS 以及其他所有流量。从现在起,您只能通过 Tailscale 进行连接。

访问控制 UI

从您的 Tailscale 网络中的任何设备:
https://openclaw.<tailnet-name>.ts.net/
<tailnet-name> 替换为您的 tailnet 名称(在 tailscale status 中可见)。 无需 SSH 隧道。Tailscale 提供:
  • HTTPS 加密(自动证书)
  • 通过 Tailscale 身份进行身份验证
  • 从 tailnet(笔记本电脑、手机等)上的任何设备进行访问

安全性:VCN + Tailscale(推荐基线)

在 VCN 锁定(仅开放 UDP 41641)且 Gateway(网关) 绑定到环回地址的情况下,您可以获得强大的纵深防御:公共流量在网络边缘被阻止,而管理访问则通过您的 tailnet 进行。 这种设置通常消除了仅为了阻止全网范围 SSH 暴力破解而对额外基于主机的防火墙规则的 需求——但您仍应保持操作系统更新,运行 openclaw security audit,并验证您没有意外监听公共接口。

Already protected

传统步骤需要?原因
UFW 防火墙VCN 在流量到达实例之前进行阻止
fail2ban如果在 VCN 处阻止了端口 22,则没有暴力破解
sshd 加固Tailscale SSH 不使用 sshd
禁用 root 登录Tailscale 使用 Tailscale 身份,而不是系统用户
仅 SSH 密钥认证Tailscale 通过您的 tailnet 进行身份验证
IPv6 加固通常不需要取决于您的 VCN/子网设置;请验证实际分配/暴露的内容

仍然推荐

  • 凭证权限: chmod 700 ~/.openclaw
  • 安全审计: openclaw security audit
  • 系统更新: 定期运行 sudo apt update && sudo apt upgrade
  • 监控 Tailscale:Tailscale 管理控制台 中查看设备

验证安全态势

# Confirm no public ports listening
sudo ss -tlnp | grep -v '127.0.0.1\|::1'

# Verify Tailscale SSH is active
tailscale status | grep -q 'offers: ssh' && echo "Tailscale SSH active"

# Optional: disable sshd entirely
sudo systemctl disable --now ssh

后备方案:SSH 隧道

如果 Tailscale Serve 不工作,请使用 SSH 隧道:
# From your local machine (via Tailscale)
ssh -L 18789:127.0.0.1:18789 ubuntu@openclaw
然后打开 http://localhost:18789

故障排除

实例创建失败(“容量不足”)

免费层 ARM 实例很受欢迎。请尝试:
  • 不同的可用性域
  • 在非高峰时段重试(清晨)
  • 选择配置时使用“Always Free(永久免费)”筛选器

Tailscale 将无法连接

# Check status
sudo tailscale status

# Re-authenticate
sudo tailscale up --ssh --hostname=openclaw --reset

Gateway(网关) 将无法启动

openclaw gateway status
openclaw doctor --non-interactive
journalctl --user -u openclaw-gateway -n 50

无法访问控制 UI

# Verify Tailscale Serve is running
tailscale serve status

# Check gateway is listening
curl http://localhost:18789

# Restart if needed
systemctl --user restart openclaw-gateway

ARM 二进制文件问题

某些工具可能没有 ARM 构建。请检查:
uname -m  # Should show aarch64
大多数 npm 包都可以正常工作。对于二进制文件,请查找 linux-arm64aarch64 版本。

持久性

所有状态保存在:
  • ~/.openclaw/ — 配置、凭证、会话数据
  • ~/.openclaw/workspace/ — 工作区(SOUL.md、记忆、产物)
定期备份:
tar -czvf openclaw-backup.tar.gz ~/.openclaw ~/.openclaw/workspace

另请参阅


本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。
Last modified on March 27, 2026