This guide covers the aspects of accessing documents in Vespa. Documents are stored in content clusters. Writes (PUT, UPDATE, DELETE) and reads (GET) pass through a container cluster. Find a more detailed flow at the end of this article.
Highlights:
Also see troubleshooting.
Operation | Description | ||||||||
---|---|---|---|---|---|---|---|---|---|
Get | Get a document by ID. |
||||||||
Put | Write a document by ID - a document is overwritten if a document with the same document ID exists. Puts can have conditions for test-and-set use cases. Conditions can be combined with create if nonexistent, which causes the condition to be ignored if the document does not already exist.
|
||||||||
Remove |
Remove a document by ID. If the document to be removed is not found, it is not considered a failure. Read more about data-retention. Also see batch deletes. Removes can have conditions for test-and-set use cases. A removed document is written as a tombstone, and later garbage collected - see removed-db / prune / age. Vespa does not retain, nor return, the document data of removed documents. |
||||||||
Update | Also referred to as partial updates, as it updates one or more fields of a document by ID - the document v1 API can be used to perform updates in the JSON Document format. If the document to update is not found, it is not considered a failure. Updates support create if nonexistent (upsert). Updates can have conditions for test-and-set use cases. All data structures (attribute, index and summary) are updatable. Note that only assign and remove are idempotent - message re-sending can apply updates more than once. Use conditional writes for stronger consistency.
|
Also see the JSON Document format:
API / util | Description |
---|---|
Vespa CLI |
Command-line tool to
get , put , remove , update , feed , visit .
|
/document/v1/ | API for get , put , remove , update , visit . |
Java Document API | Provides direct read-and write access to Vespa documents using Vespa's internal communication layer. Use this when accessing documents from Java components in Vespa such as searchers and document processors. See the Document class. |
Advanced / debugging tools:
Use the Vespa CLI, vespa-feed-client or /document/v1/ API to read and write documents:
Alternatively, use vespa-feeder to feed files or the Java Document API.
Indexing and/or document processing is a chain of processors that manipulate documents before they are stored. Document processors can be user defined. When using indexed search, the final step in the chain prepares documents for indexing.
The Document API forwards requests to distributors on content nodes. For more information, read about content nodes and the search core.