Node + tsx “__name is not a function” 崩溃
概述
通过 Node 使用tsx 运行 Fased 时,启动阶段报错:
node --import tsx ... 的开发路径中。相同代码在先构建、再运行编译入口时可以正常工作。
环境
- Node: v25.x(在 v25.3.0 上观察到)
- tsx: 4.21.0
- 操作系统: 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辅助函数缺失或被重写的问题。
解决方法
- 使用常规 runner 脚本,而不是直接运行
node --import tsx: - 或先构建,再运行编译产物:
- 已在本地确认:编译产物加
node fased.mjs status在 Node 25 上可正常运行。 - 如果可能,在 TS 加载器中禁用 esbuild 的 keepNames(防止插入
__name辅助函数);tsx 目前不提供此配置项。 - 在受支持的 Node LTS 和本机最新 Node 上测试
tsx,确认问题是否与特定 Node/loader 组合有关。
参考资料
- https://opennext.js.org/cloudflare/howtos/keep_names
- https://esbuild.github.io/api/#keep-names
- https://github.com/evanw/esbuild/issues/1031
后续步骤
- 在受支持的 Node LTS 和本机最新 Node 上复现。
- 测试
tsxnightly 版本,或在存在已知回归时固定到早期版本。 - 如果在 Node LTS 上也能复现,则向上游提交包含
__name堆栈跟踪的最小复现。