12

我写了一个小模块,它使用winston 来记录东西。

我用过sudo npm install -g winston(它在虚拟机上......所以我不太关心sudo等。

从 npm 记录:

winston@0.7.2 /usr/local/lib/node_modules/winston
├── cycle@1.0.2
├── stack-trace@0.0.7
├── eyes@0.1.8
├── colors@0.6.2
├── async@0.2.9
├── pkginfo@0.3.0
└── request@2.16.6 (forever-agent@0.2.0, aws-sign@0.2.0, tunnel-agent@0.2.0, oauth-sign@0.2.0, json-stringify-safe@3.0.0, cookie-jar@0.2.0, node-uuid@1.4.1, mime@1.2.11, qs@0.5.6, hawk@0.10.2, form-data@0.0.10)

当我尝试在节点中运行我的模块时,我得到:

Error: Cannot find module 'winston'
    at Function.Module._resolveFilename (module.js:331:15)
    at Function.Module._load (module.js:273:25)
    at Module.require (module.js:357:17)
    at require (module.js:373:17)
    at Object.<anonymous> (/home/name/Code/neon/neon-js-spike/logger.js:2:9)
    at Module._compile (module.js:449:26)
    at Object.Module._extensions..js (module.js:467:10)
    at Module.load (module.js:349:32)
    at Function.Module._load (module.js:305:12)
    at Module.require (module.js:357:17)

系统版本:ubuntu node -v = v0.11.7-pre npm -v = 1.3.8

PS我在我的家用笔记本电脑(另一个ubuntu vm)上试过这个并且工作正常。

4

5 回答 5

12

如果设置类路径的建议不起作用,则可能是您需要使用 npm 链接。见: http: //blog.nodejs.org/2011/04/06/npm-1-0-link/

对于 winston,请转到脚本的根文件夹并使用以下命令:

npm link winston
于 2013-11-21T09:20:38.533 回答
7

您可能需要export NODE_PATH=/usr/local/lib/node_modules/usr/local/lib/node_modules您的节点模块全局安装的路径在哪里。

于 2013-10-15T16:39:08.930 回答
0

如果你使用

-> 做yarn install之前yarn run dev

于 2022-01-10T12:34:05.470 回答
0

一般来说,缺少模块应该通过NODE_PATH@fakewaffle 所说的设置来解决。当然,假设它们已安装。

但是对于winston,这对我不起作用。出于某种原因,我不得不更新文件权限:

chmod o+rx -R /pathto/node_modules/winston

我不知道为什么它的权限设置不正确。该解决方案适用于 Ubuntu,可能适用于其他 linux,但不适用于 Windows。

于 2017-03-12T06:48:02.287 回答
0

npm WARN winston-daily-rotate-file@3.2.3 需要 winston@^2 的对等方|| ^3 但没有安装。您必须自己安装对等依赖项。

已经删除了 node_modules 文件夹 并使npm install成为依赖项。有效

注意:在删除之前检查你有 package.json

“winston”:“^2.4.1”,“winston-daily-rotate-file”:“^3.0.0”

于 2018-07-04T12:52:09.580 回答