🚀 省流助手(速通结论)
升级后报错 Error: claude native binary not installed,主因是 pnpm v10 默认禁用了构建脚本,导致核心二进制文件未下载。
三行命令修复:
- 删旧部:
rm -rf $(npm config get prefix)/lib/node_modules/@anthropic-ai/claude-code - 切官方:
nrm use npm(或在安装时指定官方 registry) - 强行装:
pnpm add -g @anthropic-ai/claude-code --allow-build=@anthropic-ai/claude-code
一、 现象:为什么 2.1.100 之前没事,现在报错?
在 2.1.100 之前(如 2.1.85)安装体验通常很顺滑,但近期升级到 2.1.121 频繁卡死,核心原因如下:
- 架构转向原生化:从 2.1.100 左右开始,Claude Code 为了性能强化了 Native Binary 分发。npm 包主体只是个壳,核心逻辑需要在
postinstall阶段通过install.cjs实时下载对应系统的二进制文件。 - 包管理工具策略变更:如果你最近升级了 pnpm v10,它出于安全考虑默认跳过了所有构建脚本。结果就是"壳装上了,灵魂(二进制文件)没下来",敲命令必崩。
二、 排雷:那些看似正确的"假动作"
-
假方案 A:直接
npm install -g。- 坑点:在 NVM 环境下,如果之前安装残留过损坏文件,常报
ENOTEMPTY: directory not empty, rename...。npm 试图备份旧目录但因目录非空锁死。
- 坑点:在 NVM 环境下,如果之前安装残留过损坏文件,常报
-
假方案 B:使用淘宝源/私有源安装。
- 坑点:
install.cjs脚本在下载底层二进制时,可能存在路径同步延迟或对官方 Registry 路径的硬编码,导致脚本虽然跑了但下不到东西。
- 坑点:
三、 修复 SOP:彻底清理 + 授权构建
遇到 ENOTEMPTY 报错或原生文件缺失,按此流程操作:
1. 物理清理(解决 90% 的重命名报错)
不要指望 uninstall 能删干净,直接暴力删除 Node 全局 lib 下的残留目录:
bash
# 自动获取全局路径并清理
rm -rf "$(npm config get prefix)/lib/node_modules/@anthropic-ai/claude-code"
2. 指定官方源并"授权"构建
安装时,必须显式声明允许执行构建脚本,并确保下载流指向官方源:
bash
pnpm add -g @anthropic-ai/claude-code --allow-build=@anthropic-ai/claude-code --registry=https://npmjs.org
3. 验证
ruby
$ claude -v
2.1.121 (Claude Code) # 看到版本号,说明二进制文件已挂载成功
四、 总结
- 版本分水岭:2.1.100 后的架构更依赖环境构建,不要用旧版本的经验套新版本。
- 物理删除胜过卸载:在 NVM 环境下遇到全局包升级冲突,手动
rm -rf永远是最稳的。