杂散最大侦听器超出警告事件运行连续火存储查询时发射器内存泄漏



我有一个Firebase HTTP函数,它反过来调用一些firestore操作。如果我多次调用 HTTP 函数,让每次调用都完成,然后再调用下一次调用,则会在 firebase 函数日志中收到以下错误:

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

Firebase 函数是一个导入任务,它获取要导入的数据,通过调用 firestore 查询来检查重复项,如果没有,则通过另一个数据库操作将数据添加到 firestore 数据库中。

以下是 Firebase 函数,为简洁起见,删除了部分:

module.exports = functions.https.onCall(async (obj, context) => {
// To isolate where the problem is
const wait = (ms: number) => new Promise(resolve => setTimeout(resolve, ms))
try {
const photo = getPhoto(obj)
// Query to look for duplicates
const query = db
.collection(`/Users/${context.auth.uid}/Photos`)
.where('date', '==', photo.date)
.where('order', '==', photo.order)
.limit(1)
await wait(300)
log.info('Before query')
const querySnap = await query.get()
log.info('After Query')
await wait(300)
// And then the rest of the code, removed for brevity
} catch (error) {
throw new functions.https.HttpsError('internal', error.message)
}
})

我在const querySnap = await query.get()之前和之后插入了一个暂停,以表明确实是这种调用导致了错误消息。

我还通过执行以下操作将 firestore 记录器设置为输出其内部日志记录以帮助调试问题:

import * as admin from 'firebase-admin'
admin.initializeApp()
admin.firestore.setLogFunction(log => {
console.log(log)
})

所以我得到的更完整的日志输出是这样的:(从下到上阅读(

12:50:10.087 pm: After Query
12:50:10.087 pm: Firestore (2.3.0) 2019-09-13T19:50:10.087Z RTQ7I [Firestore._initializeStream]: Received stream end
12:50:10.084 pm: Firestore (2.3.0) 2019-09-13T19:50:10.084Z RTQ7I [Firestore._initializeStream]: Releasing stream
12:50:10.084 pm: Firestore (2.3.0) 2019-09-13T19:50:10.084Z RTQ7I [Firestore.readStream]: Received response: {"document":null,"transaction":{"type":"Buffer","data":[]},"readTime":{"seconds":"1568404210","nanos":76771000},"skippedResults":0}
12:50:10.026 pm: (node:2) MaxListenersExceededWarning: Possible EventEmitter memory leak detected. 11 close listeners added. Use emitter.setMaxListeners() to increase limit
12:50:10.020 pm: Firestore (2.3.0) 2019-09-13T19:50:10.020Z RTQ7I [Firestore.readStream]: Sending request: {"parent":"[redacted]/documents/Users/SpQ3wTsFzofj6wcsF7efRrSMrtV2","structuredQuery":{"from":[{"collectionId":"Photos"}],"where":{"compositeFilter":{"op":"AND","filters":[{"fieldFilter":{"field":{"fieldPath":"date"},"op":"EQUAL","value":{"stringValue":"2019-06-26"}}},{"fieldFilter":{"field":{"fieldPath":"order"},"op":"EQUAL","value":{"integerValue":0}}}]}},"limit":{"value":1}}}
12:50:10.019 pm: Firestore (2.3.0) 2019-09-13T19:50:10.019Z RTQ7I [ClientPool.acquire]: Re-using existing client with 100 remaining operations
12:50:10.012 pm: Before query

有趣的是,我通常以 10 个为批次运行这些导入。我似乎只在第一批 10 个中收到错误。如果我然后快速运行更多批次,我似乎不会再次收到错误。但是如果我等待一段时间,它就会返回。此外,在批处理中的哪个调用中发生错误并不一致。它可能是第 9 个或第 2 个或调用,或任何其他调用。

最后,错误不会停止执行。事实上,进口似乎永远不会失败。但是,我不喜欢在我的日志中有无法解释的错误!我晚上和他们在一起睡不着觉。:-)

我很感激你能提供的任何帮助。

我从Firebase支持团队那里得到了有用的回应。他们告诉我尝试安装最新版本的 firebase-admin(将其从 8.5.0 升级到 8.6.0(,即使没有安装 grpc 的解决方法,也解决了这个问题。所以,我认为这应该是现在的正确答案。

看起来像这个错误 最大侦听器超出警告:检测到可能的事件发射器内存泄漏 #694 可能是这里的问题。

解决方法是使用npm install @grpc/grpc-js@0.5.2 --save-exact,直到错误得到修复并且 Firestore 库开始使用它。

最新更新