Linux中npm出现npmlog找不到的解决方法

Question

今天在对nodejs项目进行服务器迁移的时,在新的linux服务器上输入 npm -v 命令后报 “cannot find module ‘npmlog’….”的错误。找到的原因是拷贝过去的bin目录下的npm文件并没有链接到module目录下的npm-cli.js文件,所以导致在执行 npm -v命令时,路径问题导致npmlog模块无法找到。

具体错误信息如下所示:

# npm -v
module.js:338
    throw err;
          ^
Error: Cannot find module 'npmlog'
    at Function.Module._resolveFilename (module.js:336:15)
    at Function.Module._load (module.js:278:25)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at /usr/local/lib/node_modules/npm/bin/npm-cli.js:18:11
    at Object. (/usr/local/lib/node_modules/npm/bin/npm-cli.js:75:3)
    at Module._compile (module.js:460:26)
    at Object.Module._extensions..js (module.js:478:10)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)

Answer

解决的方法有两个,一个是删除bin目录下的npm文件,并用如下命令链接到npm-cli.js。

ln -s ../lib/node_modules/npm/bin/npm-cli.js

经过试验发现,在服务器外解压缩nodejs官网下载的编译好的压缩包,再将解压的文件拷贝到服务器上时,bin下的npm是没有链接到npm-cli.js的。

第二种方式是将下载好的node-v0.10.33-linux-x64.tar.gz压缩包先放置在服务器上,再进行解压缩,此时npm是已经链接到npm-cli.js的。

看到命令行中显示如下则为成功。

[root@linux bin]# ll
npm -> ../lib/node_modules/npm/bin/npm-cli.js

[root@linux bin]# ./npm -v
v1.4.26

这两种拷贝方式导致不同的情况的原因不详,有待考究。


Reference

Linux中npm出现npmlog找不到的解决方法


More

[1] Get Error: Cannot find module ‘npmlog’ when installing Browserfy

你可能感兴趣的:(9.,部署和环境搭建,-------9.1.,Linux,Linux异常)