node . js插座.io脚本在1-2天后被SIGSEGV杀死

node.js socket.io script getting killed by SIGSEGV after 1-2 days

本文关键字:天后 SIGSEGV 杀死 js 插座 io 脚本 node      更新时间:2023-09-26

我永远运行我的node.js服务器,我的脚本在1-2天内被杀死,我在日志文件中得到这个错误:

error: Forever detected script was killed by signal: SIGSEGV

现在我有很多函数在我的node.js脚本。在每个函数的开头编写console.log时,我最终在日志中得到以下内容:

info: transport end (undefined)
debug: set close timeout for client CbU1mvlYaIvDWHB4ChQa
debug: cleared close timeout for client CbU1mvlYaIvDWHB4ChQa
disconnection function
debug: discarding transport
debug: clearing poll timeout
debug: client authorized
info: handshake authorized 2O3m1B3dGWFOJ4W9ChQc
error: Forever detected script was killed by signal: SIGSEGV

日志使它看起来好像连接或断开连接功能有问题,但作为脚本seg故障后2天的运行和超过10000连接/断开我认为这可能不是真正的问题。

这是我的连接和断开功能。我还通过node-dbi连接到我的PGSQL数据库:

var DBWrapper = require('node-dbi').DBWrapper; 
var DBExpr = require('node-dbi').DBExpr; 
var dbConnectionConfig = { host: 'localhost', user: 'user', password:   'pass', database: 'dbname' };
dbWrapper = new DBWrapper( "pg", dbConnectionConfig );
dbWrapper.connect();
io.sockets.on('connection', function(socket) {

  console.log("socket connection");
socket.on('set username', function(userName) {
var milliseconds = (new Date).getTime();
var data = { socketid: socket.id, time: milliseconds };
dbWrapper.insert('all_sockets', data , function(err) {
});
});
socket.on('disconnect', function() {
  console.log("disconnection function");
  dbWrapper.remove('all_sockets', [['socketid=?', socket.id]] , function(err) {} );
 });
});

段故障可能来自哪里?

我建议使用段错误处理程序来确定STDERR。这样,您将获得更多有用的调试信息。

你可以在这里找到