错误:找不到模块'./lib/socket.io'

时间:2012-03-26 19:23:27

标签: node.js socket.io npm ubuntu-server

我让我的服务器使用了早期版本的node.js,npm和socket.io但是在更新后我开始遇到socket.io的问题:

$ node server.js

node.js:237
        throw e; // process.nextTick error, or 'error' event on first tick
              ^
Error: Cannot find module './lib/socket.io'
    at Function._resolveFilename (module.js:333:15)
    at Function._load (module.js:280:25)
    at Module.require (module.js:357:17)
    at require (module.js:373:17)
    at Object.<anonymous> (/usr/local/lib/node_modules/socket.io/index.js:8:18)
    at Module._compile (module.js:444:26)
    at Object..js (module.js:462:10)
    at Module.load (module.js:351:32)
    at Function._load (module.js:309:12)
    at Module.require (module.js:357:17)

在升级之前,我在node_modules下有一个socket.io的符号链接,指向同名的“集中安装”目录。最近我尝试通过发出命令来安装socket.io local到我的项目:

npm install socket.io

将socket.io放在我的项目中的node_modules下。我一开始觉得奇怪的是错误信息是“./lib/socket.io”,但是当我查看它时,我发现project / node_modules / socket.io / index.js需要socket.io,如下所示:< / p>

module.exports = require('./lib/socket.io');

但除了交通之外什么都没有:

...project/node_modules/socket.io/lib
$ ll
total 24
drwxrwxr-x 3 ghbarratt dev  4096 Mar 26 14:38 .
drwxrwxr-x 5 ghbarratt dev  4096 Mar 26 15:03 ..
-rw-rw-r-- 1 ghbarratt dev 10777 Mar  6 16:37 transport.js
drwxrwxr-x 3 ghbarratt dev  4096 Mar 26 14:38 transports

lib下是否有另一个socket.io目录或socket.io.js文件?为什么index.js需要一个似乎缺少的内部文件?

版本:

node -v
v0.7.7-pre

npm -v
1.1.12

socket.io@0.9.2

Distributor ID: Ubuntu
Description:    Ubuntu 10.10
Release:        10.10
Codename:       maverick

1 个答案:

答案 0 :(得分:17)

我讨厌回答我自己的问题,但我确实解决了问题并且没有其他答案,所以我想补充一下,以防它可以帮助别人。

根据Felix Loether的评论(我+ 1),我相当确定我没有得到npm install socket.io期间我应该拥有的所有文件。我尝试做apt-get update / upgrade,认为我可能需要更新tar或其他东西,但结果仍然相同。

我在安装输出中注意到304响应,并且在那时想知道是否存在某种我应该尝试清除的npm缓存。 I discovered我可以使用以下命令清除npm缓存:npm cache clean。清理缓存终于让我超越了无错误直到运行时的问题。

然后我开始收到一条错误消息:make: node-waf: Command not found lead me to reinstall node

毕竟,它奏效了!

相关问题