【OpenClaw】启动报错 disconnected (1008): unauthorized: gateway token mismatch

【OpenClaw】启动报错 disconnected (1008): unauthorized: gateway token mismatch


📑 文章目录

  1. 一、问题现象
  2. 二、错误原因分析
  3. 三、快速修复(60 秒)
  4. 四、Docker 用户特别注意
  5. 五、彻底修复(停止 → 清除 → 重启)
  6. 六、易混淆错误辨析
  7. 七、常用命令速查表
  8. 八、总结

一、问题现象

OpenClaw 启动后,控制台输出以下报错信息:

disconnected (1008): unauthorized: gateway token mismatch (open the dashboard URL and paste the token in Control UI settings) 

该错误属于 WebSocket 握手阶段的认证失败,错误码 1008 是 WebSocket 协议中定义的 “Policy Violation”,表示服务端因策略原因主动拒绝连接。


二、错误原因分析

当客户端(CLI、远程节点或 Control UI 浏览器)连接到 Gateway 时,会在握手阶段携带一个 Token。Gateway 会将该 Token 与自身配置中的 gateway.auth.token 进行比对。一旦不匹配,Gateway 将立即拒绝 WebSocket 连接,返回 1008 错误。

常见导致 Token 不匹配的场景:

  • 🔄 Gateway 重启后生成了新的 Token,但客户端仍使用旧 Token
  • 🌐 通过浏览器收藏夹/旧标签页访问 Dashboard(URL 中不含最新 Token)
  • 📝 手动修改了配置文件中的 auth.token,但未同步更新 remote.token
  • 🐳 Docker 环境变量静默覆盖了挂载配置文件中的 Token 值

三、快速修复(60 秒)

方法一:重新打开带 Token 的 Dashboard URL

如果你是通过浏览器的旧标签页或直接访问 http://127.0.0.1:18789/ 打开的 Dashboard,那么浏览器不会携带当前有效的 Token。

修复步骤:

# 方式 1:自动打开浏览器 openclaw dashboard # 方式 2:仅输出 URL,手动复制到浏览器 openclaw dashboard --no-open 
⚠️ 安全提示

请勿收藏带 Token 的 Dashboard URL!Token 应当被视为密码,每次通过命令获取即可。

方法二:对齐配置文件中的 Token

打开配置文件 ~/.openclaw/openclaw.json,重点关注以下两个字段:

{"gateway":{"auth":{"token":"my-secret-token"// ← Gateway 服务端使用},"remote":{"url":"ws://localhost:18789","token":"my-secret-token"// ← 客户端使用(必须与上面一致!)}}}

确认 auth.tokenremote.token 的值完全一致。如果不同,使用以下命令同步:

# 将 remote.token 设置为与 auth.token 一致 openclaw config set gateway.remote.token "YOUR_AUTH_TOKEN_HERE"# 重启 Gateway 使配置生效 openclaw gateway restart 

方法三:使用自动诊断修复

OpenClaw 内置了诊断工具,可以自动检测并修复大多数配置问题(包括 401 Unauthorized、429 Rate Limit Exceeded、Token Mismatch 等):

openclaw doctor --fix
推荐

如果你不确定问题根因,优先尝试 openclaw doctor --fix,它能覆盖大部分常见配置错误。

四、Docker 用户特别注意

在 Docker 中运行 OpenClaw 时,docker-compose.ymldocker run 命令中设置的 环境变量会静默覆盖挂载配置文件中的值。这意味着:即使 ~/.openclaw/openclaw.json 中的 Token 是正确的,一个过时的 OPENCLAW_GATEWAY_TOKEN 环境变量也会导致持续报错,且常规排查无效。

🔍 排查方法

# 进入容器查看所有 OpenClaw 相关环境变量dockerexec<container_name>env|grep OPENCLAW 

如果输出中出现 OPENCLAW_GATEWAY_TOKEN,且其值与配置文件中的 gateway.auth.token 不一致 —— 这就是问题所在

🛠️ 修复方法

docker-compose.yml 中更新或删除该环境变量:

# docker-compose.ymlservices:openclaw:image: openclaw:latest environment:# 方案 A:更新为正确的 Token- OPENCLAW_GATEWAY_TOKEN=正确的Token值 # 方案 B:直接删除此行,让配置文件生效# - OPENCLAW_GATEWAY_TOKEN=xxx ← 删除此行

修改完成后重启容器:

docker compose down &&docker compose up -d

五、彻底修复(停止 → 清除 → 重启)

如果以上快速修复方法都不奏效,可以执行完整的 Token 重置流程:

① 停止 Gateway → ② 清除旧 Token → ③ 启动 Gateway → ④ 重连 Agent 

Step 1:停止 Gateway 并确认已停止

# 原生部署 openclaw gateway stop ps aux |grep openclaw # Docker 部署docker compose stop dockerps|grep openclaw 

Step 2:清除旧 Token

删除每个 Agent 的 auth.json 文件中的 token 值。

注意

只删除 auth.json 中的 token 值,不要删除整个文件

Step 3:重新启动 Gateway

Gateway 在启动时会自动生成新的 Token。

openclaw gateway start 

Step 4:重新连接所有 Agent

Agent 首次连接时会自动获取并保存新 Token,无需手动操作。

💡 Docker 用户提示

日常重启推荐使用 docker compose restart;仅在需要全新容器状态时才使用 docker compose down && docker compose up -d

六、易混淆错误辨析

请注意区分以下两种 Token Mismatch 错误,它们的修复方式完全不同:

对比项Gateway Token MismatchDevice Token Mismatch
认证对象Agent → Gateway 的连接浏览器 / Control UI 会话
涉及配置gateway.auth.tokendevice.token
典型场景Gateway 重启、配置不同步更换浏览器、清除 Cookie
修复方式对齐 auth.token 和 remote.token重新打开 Dashboard URL

七、常用命令速查表

场景命令
🔧 自动诊断修复openclaw doctor --fix
🔑 查看当前 Gateway Tokenopenclaw config get gateway.auth.token
🔄 重新生成 Tokenopenclaw doctor --generate-gateway-token
🌐 打开带 Token 的 Dashboardopenclaw dashboard --no-open
📝 同步 Remote Tokenopenclaw config set gateway.remote.token "TOKEN"
♻️ 重启 Gatewayopenclaw gateway restart

八、总结

disconnected (1008): gateway token mismatch 错误的本质是 客户端与服务端持有的 Token 不一致。绝大多数情况下,通过以下三步即可快速解决:

  1. 首先尝试 openclaw doctor --fix 自动修复;
  2. 如未解决,检查配置文件中 auth.tokenremote.token 是否一致;
  3. Docker 用户额外检查环境变量 OPENCLAW_GATEWAY_TOKEN 是否存在覆盖。

如果上述方法均无效,执行完整的「停止 → 清除 → 重启」流程即可彻底解决。


🎉 希望本文对你有帮助!

如果解决了你的问题,请点赞 👍 收藏 ⭐ 关注 🔔,你的支持是我持续输出的动力!有问题欢迎在评论区留言交流~

Read more

从代码混乱到井然有序:飞算JavaAI的智能治理之道

从代码混乱到井然有序:飞算JavaAI的智能治理之道

文章目录 * 一、前言 * 二、飞算JavaAI平台 * 三、飞算JavaAI安装流程 * 3.1 Idea安装配置 * 3.2 官网注册登入 * 四、飞算JavaAI独特魅力:合并项目场景 * 4.1 ERP老项目精准翻新:保留核心逻辑的智能改造方案 * 4.2 智能合并:重构ERP系统的代码迷宫 * 4.3 ERP接口智能导航:模块化精准治理每一处数据流 * 4.4 其他功能 * 五、工程代码快速构建 * 六、飞算 JavaAI 与其他 AI 编程工具对比 * 七、总结与分析 飞算JavaAI彻底颠覆了传统AI代码生成的不可靠印象,以精准的需求理解和高质量的代码输出重新定义了智能编程体验。不同于那些需要反复调试的"半成品代码",它能直接生成符合企业级规范的Java代码,从Entity到Controller一气呵成,让开发者真正感受到&

By Ne0inhk
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题

如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题

如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题 摘要 本文针对Java项目启动时出现的java.io.IOException: closed错误,提供系统性解决方案。该异常通常由流资源异常关闭或损坏引发,常见于Maven依赖损坏(mvn dependency:purge-local-repository)、Wrapper脚本缺失(mvn wrapper:wrapper)、IDE缓存异常(Invalidate Caches)或Spring Boot插件配置不当(显式指定spring-boot-maven-plugin版本)等情况。通过分步操作(清理本地仓库、重装Wrapper、清理IDE缓存、检查pom配置)并结合日志调试(-X参数),可快速定位问题根源。最后提出预防建议:CI/CD定期清理依赖、版本化Wrapper文件、固定插件版本,有效提升项目启动稳定性与团队协作一致性。 关键词: Java IOException, Maven依赖修复, Spring

By Ne0inhk
华为OD机试双机位C卷-FLASH坏块监测系统(Py/Java/C/C++/Js/Go)

华为OD机试双机位C卷-FLASH坏块监测系统(Py/Java/C/C++/Js/Go)

FLASH坏块监测系统 华为OD机试双机位C卷 - 华为OD上机考试双机位C卷 100分题型 华为OD机试双机位C卷真题目录点击查看: 华为OD机试双机位C卷真题题库目录|机考题库 + 算法考点详解 题目描述 开发一个 FLASH 坏块监测系统,能够监测 FLASH 中坏块的数量。FLASH 介质以一个大小为 m×n的二维二进制矩阵表示,其中:0 表示正常,1 表示异常。最初,FLASH 介质中的所有单元格都是正常(即,所有单元格都是 0)。 系统运行过程中,FLASH 坏块不断产生:随着系统持续运行,某一个时刻 i,FLASH 介质中的某个单元格 (ri,ci)由正常变为异常。返回一个整数数组 result,其中 result[i] 是 FLASH 介质中第

By Ne0inhk