node.js - Node GeoFire 内存泄漏?

标签 node.js firebase memory-leaks geofire firebase-queue

我在 Node 上运行了一些非常基本的 firebase + firebase-queue + GeoFire 代码,这似乎导致了内存泄漏,但我不相信我没有在某个地方搞砸了。

'use strict';

if (!process.env.FIREBASE_PROJECT_ID) {
  require('dotenv').config({ silent: true });
}

let fbConfig = require('./firebase-config');
let fbNodes = fbConfig.NODES;
let Queue = require('firebase-queue');
let admin = require("firebase-admin");
let GeoFire = require('geofire');

admin.initializeApp({
  credential: admin.credential.cert(fbConfig.FIREBASE_SERVICE_ACCOUNT),
  databaseURL: fbConfig.APP_SETTINGS.databaseURL
});

let db = admin.database();
let queueRef = db.ref(fbNodes.QUEUE);
let geoFire = new GeoFire(db.ref(fbNodes.GEOFIRE));

var q = new Queue(queueRef, function (data, progress, resolve, reject) {
  let geoQuery = geoFire.query({
    center: data.queryCenter,
    radius: data.maxDistanceKm
  });

  // fires for every key returned by the geoQuery
  let listener = geoQuery.on('key_entered', function (key, loc, dist) {
    // do nothing
  });

  // This will fire once the initial data is loaded, so now we can cancel 
  // the "key_entered" event listener
  geoQuery.on('ready', function () {
    listener.cancel();
    resolve();
  });
});

下面是内存使用情况的内存消耗图表,显示此代码在大约 10 分钟后消耗了 1.5 GB 内存,并解决了 1100 个任务,直到崩溃。

memory consumption charted by memory-usage

知道这里发生了什么吗?

它运行于:

  • Node 6.7.0
  • firebase-admin 4.0.4
  • firebase 队列 1.6.1
  • geofire 4.1.1

最佳答案

泄漏是由 GeoFire 查询引起的。每次处理队列中的任务时,都会创建一个查询,但这些查询永远不会被取消 - 只有它们的监听器会被取消。

要堵住漏洞,请在完成后对查询调用cancel。例如:

geoQuery.on('ready', function () {
  listener.cancel();
  geoQuery.cancel();
  resolve();
});

关于node.js - Node GeoFire 内存泄漏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41630007/

相关文章:

php - node.js 和 reactjs 作为 php 模板渲染服务是个好主意吗?

javascript - 使用 SystemJS 加载捆绑的 AMD 模块

java - 如何检查用户是否已通过 gmail 或 google 帐户登录?

Firebase 计数分组依据

angularjs - 如何捕获 Angular 应用程序中的内存泄漏?

c++ - valgrind 检测到内存泄漏,但找不到我忘记释放的行

javascript - 带有 Puppeteer 的 waitForSelector 仅在 headless 模式下不响应

javascript - Node.js For 循环和 Readline 函数调用?

swift - Firebase 查询

android - 修复由 Leak Canary 发现的 Activity 内存泄漏