我编写了一个模块,并在不久前发布到了npm(https://npmjs.org/package/wisp)
因此它可以从命令行安装:
$npm I-G WISP
但是,当我从命令行运行它时,我不断得到一个错误,即optimist未安装:
$ wisp
Error: Cannot find module 'optimist'
at Function.Module._resolveFilename (module.js:338:15)
at Function.Module._load (module.js:280:25)
at Module.require (module.js:362:17)
at require (module.js:378:17)
at Object.<anonymous> (/usr/local/lib/node_modules/wisp/wisp:12:10)
at Object.<anonymous> (/usr/local/lib/node_modules/wisp/wisp:96:4)
at Module._compile (module.js:449:26)
at Object.exports.run (/usr/local/lib/node_modules/coffee-script/lib/coffee-script/coffee-script.js:68:25)
at compileScript (/usr/local/lib/node_modules/coffee-script/lib/coffee-script/command.js:135:29)
at fs.stat.notSources.(anonymous function) (/usr/local/lib/node_modules/coffee-script/lib/coffee-script/command.js:110:18)
但是,我在package.json中指定了一个依赖项:
{
"name": "wisp",
"author": "Brendan Scarvell <bscarvell@gmail.com>",
"version": "0.1.0",
"description": "Global nodejs file server",
"dependencies": {
"optimist": "~0.3.4"
},
"repository": "git://github.com/tehlulz/wisp",
"bin": {
"wisp" : "./wisp"
}
}
有人知道该怎么做才能让它运行吗?我知道这与bin部分有关,它将可执行文件添加到bin,并且该目录中的node_modules是空的。不知道怎么解决这个问题。
对于其他遇到此问题的人来说,我之所以出现此问题,是因为我的npm
安装到了一个不在node_path
上的位置。
[root@uberneek ~]# which npm
/opt/bin/npm
[root@uberneek ~]# which node
/opt/bin/node
[root@uberneek ~]# echo $NODE_PATH
我的NODE_PATH为空,运行npm install--global--verbose promedied-io
显示它正在安装到/opt/lib/node_modules/promedied-io
:
[root@uberneek ~]# npm install --global --verbose promised-io
npm info it worked if it ends with ok
npm verb cli [ '/opt/bin/node',
npm verb cli '/opt/bin/npm',
npm verb cli 'install',
npm verb cli '--global',
npm verb cli '--verbose',
npm verb cli 'promised-io' ]
npm info using npm@1.1.45
npm info using node@v0.8.4
[cut]
npm info build /opt/lib/node_modules/promised-io
npm verb from cache /opt/lib/node_modules/promised-io/package.json
npm verb linkStuff [ true, '/opt/lib/node_modules', true, '/opt/lib/node_modules' ]
[cut]
我的脚本在要求('promedie-io/promise')
时失败:
[neek@uberneek project]$ node buildscripts/stringsmerge.js
module.js:340
throw err;
^
Error: Cannot find module 'promised-io/promise'
at Function.Module._resolveFilename (module.js:338:15)
我可能使用configure--prefix=/opt
从源代码处安装了node和npm。我不知道为什么这会使他们无法找到已安装的模块。目前的修复方法是将NODE_PATH指向正确的目录:
export NODE_PATH=/opt/lib/node_modules
我的要求('promedies-io/promise')
现在成功。
将以下内容添加到prog(mac)的开头:
module.paths.push('/usr/local/lib/node_modules');
默认情况下,node不查看/usr/local/lib/node_module内部以加载全局模块。请参阅http://nodejs.org/api/modules.html#modules_loading_from_the_global_folders中解释的模块加载
因此,您必须1)将/usr/local/lib/node_module添加到NODE_PATH并将其导出,或者2)将已安装的节点模块复制到/usr/local/lib/node.(如加载模块的链接所述,node将在此路径中搜索并将工作)