Hub*_*bro 29 error-handling node.js coffeescript express
这是我的代码(它是coffeescript并使用颜色,但这不相关)
if !module.parent
try
hons_server.listen config.port
console.log 'Listening to port ' + config.port
catch err
console.error "Couldn't start server: #{String(err)}".red
Run Code Online (Sandbox Code Playgroud)
hons_server是一个express.js服务器.我很难理解为什么抛出的错误hons_server.listen()不会被try/catch捕获.当我运行我的服务器两次时,我得到输出:
$ coffee src/server.coffee
Listening to port 9090
node.js:201
throw e; // process.nextTick error, or 'error' event on first tick
^
Error: listen EADDRINUSE
at errnoException (net.js:632:11)
at Array.0 (net.js:733:26)
at EventEmitter._tickCallback (node.js:192:40)
我想知道为什么没有捕获抛出的错误,以及我如何/在哪里可以捕获EADDRINUSE错误.
mis*_*cko 25
在nodejs 0.8.22和express 3.1.0上,我接受的解决方案对我不起作用.
这样就可以了:
process.on('uncaughtException', function(err) {
if(err.errno === 'EADDRINUSE')
console.log(...);
else
console.log(err);
process.exit(1);
});
Run Code Online (Sandbox Code Playgroud)
fen*_*ent 21
error在服务器上监听事件
hons_server.on 'error', (err) ->
console.log 'there was an error:', err.message
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15179 次 |
| 最近记录: |