Nodejs无法使用全局模块

Node.js 连接 MySQL时,在代码所在的目录下本地安装MySQL模块可以正常运行:

本地安装
$ npm install mysql
$ node mysql.js
--------------------------SELECT----------------------------
[ RowDataPacket { id: '1', name: 'chang' } ]
------------------------------------------------------------

想把MySQL模块全局安装,以后所有目录的下的代码都可以引用,不必在每一个代码所在的目录下本地安装一次:

全局安装
$ npm install -g mysql

删除本地MySQL模块,再次运行,报错:

$ node mysql.js
module.js:471
    throw err;
    ^

Error: Cannot find module 'mysql'
    at Function.Module._resolveFilename (module.js:469:15)
    at Function.Module._load (module.js:417:25)
    at Module.require (module.js:497:17)
    at require (internal/module.js:20:19)
    at Object. (D:\demo\mysql.js:1:75)
    at Module._compile (module.js:570:32)
    at Object.Module._extensions..js (module.js:579:10)
    at Module.load (module.js:487:32)
    at tryModuleLoad (module.js:446:12)
    at Function.Module._load (module.js:438:3)

查看npm config list的prefix值prefix = "C:\\Users\\bili\\AppData\\Roaming\\npm",进入该目录,查看确实已经有MySQL模块,不知道为什么无效(可能是Nodejs本身的bug吧)。设置NODE_PATH(C:\Users\bili\AppData\Roaming\npm)环境变量后可正常运行。

你可能感兴趣的:(Nodejs无法使用全局模块)