2015-02-06 77 views
1

在过去的16个小时左右,我一直在试图在我的电脑上运行MEAN堆栈项目。如何调试nodejs项目?

我开始与Yeoman angular-fullstack project。但是那给了我各种各样的错误,所以我就放弃了。

然后我跟着一些帮助我开始的教程,但没有涵盖我的问题。

然后我发现mean.io它提供了一个完整的样板MEAN堆栈项目,我按照说明进行设置。不幸的是,当我尝试运行它,我又得到各种错误:-(

的是最糟糕的,它说什么/何原因造成的错误NOTHING。

谁能帮我想出来了吗?请:-)

我得到的最新错误是当我运行grunt

C:\Users\Imray\projects Practice\meanIO\meanApp>grunt 
Running "hook" task 
>> Starting hooked tasks. 

Running "clean:0" (clean) task 
>> 0 paths cleaned. 

Running "jshint:all" (jshint) task 
>> 42 files lint free. 

Running "csslint:src" (csslint) task 
>> 5 files lint free. 

Running "concurrent:tasks" (concurrent) task 
Running "watch" task 
Waiting... 
Running "nodemon:dev" (nodemon) task 
[nodemon] v1.2.1 
[nodemon] to restart at any time, enter `rs` 
[nodemon] watching: *.* 
[nodemon] starting `node --debug server.js` 
debugger listening on port 5858 

events.js:72 
     throw er; // Unhandled 'error' event 
      ^
Error: listen EADDRINUSE 
    at errnoException (net.js:904:11) 
    at Server._listen2 (net.js:1042:14) 
    at listen (net.js:1064:10) 
    at Server.listen (net.js:1138:5) 
    at ExpressEngine.beginBootstrap (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\lib\core_modules\server\E 
xpressEngine.js:123:14) 
    at Meanio.serveWithDb (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\lib\core_modules\server\index.js:14 
:10) 
    at Consumer.Dependable.runAction (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\node_modules\lazy-depend 
able\index.js:72:22) 
    at Consumer.Dependable.fire (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\node_modules\lazy-dependable\ 
index.js:69:53) 
    at Consumer.onResolved (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\node_modules\lazy-dependable\index 
.js:119:8) 
    at Consumer.Dependable.resolve (C:\Users\Imray\projects Practice\meanIO\meanApp\node_modules\meanio\node_modules\lazy-dependab 
le\index.js:55:10) 
[nodemon] app crashed - waiting for file changes before starting... 

回答

0

重新启动计算机后问题就消失了。不知道为什么,但我会接受。

0

EADDRINUSE是一个低级别的系统错误,通常意味着您正在使用的端口号上还有别的东西在运行。尝试使用不同的端口。

编辑:请注意,它可能不只是实际的服务器端口是无效的。它看起来像你的部署脚本创建了一个调试器,可能还有其他服务在不同的端口上侦听,所以它们可能需要改变。

+0

而不是使用'grunt'作为'mean.io'文档指示,我使用'npm start',现在我得到'错误:写入EINVAL - 无法写入IPC通道。这太令人沮丧 – CodyBugstein 2015-02-06 14:28:52

+0

发布你应该使用的gruntfile和grunt命令。 – 2015-02-06 14:35:05

+0

[docs](http://learn.mean.io/)声称只使用'grunt',gruntfile位于[Mean.io Github回购](https://github.com/linnovate/mean/)上blob/master/Gruntfile.js) – CodyBugstein 2015-02-06 14:37:01

2

根据你的输出结果你有Error: listen EADDRINUSE。 这意味着您已经在此端口上运行进程。

尝试通过键入调查哪些进程使用这个端口:

sudo lsof -n -i4TCP:$PORT_NUMBER | grep LISTEN 

杀死该进程,并重新启动应用程序。
如果您需要该过程,请更改您的应用程序端口。

+0

我在Windows上,所以我使用'resmon'来查看'5858'是否被使用,它不是 – CodyBugstein 2015-02-06 14:32:13