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 的 loader 路径中,此模块的辅助函数缺失或被覆盖。 - 在其他使用 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 loader 中禁用 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 回归。
- 测试
tsxnightly,或如果存在已知回归,则固定到更早版本。 - 如果在 Node LTS 上也能复现,请向上游提交一个最小复现,并附上
__name堆栈跟踪。