I'm just started with CouchDB and noticed that it keeps multiple versions of data in the database. Does it mean that each version is a full copy of the fields currently added? So does it keep redundant data on the disk or the versions are just incremental versions?
Does multiple versions of couchDB keeps redundant data?
268 Views Asked by Alex At
1
There are 1 best solutions below
Related Questions in COUCHDB
- Sort continents by amount of countries
- SImple reduce function is not working, what is wrong with my reduce function code in couchDB?
- Do 'reduce' with results from Cloudant search?
- DB candidate as CouchDB/Schema replacement
- CouchDB sum by date range and type
- Couchdb View does not re-index
- Retrieve data without _id and _ref from coucgdb
- How do I get rid of unused views on CouchDB using futon?
- Using node-couchdb to query a database
- Import data from CouchDB to Sql Server
- Architecture of an app when using CouchDB/PouchDB
- How to create and maintain couchDB/pcouchDB doc _id's
- How do I query X specific documents all at once using an index with pouchdb?
- Installing CouchDB on IaaS?
- Download file, retrieved from port on the local server
Related Questions in COUCHDB-FUTON
- SImple reduce function is not working, what is wrong with my reduce function code in couchDB?
- How do I get rid of unused views on CouchDB using futon?
- CouchDB-Why my rerduce is always coming as false ? I am not able to reduce anything properly
- Fetch field of another Doc in CouchDB?
- CouchDB Fauxton - How to navigate through revisions history?
- access denied when accessing couchdb from laptop over ethernet cable
- Does multiple versions of couchDB keeps redundant data?
- Fauxton errors in requre file
- Creating filtered indexes on couchdb
- Do replication on a different drive
- Tool for managing CouchDB
- how to manage list functions using futon?
- Identifying Duplicates in CouchDB
- CouchDB Views and Design Documents
- CouchDB "[Circular]" when writing to an array
Related Questions in NOSQL
- Developing a search and tag heavy website
- PostgreSQL 9.4 - Elements of jsonb array to ts_vector in
- ArangoDb get latest document from all collections
- Modeling with MongoDB and Mongoose
- Any high-level .NET clients for PostgreSQL's JSON type?
- Filtered Query in Elastic Search
- Nosql database design for complex querying
- JDBC or JPA for NoSQL
- How to connect Clusterpoint database to an android appliaction
- How to write query to my Cloudant database?
- How do I query X specific documents all at once using an index with pouchdb?
- Project a _id ref field as document
- MongoDB from PHP strange behavior
- MongoDB slow log (profiler) shows many many "killcursors" action when heavy load comes, why? and what killcursors do?
- Optimize duplicate values in NoSql key-value storage
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
CouchDB holds multiple complete revisions of documents, it does not store incremental changes. The internals of CouchDB use an append-only data structure, so each new revision is added to the database file.
In addition, CouchDB uses MVCC (multi-version concurrency control) which prevents the need for locks while allowing concurrent writers. (you can read more about this feature in their documentation) This is relevant because the revision numbers are an important part of that mechanism, and keeping some previous revisions aid in that process. (particularly for conflict resolution in a replicated setup)
In short, you will have duplicates in your database each time you modify a document. Thus, modifying the same document many times can lead to an inflated database file. In addition, very large documents with fewer modifications also have this same effect. For each document, only the latest version is considered "active" by the database, but old revisions may still be around. (more on that next)
This might sound inefficent and wasteful, but CouchDB has you covered with a feature called compaction. This process removes all revisions (except for the most recent) from the database file altogether. Prior to CouchDB 2.0, this was generally invoked manually by an admin, but now it is much more automated.
One common misconception about CouchDB is that the multiple versions can be used like a version-control system (eg: git, svn), so you can always keep some sort of historical record of your database. However, this is completely false, as MVCC is purely for concurrency control. As stated before, compaction removes the old revisions, so you should only depend on the most recent revision existing in your database at any time.
I would strongly recommend reading through all of CouchDB's official documentation. It is not especially lengthy, and quite excellent at describing the internals and the trade-offs you have available to you when deciding how to build your applications.