警告:发生节点apn emitter.setMaxListeners()

时间:2017-05-11 05:32:54

标签: node.js eventemitter node-apn

我使用节点apn发送推送通知。

发生关于发送10,000个用户推送的emitter.setMaxListeners()问题。

但不会发生关于向1,000个用户发送推送的问题。

如何解决这个问题。

警告消息:

(node:17804) MaxListenersExceededWarning: Possible EventEmitter memory leak detected. 11 wakeup listeners added. Use emitter.setMaxListeners() to increase limit

const server = new Hapi.Server();
server.connection({port: 3000});
...
server.register([{
...
}], (err) => {
    if (err) {
        throw err;
    }

    server.start((err) => {
        if (err) {
            throw err;
        }
        console.log(`Server running at : ${server.info.uri}`);
    });
});

server.route({
    method: 'POST',
    path: '/push',
    handler: function(request, reply) {
        ...
        var notification = new apn.Notification() ;
        notification.badge = count ;
        notification.sound = "default" ;
        notification.alert = message ;
        notification.topic = toping ;
        ...
        //here tokens 10,000 counts
        apn_sender.send(notification, tokens).then((result) => {

            var res = {
                success : result.sent.length,
                failed : result.failed.length
            } ;

            return reply(res) ;

        }) ;
        ...
    }
});

2 个答案:

答案 0 :(得分:0)

尝试将setMaxListeners设为,

process.setMaxListeners(0);

当为特定事件添加了超过10个侦听器时,EventEmitters会打印警告(默认情况下)。这使我们能够帮助发现内存泄漏。但是,并非所有事件都应限于10名听众。 emitter.setMaxListeners()方法允许为此特定EventEmitter实例修改限制。可以将该值设置为Infinity(或0)以指示无限数量的侦听器。

希望这有帮助!

答案 1 :(得分:0)

您是否使用以下方法关闭了与APNs提供程序的连接

apnProvider.shutdown();

发送通知完成后。