Я запускаю приложение Express.js, использующее Socket.io для веб-приложения чата, и примерно 5 раз в течение 24 часов случайным образом получаю следующую ошибку. Процесс узла закрывается навсегда и немедленно перезапускается.
Проблема в том, что перезапуск Express выгоняет моих пользователей из их комнат, а это никому не нужно.
Веб-сервер проксируется HAProxy. Нет проблем со стабильностью сокетов, просто используются транспорты веб-сокетов и флэш-сокетов. Я не могу воспроизвести это намеренно.
Это ошибка узла v0.10.11:
    events.js:72
            throw er; // Unhandled 'error' event
                  ^
    Error: read ECONNRESET     //alternatively it s a 'write'
        at errnoException (net.js:900:11)
        at TCP.onread (net.js:555:19)
    error: Forever detected script exited with code: 8
    error: Forever restarting script for 2 time
ИЗМЕНИТЬ (22 июля 2013 г.)
Добавлен обработчик ошибок клиента socket.io и обработчик неперехваченных исключений. Кажется, вот этот ловит ошибку:
    process.on('uncaughtException', function (err) {
      console.error(err.stack);
      console.log("Node NOT Exiting...");
    });
Поэтому я подозреваю, что это не проблема Socket.io, а HTTP-запрос к другому серверу, который я делаю, или соединение MySQL / Redis. Проблема в том, что стек ошибок не помогает мне определить проблему с кодом. Вот результат журнала:
    Error: read ECONNRESET
        at errnoException (net.js:900:11)
        at TCP.onread (net.js:555:19)
Как мне узнать, что вызывает это? Как мне получить больше от ошибки?
Хорошо, не очень многословно, но вот трассировка стека с Лонгджоном:
    Exception caught: Error ECONNRESET
    { [Error: read ECONNRESET]
      code: 'ECONNRESET',
      errno: 'ECONNRESET',
      syscall: 'read',
      __cached_trace__:
       [ { receiver: [Object],
           fun: [Function: errnoException],
           pos: 22930 },
         { receiver: [Object], fun: [Function: onread], pos: 14545 },
         {},
         { receiver: [Object],
           fun: [Function: fireErrorCallbacks],
           pos: 11672 },
         { receiver: [Object], fun: [Function], pos: 12329 },
         { receiver: [Object], fun: [Function: onread], pos: 14536 } ],
      __previous__:
       { [Error]
         id: 1061835,
         location: 'fireErrorCallbacks (net.js:439)',
         __location__: 'process.nextTick',
         __previous__: null,
         __trace_count__: 1,
         __cached_trace__: [ [Object], [Object], [Object] ] } }
Здесь я обслуживаю файл политики флеш-сокета:
    net = require("net")
    net.createServer( (socket) =>
      socket.write("<?xml version=\"1.0\"?>\n")
      socket.write("<!DOCTYPE cross-domain-policy SYSTEM \"https://www.macromedia.com/xml/dtds/cross-domain-policy.dtd\">\n")
      socket.write("<cross-domain-policy>\n")
      socket.write("<allow-access-from domain=\"*\" to-ports=\"*\"/>\n")
      socket.write("</cross-domain-policy>\n")
      socket.end()
    ).listen(843)
Может это быть причиной?
 
                                                                     
                                                                     
                                                                    