FIRESTORE (4.10.1) 内部断言失败:AsyncQueue 已经失败:请求的版本 (1) 小于现有版本 (2)
Posted
技术标签:
【中文标题】FIRESTORE (4.10.1) 内部断言失败:AsyncQueue 已经失败:请求的版本 (1) 小于现有版本 (2)【英文标题】:FIRESTORE (4.10.1) INTERNAL ASSERTION FAILED: AsyncQueue is already failed: The requested version (1) is less than the existing version (2) 【发布时间】:2018-10-03 16:23:38 【问题描述】:我很抱歉含糊不清,但我真的不知道该说什么,除了我收到这个错误!我不知道为什么,除了我认为它与兼容性版本有关。一切都在一台机器上运行。我将它克隆到另一个,现在出现此错误。
我正在使用 angularfire2 运行 Angular 5。
请告诉我哪些日志等会有所帮助。
谢谢, 韦恩
我也在使用 ngx-pwa-localStorage,所以它可能与以下内容有关: Chrome console error: The requested version (1) is less than the existing version (2)
下面是我的 package.json
"name": "scriptertainment",
"version": "0.4.0",
"license": "MIT",
"scripts":
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
,
"private": true,
"dependencies":
"@angular-devkit/core": "^0.4.6",
"@angular-devkit/schematics": "0.0.52",
"@angular/animations": "^5.0.0",
"@angular/common": "^5.0.0",
"@angular/compiler": "^5.0.0",
"@angular/core": "^5.2.10",
"@angular/forms": "^5.0.0",
"@angular/http": "^5.0.0",
"@angular/platform-browser": "^5.0.0",
"@angular/platform-browser-dynamic": "^5.0.0",
"@angular/router": "^5.0.0",
"@angular/service-worker": "^5.2.10",
"@ng-bootstrap/ng-bootstrap": "^1.1.0",
"@ngx-pwa/local-storage": "^5.2.0",
"angularfire2": "5.0.0-rc.6",
"bootstrap": "4.0.0-beta.2",
"core-js": "^2.4.1",
"firebase": "^4.12.0",
"ionicons": "^3.0.0",
"ngx-filter-pipe": "2.1.0",
"ngx-swiper-wrapper": "^5.3.8",
"open-iconic": "^1.1.1",
"pdfjs-dist": "^2.0.489",
"rxjs": "^5.5.2",
"swiper": "^4.2.0",
"zone.js": "^0.8.14"
,
"devDependencies":
"@angular/cli": "^1.7.2",
"@angular/compiler-cli": "^5.0.0",
"@angular/language-service": "^5.0.0",
"@types/jasmine": "~2.5.53",
"@types/jasminewd2": "~2.0.2",
"@types/node": "~6.0.60",
"codelyzer": "~3.2.0",
"jasmine-core": "~2.6.2",
"jasmine-spec-reporter": "~4.1.0",
"karma": "~1.7.0",
"karma-chrome-launcher": "~2.1.1",
"karma-cli": "~1.0.1",
"karma-coverage-istanbul-reporter": "^1.2.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.1.2",
"ts-node": "~3.2.0",
"tslint": "~5.7.0",
"typescript": "~2.4.2"
【问题讨论】:
【参考方案1】:感谢https://***.com/users/819775/igor 的帮助。
答案是手动删除 firestore IndexDB 条目。在 Chrome 中,进入开发控制台,转到应用程序选项卡。找到左侧的 IndexDB 并展开。对于列表中的每个 firebase db,选择 db 并使用“删除数据库”按钮。
这对我来说没问题,因为我的应用尚未投入生产,但我不得不想象对于实时站点,您需要在页面加载并刷新页面时实现 db delete 调用或放入放置一个处理数据库清理的临时站点重定向。
由于更新似乎占用了 FB DB,我不确定您将如何回收这些数据。希望您的应用将数据持久保存在其他地方,如果这很重要的话。
【讨论】:
这是否成为您的生产问题?我发现不启用离线持久性为我清除了错误,但你关于生产站点的观点让我担心。 我在 5.5.0 上遇到了同样的问题,这解决了它。 @wtk,这对我来说不是一个问题,因为我直到网站更新后才投入生产。【参考方案2】:在使用两个不同版本的 firebase 测试两个不同的应用程序时,我遇到了同样的问题。
我找到的最简单的解决方案就是清除浏览器历史记录。
【讨论】:
【参考方案3】:我删除了离线持久性,错误消失了。
如果您不确定它在哪里,请在代码库中搜索以下变体:
firebase.firestore().enablePersistence()
【讨论】:
我尝试了您的解决方案,它解决了我的问题,但这种方法的主要吸引力在于它增加了 Firestore 读数的数量!【参考方案4】:当启用离线持久性并且为特定域打开多个选项卡时会导致此错误。 本地主机也很重要 我发现错误具有误导性
【讨论】:
【参考方案5】:问题是浏览器缓存中的 firebase 缓存设置在某些 firebase 版本之间不兼容。最适合我的是使用隐身浏览器窗口而不是清除历史记录。
【讨论】:
以上是关于FIRESTORE (4.10.1) 内部断言失败:AsyncQueue 已经失败:请求的版本 (1) 小于现有版本 (2)的主要内容,如果未能解决你的问题,请参考以下文章
FIRESTORE (7.14.3) 内部断言失败:值必须未定义或 Uint8Array
Flutter 错误 - 断言失败:第 213 行 pos 15:'data != null':在从 firestore 获取数据时不正确
云功能失败并出现异常:内部,Flutter 应用程序中没有代码
构建失败并出现异常 - 任务“:cloud_firestore:parseDebugLocalResources”执行失败