(节点)警告:检测到可能的事件发射器内存泄漏.添加了 11 个错误侦听器.使用 emitter.setMaxListen



我正在使用pg节点模块来连接数据库。我一直在为每个 DML 操作创建多个连接。发生连续查询执行时我收到警告消息为"(节点)警告:检测到可能的事件发射器内存泄漏。添加了 11 个错误侦听器。使用 emitter.setMaxListeners() 来增加限制。给定的 pg 默认值 poolSize 为 5。

 var pg = require('pg')
 pg.defaults.poolSize = 5;
 var dbHelper = {
 initializeConnection: function (callback) {
    pg.connect(conString, function (err, client, done) {
        if (err) {
            done(client);
            return callback(err, null);
        }
        callback(null, client, done);
    });
    pg.on('error', function (err) {
    });
    pg.end();
},
  query: function (pgQuery, args, callback, options) {
    this.initializeConnection(function (err, client, done) {
           client.query(pgQuery, args, function (err, response) {
            done();
            return callback(err, response);
        });
    });
},
};
 module.exports = dbHelper;

示例查询

 dbHelper.query("SELECT name,age,address FROM EMPLOYEE WHERE id=$1", [1001], function (err, response) {
        callback(err, response);
    });

如何防止事件发射器内存韭菜。

原因是您没有正确释放连接:

pg.connect(conString, function (err, client, done) {
      if (err) {
          done(client);
          return callback(err, null);
      }
      callback(null, client, done);
  });

这应该是:

pg.connect(conString, function (err, client, done) {
    if (err) {
        callback(err, null);
    } else {
        callback(null, client);
        done();
    }
});

即您在没有错误时调用done()

如果你想完全避免这种错误 - 查看pg-promise;)

最新更新