【OpenClaw】OpenClaw无法访问问题排查指南

OpenClaw无法访问问题排查指南

一、问题描述

容器正在运行,端口已正确映射,但无法通过 http://localhost:18789 访问OpenClaw Web界面。

二、问题根源

配置向导可能修改了Web UI的绑定地址或启用了身份验证机制,导致外部无法正常访问。

常见原因:

  • 配置文件中的 bind 被设置 为 loopback127.0.0.1
  • 启用了Token或密码身份验证
  • 配置文件中的认证模式设置不当

三、排查步骤

步骤1:确认容器是否还在运行

powershell 复制代码
docker ps | Select-String "openclaw"
  • ✅ 如果看到状态为 Up,说明容器还在运行,继续下一步
  • ❌ 如果没有输出或状态为 Exited,说明容器意外退出

查看错误日志:

powershell 复制代码
docker logs openclaw --tail=50

步骤2:检查端口映射是否正常

powershell 复制代码
docker port openclaw

预期输出:18789/tcp -> 0.0.0.0:18789

  • ✅ 如果输出正确,继续下一步
  • ❌ 如果输出为空或端口不对,说明端口映射丢失

步骤3:查看容器日志

powershell 复制代码
docker logs openclaw 2>&1 | Select-String -Pattern "token|http|listening|bind"

重点关注:

  • Gateway listening on http://0.0.0.0:18789 - 服务正常监听
  • Access with token: http://localhost:18789?token=xxxx - 需要Token访问
  • bind address already in use - 端口被占用
  • permission denied - 权限问题

步骤4:重启容器

powershell 复制代码
docker restart openclaw

等待10-20秒后,再次访问 http://localhost:18789

四、问题解决

问题1:bind设置为loopback

症状 :配置文件中的 "bind": "loopback" 导致Web UI只允许容器内部访问

解决方法

  1. 编辑配置文件 Z:\Tools\docker\openclaw\data\openclaw.json

  2. 找到 "bind": "loopback" 这一行

  3. 修改为:

    json 复制代码
    "bind": "0.0.0.0"

    或者直接删除该行(使用默认值)

  4. 保存文件

  5. 重启容器:

    powershell 复制代码
    docker restart openclaw

问题2:启用了Token认证

症状:日志中显示需要Token才能访问

解决方法

  1. 从日志中找到完整的Token URL:

    复制代码
    Access with token: http://localhost:18789?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
  2. 直接使用该URL访问

问题3:需要密码登录

症状:访问时弹出密码输入框

解决方法

使用设置的环境变量密码:Perfect1@34

问题4:认证模式设置为必须验证

症状:所有访问都被拒绝

解决方法

  1. 编辑配置文件 Z:\Tools\docker\openclaw\data\openclaw.json

  2. 添加或修改认证模式:

    json 复制代码
    {
      "gateway": {
        "auth": {
          "mode": "none"
        }
      }
    }
  3. 保存并重启容器

⚠️ 注意:禁用认证会让任何能访问该端口的人直接控制OpenClaw,仅在个人电脑或内网环境使用。

五、完整配置文件示例

以下是推荐的配置文件内容:

json 复制代码
{
  "bind": "0.0.0.0",
  "gateway": {
    "auth": {
      "mode": "password"
    }
  },
  "models": {
    "providers": {
      "ollama": {
        "baseUrl": "http://host.docker.internal:11434",
        "apiKey": "ollama-local"
      }
    }
  },
  "agents": {
    "defaults": {
      "model": {
        "primary": "ollama/deepseek-r1:latest"
      }
    }
  }
}

六、验证修复

1. 确认bind配置已更改

powershell 复制代码
docker exec openclaw Select-String -Pattern "bind" /home/node/.openclaw/openclaw.json

应该显示 "bind": "0.0.0.0"

2. 测试Web访问

在浏览器中访问:

复制代码
http://localhost:18789

或尝试:

复制代码
http://127.0.0.1:18789

3. 检查服务状态

powershell 复制代码
docker logs openclaw 2>&1 | Select-String -Pattern "listening|ready"

七、终极解决方案

如果以上方法都不奏效,可以删除容器并重新创建(保留数据卷):

powershell 复制代码
# 停止并删除容器
docker stop openclaw
docker rm openclaw

# 重新创建容器
docker run -d `
  --name openclaw `
  --restart always `
  -p 18789:18789 `
  --add-host=host.docker.internal:host-gateway `
  -v "Z:\Tools\docker\openclaw\data:/home/node/.openclaw" `
  -v "Z:\Tools\docker\openclaw\config:/app/config" `
  -e OLLAMA_BASE_URL=http://host.docker.internal:11434 `
  -e DEFAULT_MODEL=deepseek-r1:latest `
  ghcr.io/openclaw/openclaw:latest

八、补充说明

为什么会出现bind设置为loopback?

配置向导中某个选项(如安全提示)可能导致自动生成了 loopback 配置。在容器环境下,loopback 只允许容器内部访问,对外不可见。

Windows防火墙检查

如果依然连接失败,检查Windows Defender防火墙,确保没有阻止Docker的网络访问。

端口冲突检查

如果18789端口被其他程序占用,可以:

  1. 查找占用端口的进程:netstat -ano | Select-String "18789"
  2. 结束占用进程或使用其他端口

九、预防措施

  1. 一劳永逸的配置方法 :使用环境变量和 --add-host 参数创建容器
  2. 定期备份配置文件 :备份 Z:\Tools\docker\openclaw\data\openclaw.json
  3. 记录关键配置:记录Token、密码等重要信息
  4. 使用固定版本镜像:避免使用latest版本导致配置不兼容
相关推荐
AC赳赳老秦2 小时前
OpenClaw+Power Apps 实战:自动生成 Power Apps 应用、连接 Excel 数据源
大数据·开发语言·python·serverless·excel·deepseek·openclaw
七夜zippoe11 小时前
OpenClaw 节点方法调用:跨设备能力调用实战
ai·调用·跨设备·openclaw·nodes
虾壳云官方1 天前
OpenClaw 2.7.9 Windows 一键部署教程:零基础也能搭建 AI 自动化助手
运维·人工智能·windows·自动化·openclaw·openclaw一键部署
七夜zippoe2 天前
OpenClaw 节点命令执行:远程Shell与系统操作实战
github·shell·openclaw·nodes·系统操作
旺财矿工2 天前
OpenClaw 飞书机器人配置教程|一键对接飞书,实现聊天下达 AI 指令
人工智能·机器人·飞书·openclaw·龙虾
程序猿小白菜2 天前
OpenClaw 飞书机器人搭建流程
ai·机器人·飞书·openclaw
x-cmd2 天前
[260612] x-cmd v0.9.8:x feishu 发送消息支持 Markdown + 卡片,让 x claw 接入飞书后消息不再干巴巴
飞书·agent·claude·命令行·x-cmd·openclaw
虾壳云官方2 天前
【本地 AI 自动化最新工具】 OpenClaw 2.7.9 Windows 完整部署教程(包含安装包)
人工智能·windows·openclaw·openclaw安装·openclaw一键部署
AC赳赳老秦2 天前
OpenClaw + 云数据库运维:自动备份、扩容、迁移 RDS/MySQL 云数据库
运维·开发语言·数据库·人工智能·python·mysql·openclaw
七夜zippoe2 天前
OpenClaw 节点定位服务:GPS与位置信息实战
gps·位置信息·openclaw·nodes·定位服务