Mysql
 sql >> Database >  >> RDS >> Mysql

MaxListenersExceededWarning:è stata rilevata una possibile perdita di memoria di EventEmitter. Aggiunti 11 elenchi di messaggi. Utilizzare emitter.setMaxListeners() per aumentare il limite

Il limite predefinito per Emettitore di eventi è 10. Puoi aumentarlo con emitter.setMaxListeners. Il mio consiglio è di non cambiarlo a meno che e fino a quando non sia esplicitamente richiesto, gli ascoltatori vengono aumentati perché non hai cancellato l'iscrizione. Ora al tuo codice.

const redis = require('redis');
const config = require('../config');
const sub = redis.createClient(config.REDIS.port, config.REDIS.host);
const pub = redis.createClient(config.REDIS.port, config.REDIS.host);

sub.subscribe('spread');

module.exports = (io) => {
  io.on('connection', (socket) => {
    // this callback will be executed for all the socket connections.
    let passport =
      socket.handshake.session.passport; /* To find the User Login  */

    if (typeof passport !== 'undefined') {
      socket.on('typing:send', (data) => {
        pub.publish('spread', JSON.stringify(data));
      });

      // this is where you are subscribing for each and every socket connected to your server
      sub.on('message', (ch, msg) => {
        // this is the Exact line where I am getting this error

        // whereas you are emitting messages on socket manager, not on the socket.
        io.emit(`${JSON.parse(msg).commonID}:receive`, { ...JSON.parse(msg) });
      });
    }
  });
};

Ora se analizziamo il codice sopra, se apri 20 connessioni socket al tuo server si iscriverà 20 volte, qui sta andando storto. Ora se la tua esigenza è ascoltare il messaggio pubblicato su Redis a livello di server e quindi emetterlo su io allora il tuo codice dovrebbe essere come sotto

const redis = require('redis');
const config = require('../config');
const sub = redis.createClient(config.REDIS.port, config.REDIS.host);
const pub = redis.createClient(config.REDIS.port, config.REDIS.host);

sub.subscribe('spread');

module.exports = (io) => {
  sub.on('message', (ch, msg) => {
    // this is the Exact line where I am getting this error
    io.emit(`${JSON.parse(msg).commonID}:receive`, { ...JSON.parse(msg) });
  });

  io.on('connection', (socket) => {
    let passport =
      socket.handshake.session.passport; /* To find the User Login  */

    if (typeof passport !== 'undefined') {
      socket.on('typing:send', (data) => {
        pub.publish('spread', JSON.stringify(data));
      });
    }
  });
};