onSnapshot出错:FirebaseError:[code = invalid-argument]:事务已关闭

Kar*_*pka 6 google-cloud-firestore

我递归加载存储在Firestore中的树.树有~79个节点.

偶尔我会收到此错误(大约十分之一的全树加载).

编辑:代码:https://github.com/karol-depka/OrYoL

编辑:部署的示例:https://oryol.karoldepka.com/tree(对不起,现在没有plunker,只是这个)

详情如下.

package.json中的Firebase版本: 4.5.0

问题:

我在哪里可以获得比此基本文档https://firebase.google.com/docs/reference/js/firebase.FirebaseError更多的信息 ?

问题的根源是什么以及如何解决?

3VM724:27 Uncaught Error in onSnapshot: Error: transaction closed
at new FirestoreError (error.js:164)
at JsonProtoSerializer.webpackJsonp.../../../../firebase/firestore/remote/serializer.js.JsonProtoSerializer.fromRpcStatus (serializer.js:126)
at JsonProtoSerializer.webpackJsonp.../../../../firebase/firestore/remote/serializer.js.JsonProtoSerializer.fromWatchChange (serializer.js:517)
at PersistentListenStream.webpackJsonp.../../../../firebase/firestore/remote/persistent_stream.js.PersistentListenStream.onMessage (persistent_stream.js:334)
at persistent_stream.js:270
at persistent_stream.js:247
at async_queue.js:81
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:392)
at Object.onInvoke (core.es5.js:3890)
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:391)
Run Code Online (Sandbox Code Playgroud)

代码:

private processNodeEvents(nestLevel: number, snapshot: any, parents, listener: DbTreeListener) {
  const serviceThis = this
  snapshot.docChanges.forEach(function(change) {
    let data = change.doc.data()
    if (change.type === 'added') {
      const parentsPath = serviceThis.nodesPath(parents)
      console.log('node: ', nestLevel, parentsPath, data);
      serviceThis.pendingListeners ++
      data.node.onSnapshot(targetNodeDoc => {
        serviceThis.pendingListeners --
        listener.onNodeAdded(
          new NodeAddEvent(parentsPath, parentsPath[parentsPath.length - 1], targetNodeDoc, targetNodeDoc.id,
            serviceThis.pendingListeners))
        console.log('target node:', nestLevel, targetNodeDoc)
        console.log('target node title:', nestLevel, targetNodeDoc.data().title)

        const subCollection = targetNodeDoc.ref.collection('subNodes')
        console.log('subColl:', subCollection)
        subCollection.onSnapshot((subSnap: QuerySnapshot) => {
          const newParents = parents.slice(0)
          newParents.push(targetNodeDoc.ref)
          serviceThis.processNodeEvents(nestLevel + 1, subSnap, newParents, listener)
        })
      })
      // console.log('root node ref: ', targetNode);
    }
    if (change.type === 'modified') {
      console.log('Modified city: ', data);
    }
    if (change.type === 'removed') {
      console.log('Removed city: ', data);
    }
  })
}
Run Code Online (Sandbox Code Playgroud)

编辑:通过多次运行代码发现另一个错误:

VM3343:27 Uncaught Error in onSnapshot: Error: The referenced transaction has expired or is no longer valid.
at new FirestoreError (error.js:164)
at JsonProtoSerializer.webpackJsonp.../../../../firebase/firestore/remote/serializer.js.JsonProtoSerializer.fromRpcStatus (serializer.js:126)
at JsonProtoSerializer.webpackJsonp.../../../../firebase/firestore/remote/serializer.js.JsonProtoSerializer.fromWatchChange (serializer.js:517)
at PersistentListenStream.webpackJsonp.../../../../firebase/firestore/remote/persistent_stream.js.PersistentListenStream.onMessage (persistent_stream.js:334)
at persistent_stream.js:270
at persistent_stream.js:247
at async_queue.js:81
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:392)
at Object.onInvoke (core.es5.js:3890)
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:391)
window.console.error @ VM3343:27
Run Code Online (Sandbox Code Playgroud)

编辑:更新firebase 4.6.0,问题发生3次:

Uncaught Error in onSnapshot: Error: transaction closed
  at new FirestoreError (error.js:149)
  at JsonProtoSerializer.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/serializer.js.JsonProtoSerializer.fromRpcStatus (serializer.js:93)
  at JsonProtoSerializer.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/serializer.js.JsonProtoSerializer.fromWatchChange (serializer.js:536)
  at PersistentListenStream.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/persistent_stream.js.PersistentListenStream.onMessage (persistent_stream.js:309)
  at persistent_stream.js:246
  at persistent_stream.js:222
  at async_queue.js:62
  at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:392)
  at Object.onInvoke (core.es5.js:3890)
  at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:391)
Run Code Online (Sandbox Code Playgroud)

编辑:即使错误发生,树似乎继续加载.

编辑:错误的另一个版本,code=aborted(升级firebase4.6.0):

Error in onSnapshot: FirebaseError: [code=aborted]: The referenced transaction has expired or is no longer valid.
/vendor.bundle.js:18588 errHandler()
/vendor.bundle.js:33367
/polyfills.bundle.js:2970 ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invokeTask()
/vendor.bundle.js:107276 Object.onInvokeTask()
/polyfills.bundle.js:2969 ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invokeTask()
/polyfills.bundle.js:2737 Zone.webpackJsonp.../../../../zone.js/dist/zone.js.Zone.runTask()
/polyfills.bundle.js:3044 webpackJsonp.../../../../zone.js/dist/zone.js.ZoneTask.invokeTask()
/polyfills.bundle.js:3033 ZoneTask.invoke()
Run Code Online (Sandbox Code Playgroud)

Pål*_*vik 1

我有或多或少相同的东西,它的工作和不工作是随机的。我不使用快照,而是使用 valueChanges

ERROR Error: transaction closed
at new FirestoreError (error.js:149)
at JsonProtoSerializer.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/serializer.js.JsonProtoSerializer.fromRpcStatus (serializer.js:93)
at JsonProtoSerializer.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/serializer.js.JsonProtoSerializer.fromWatchChange (serializer.js:536)
at PersistentListenStream.webpackJsonp.../../../../@firebase/firestore/dist/esm/src/remote/persistent_stream.js.PersistentListenStream.onMessage (persistent_stream.js:309)
at persistent_stream.js:246
at persistent_stream.js:222
at async_queue.js:62
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:392)
at Object.onInvoke (core.es5.js:3890)
at ZoneDelegate.webpackJsonp.../../../../zone.js/dist/zone.js.ZoneDelegate.invoke (zone.js:391)
Run Code Online (Sandbox Code Playgroud)

对我来说,正是这种和平的代码引发了错误:

return Observable.forkJoin(entries.map(entry => {
  return this.getPick(entry)
}))
Run Code Online (Sandbox Code Playgroud)

Entry 中的每个条目用于从 firestore 返回单个选择。

  private getPick(entryId: number) {
     return this.afs.collection<Pick>('entry/' + entryId + '/event/' + '9/' + 'picks', ref => ref.where('is_captain','==',true))
     .valueChanges()
Run Code Online (Sandbox Code Playgroud)

我并不是想劫持你的帖子,但我觉得这非常相关。如果我将 forkJoin 更改为

Observable.forkJoin(entries.slice(0,20)...
Run Code Online (Sandbox Code Playgroud)

然后它就起作用了,所以我猜这是某种查询过载。