API to get all the xattrs for a given document, along with its body
Description
Components
Affects versions
Fix versions
Labels
Environment
Release Notes Description
is caused by
relates to
Activity
Abhijeeth Nuthan January 15, 2025 at 12:24 AM
@Dave Finlay Yes we still have the code in place. Filed https://jira.issues.couchbase.com/browse/MB-64852 to track the improvement to move to new API.
Sumukh Bhat November 18, 2024 at 11:10 AM
Hi @Trond Norbye , wanted to double-check the GetEx’s behaviour for handling responses on the client side:
Sounds like for a tombstone, KEY_ENOENT with response.Cas = 0 is returned.
For a locked document, LOCKED response is returned (unlike getMeta where SUCCESS with response.Cas == MaxCas (UINT64_MAX))
Is that correct? Any special responses that the client needs to be aware of?
CB robot October 7, 2024 at 2:13 PM
Build couchbase-server-8.0.0-1882 contains kv_engine commit 092ac42 with commit message:
https://couchbasecloud.atlassian.net/browse/MB-63201#icft=MB-63201: Add GetEx and GetExReplica commands
Vinathi Kanna September 25, 2024 at 4:03 AM
Removing Morpheus fix version and adding Ponyo.
Details
Assignee
Reporter
Gerrit Reviews
:check_mark: MB-63201: Add GetEx and GetExReplica repo:kv_engine branch:master
Before https://couchbasecloud.atlassian.net/browse/MB-58989#icft=MB-58989, XDCR just fetched the target document metadata for source-side conflict resolution. But with https://couchbasecloud.atlassian.net/browse/MB-58989#icft=MB-58989, we need to "log" (store in a bucket), both the source document and the target document, involved in a conflict, along with their metadata.
For milestone-1/phase-1 of the project, this is how we do it:
1. Fetch the target document metadata using subdoc lookup on selected vxattrs and system xattrs. If the logging feature is turned on, get the XTOC vxattr in the same call.
2. Perform conflict resolution using the details fetched in (1).
3. If (2) doesn't detect a conflict, we are done.
4. If (2) detects a conflict: Parse the XTOC result obtained in (1), compose another subdoc lookup with all the xattr keys in XTOC and one compulsory spec for document body. This is done with subdoc lookup with command.CAS set to response.CAS returned by (1).
5. If we get KEY_EEXISTS or KEY_ENOENT, go to (1) and retry everything.
6. Otherwise, log the results and we are done.
As I understand there is a limit on number of lookup paths as 16. One path is always guaranteed to be document body. That leaves us with 15 xattr paths. With this context I have a couple of questions and hence creating this MB for tracking purposes:
1. Is the above described steps the most optimal way to get all the xattrs + document body right now? If yes, does it affect target KV performance by a lot in addition to XDCR performance hit due to XTOC parsing, retries etc.
2. Will there be a scope for new improvement wherein the document body and xattr section will be returned with a single API? Or a new vxattr for subdoc lookup, say $body whose response will be a combination of both document body and xattrs.