Nodejs应用程序错误:使用pm2部署时绑定EADDRINUSE

时间:2013-09-08 19:40:02

标签: node.js mongodb deployment express cluster-computing

使用pm2

快速部署应用程序

数据库是mongodb

使用命令运行app时:

NODE_ENV=production pm2 start app.js -i max

aften有错误:绑定EADDRINUSE,这是日志,当出错时,

[app err (l0)] js:1073:26
[app err (l1)]     at Object.30:1 (cluster.js:587:5)
[app err (l2)]     at handleResponse (cluster.js:171:41)
[app err (l3)]     at respond (cluster.js:192:5)
[app err (l4)]     at handleMessage (cluster.js:202:5)
[app err (l5)]     at process.EventEmitter.emit (events.js:117:20)
[app err (l6)]     at handleMessage (child_process.js:318:10)
[app err (l7)]     at child_process.js:392:7
[app err (l8)]     at process.handleConversion.net.Native.got (child_process.js:91:7)Error: bind EADDRINUSE
[app err (l9)]     at errnoException (net.js:901:11)
[app err (l10)]     at net.js:1073:26
[app err (l11)]     at Object.31:1 (cluster.js:587:5)
[app err (l12)]     at handleResponse (cluster.js:171:41)
[app err (l13)]     at respond (cluster.js:192:5)
[app err (l14)]     at handleMessage (cluster.js:202:5)
[app err (l15)]     at process.EventEmitter.emit (events.js:117:20)
[app err (l16)]     at handleMessage (child_process.js:318:10)
[app err (l17)]     at child_process.js:392:7
[app err (l18)]     at process.handleConversion.net.Native.got (child_process.js:91:7)

这导致app很慢,如何解决这个问题,非常感谢

2 个答案:

答案 0 :(得分:29)

我不知道您的应用程序使用的端口。这取决于你的代码。在这个例子中,我假设端口是3000

您需要验证您的系统上是否已使用该端口。要做到这一点:

  • 在linux上:sudo netstat -nltp | grep 3000
  • 在OSX上:sudo lsof -i -P | grep 3000

如果您有结果,则需要终止该过程(kill <pid>)。

您应该检查pm2 list是否返回0进程。此外,当您执行pm2 stopAll时,套接字不会被释放。不要忘记做pm2 kill以确保守护程序被杀死。

$ pm2 kill
Daemon killed

答案 1 :(得分:4)

OS X

Cmd + Space - &gt;输入:活动监视器 - &gt;找到你的应用并终止它。

enter image description here