Node + tsx “__name is not a function” 崩溃
摘要
通过 Node 使用tsx 运行 OpenClaw 时在启动失败:
tsx(提交 2871657e,2026-01-06)之后开始的。相同的运行路径在 Bun 下工作正常。
环境
- Node:v25.x(在 v25.3.0 上观察到)
- tsx:4.21.0
- OS:macOS(在其他运行 Node 25 的平台上也可能复现)
复现(仅 Node)
仓库中的最小复现
Node 版本检查
- Node 25.3.0:失败
- Node 22.22.0(Homebrew
node@22):失败 - Node 24:尚未在此处安装;需要验证
说明 / 假设
tsx使用 esbuild 来转换 TS/ESM。esbuild 的keepNames会发出一个__name辅助函数,并用__name(...)包装函数定义。- 崩溃表明
__name存在但在运行时不是一个函数,这意味着该辅助函数在 Node 25 加载器路径中缺失或被覆盖。 - 在其他 esbuild 使用者中,当辅助函数缺失或被重写时,也报告过类似的
__name辅助函数问题。
回归历史
2871657e(2026-01-06):脚本已从 Bun 更改为 tsx,以使 Bun 成为可选项。- 在此之前(Bun 路径),
openclaw status和gateway:watch工作正常。
解决方案
- 使用 Bun 运行开发脚本(当前临时回退方案)。
-
使用 Node + tsc watch,然后运行编译输出:
-
本地已确认:
pnpm exec tsc -p tsconfig.json+node openclaw.mjs status在 Node 25 上有效。 -
如果可能,在 TS 加载器中禁用 esbuild keepNames(防止
__name辅助函数插入);tsx 目前未公开此选项。 -
使用
tsx测试 Node LTS (22/24) 以查看该问题是否特定于 Node 25。
参考
- https://opennext.js.org/cloudflare/howtos/keep_names
- https://esbuild.github.io/api/#keep-names
- https://github.com/evanw/esbuild/issues/1031
后续步骤
- 在 Node 22/24 上复现以确认 Node 25 的回归。
- 如果存在已知的回归,请测试
tsx每夜版或固定到早期版本。 - 如果在 Node LTS 上复现,请使用
__name堆栈跟踪向上游提交最小复现。
本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。