Я запускаю приложение 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)
Может это быть причиной?