javascript - 为什么 couchbase-sync-gateway 会返回“将 Rev 添加到 RevTree 失败”?
问题描述
我尝试了我在 Couchbase 上阅读的程序来解决冲突Resolving Conflicts, sync-gateway 1.5。
从 couchbase-sync-gateway 我得到 _bulk_docs 的结果,这个错误但我找不到任何反馈:
2019-09-13T12:10:36.932Z HTTP: #754: GET /bucket_01/id.00001?open_revs=all (as admin)
2019-09-13T12:10:37.079Z HTTP: #755: POST /bucket_01/_bulk_docs
2019-09-13T12:10:37.079Z HTTP: #755: --> 401 Login required (0.4 ms)
2019-09-13T12:10:37.203Z HTTP: #756: POST /bucket_01/_bulk_docs (as admin)
2019-09-13T12:10:37.210Z BulkDocs: Doc "id.00001" --> 500 Internal error: Failure adding Rev to RevTree (Failure adding Rev to RevTree)
错误是“将 Rev 添加到 RevTree 失败”,我明白发生了什么,但我无法修复它。
更新:15.09.2019
带有 CRUD 键日志的 bulk_docs 的响应:
2019-09-15T21:14:28.232Z HTTP: #006: POST /cfond_09/_bulk_docs (as admin)
2019-09-15T21:14:28.280Z CRUD: Stored doc "id.00001" / "6-baf5790d2d436f2e7af2715d59c1c3ce"
2019-09-15T21:14:28.284Z CRUD: Stored doc "id.00001" / "9-1c76fa9e825ca5eff39db0752a06eac2"
2019-09-15T21:14:28.286Z CRUD: Failed to add revision ID: 4-3ceed538cc59369128c25e3858183677, error: doc: id.00001, RevTree addRevision, already contains rev "4-3ceed538cc59369128c25e3858183677"
2019-09-15T21:14:28.286Z BulkDocs: Doc "id.00001" --> 500 Internal error: Failure adding Rev to RevTree (Failure adding Rev to RevTree)
2019-09-15T21:14:28.290Z CRUD: Stored doc "id.00001" / "5-ea9b3e32746fcb844d2004bc38061d40"
只有一个修订版不太顺利,我想我对同一个文档的 Bodymap 有三个修订版,其中一个修订版的主体如下:
[...]
8: "{\"_deleted\":true}",
[...]
文件状态:
[...]
"history": {
"revs": [
"4-422342a11e82d6368a08c62e83ecf2b0",
"8-fb0b278568a4bf668f814e0072df2da9",
"2-92501b3c9bbbeca8b470f6d12d9f68c2",
"4-ab334e71ddd5b5537f77af109aed9af2",
"5-63f080d6c319ed3f7f4b3bd5e5e2dd0c",
"1-9d6dfa10417c47474cb8313c047fc3f0",
"3-4245004b12e10b31a1bcbe38505eb5b6",
"7-8e2994be714407787701584156ec150f",
"5-d29926e6904e77678c7970c1bfa7e6ea",
"4-3ceed538cc59369128c25e3858183677",
"6-a7117b51d59a9fd179f369ad965be08e"
],
"parents": [
-1,
7,
5,
-1,
3,
-1,
2,
10,
0,
-1,
4
],
"deleted": [
0,
8,
9
],
"bodymap": {
"6": "{ ... all body ... }",
"8": "{\"_deleted\":true}",
"9": "{ ... all body ... }"
}, [...]
RevTree 中存在有问题的修订。我不明白问题出在哪里。
更新 16.09.2019
我想我了解 Couchbase 和 Sync-Gateway 中发生的情况:一个文档分叉为两个文档,一个 3-XYZ 和 4-QWE。这两个文档是相同的,但与修订 ID 不同。当我调用 bulk_docs 时,4-QWE 变为 5-IOP,3-XYZ 变为 4-QWE。但是 4-QWE 已经出现在 RevTree 中,错误 500。这是我的想法,有人同意吗?
更新 20.09.2019
错误消失了。我在文档中添加了一个新字段,我保存在批量文档中。bulk_docs 可以正常工作,但冲突仍然是 Bodymap。你知道有什么解决办法吗?
解决方案
有 3 种可能的情况可能会出现此错误:
- RevTree addRevision,空的revid是非法的
- RevTree addRevision,已经包含 rev "..."
- RevTree addRevision,父 id "..." 丢失
如果启用 CRUD 日志键,则应记录您遇到的特定错误:https ://docs.couchbase.com/sync-gateway/1.5/config-properties.html#logging-default-logKeys
这应该给你一个关于出了什么问题的提示。
推荐阅读
- python - Python如何通过知道列表中列表的第一个元素来获取列表中列表的索引?
- android - 禁用扩展时自动滚动 AppBarLayout
- r - 为什么这个 R 版本的骑士之旅不起作用?
- sublimetext3 - 如何在 Autoprefixer 的 caniuse 列表上运行更新
- php - Composer 如何从版本 1 更新到版本 2
- python - 如何访问传递给 Python 线程的函数 args?
- discord - Discord Python Rewreite - 频道搜索器
- r - 在ggplot中注释方程
- javascript - React Native Loader 在每个组件或根目录中?
- python - 我无法安装 discord.py