Как мне перехватить сообщения об ошибках на node.js / express, например, EADDRINUSE? - PullRequest
28 голосов
/ 03 марта 2012

Это мой код (это coffeescript и использует цвета, но это не имеет значения)

# If this module is executed
if !module.parent
    # Start server
    try
        hons_server.listen config.port
        console.log 'Listening to port ' + config.port
    catch err
        console.error "Couldn't start server: #{String(err)}".red

hons_server - сервер express.js . Мне трудно понять, почему ошибки, выданные в результате hons_server.listen(), не улавливаются при попытке / отлове. Когда я запускаю свой сервер дважды, я получаю вывод:

$ 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.

Ответы [ 2 ]

24 голосов
/ 13 мая 2013

Принятое решение не работало для меня на 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);
});     

Также см. Node.jsОшибки запуска приложения Express Express

21 голосов
/ 03 марта 2012

Прослушивание события error на сервере isntance

hons_server.on 'error', (err) ->
    console.log 'there was an error:', err.message
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...