后台报 “Socket hangs up”就挂了,这是什么原因?
发布于 12 年前 作者 yunfei 41086 次浏览 最后一次编辑是 8 年前
14 回复

这个信息表示socket断了。

但不知道你说的挂了是什么意思,是你程序崩溃了还是怎样?

目测应该是某一socket连接异常,抛出了“Socket hangs up”,而又木有程序诸如 socket.on('error')try { } cacth (err) {}之类的措施来捕获并处理此错误,于是导致Node.js进程直接退出。

  • 1、“Socket hangs up”只是一个连接期间发生的错误,这种问题是随时可能会遇到的,监听“error”事件应该能捕获到,这样就不会抛出异常了

  • 2、你的程序应该能处理各种未知的错误,比如:

    • 使用try {} catch (err) {}来捕获某个范围内的错误

    • 使用内置的Domain模块来捕获某个范围内try ... catch无法捕获到的错误(某些异步操作,如setTimeout()回调里面抛出的异常在外面是无法捕获到的)(参考http://nodejs.org/api/domain.html )

    • 捕获全局全局异常uncaughtException并处理(参考http://nodejs.org/api/process.html#process_event_uncaughtexception )

    • 使用forever之类的工具来监控进程,以便进程意外退出时能自动重启 (参考https://npmjs.org/package/forever )

我用nodejs 0.8.20的时候,按住F5刷几次就出现这个错,换0.8.19没事,现在是0.8.21也没事。。

可能是页面发了请求之后, 接收请求之前跳转或者用户关闭浏览器了, 再搞任何操作都会出 hang up.

谢谢。。已经解决了!!哈哈。。。

@yunfei 怎么解决的

@panawang 我之前也遇到过类似的报错,话说 node 的报错真的很模糊。后来我 debug 到 socket 那一层,发现 socket 这个库有问题,然后再深究,是 stream 库的问题…然后我放弃了。

@alsotang 这两天也遇到这个问题了, 在osx上没事在ubuntu上就报错, 还没解决, 目前暂时绕过去了, 不过不解决总是放不下哈

@panawang 你那个问题是怎么印发的? 我上次遇到这个问题,是我在纽约的 vps,向七牛 put 数据时候出现的。我至今也不懂是超时导致的,还是 DNS 解析之类的导致的。 而且也忘记自己怎么绕过去的了。

连接数超了,看看req.agent

@leizongmin 对于Socket hangs up的异常,request.error(‘error’)和process.on(‘uncaughtException’),try{}catch(err){}都捕捉不到,直接导致系统重启,虽说有守护进程,但终究不是办法,你对于这种问题有何见解?

关注一下,这类问题很难搞

@jiangliqin 我一直认为uncaughtException是始终能捕捉到这些异常的,所以你所说的前提不成立

连mongodb的时候如果不设置keepalive就会socket hang up然后down 可以看看mongo client里面handle这个地方的源码

回到顶部