3.2. Base Configuration

3.2.1. Base CouchDB Options


Higher values may result in better read performance due to fewer read operations and/or more OS page cache hits. However, they can also increase overall response time for writes when there are many attachment write requests in parallel.

attachment_stream_buffer_size = 4096

Specifies location of CouchDB database files (*.couch named). This location should be writable and readable for the user the CouchDB service runs as (couchdb by default).

database_dir = /var/lib/couchdb

When this config value as false the CouchDB provides guaranty of fsync call before return 201 Created response on each document saving. Setting this config value as true may raise some overall performance with cost of losing durability - it’s strongly not recommended to do such in production:

delayed_commits = false


Delayed commits are a feature of CouchDB that allows it to achieve better write performance for some workloads while sacrificing a small amount of durability. The setting causes CouchDB to wait up to a full second before committing new data after an update. If the server crashes before the header is written then any writes since the last commit are lost.


Changed in version 1.2: Added Google Snappy compression algorithm.

Method used to compress everything that is appended to database and view index files, except for attachments (see the attachments section). Available methods are:

  • none: no compression
  • snappy: use Google Snappy, a very fast compressor/decompressor
  • deflate_N: use zlib’s deflate; N is the compression level which ranges from 1 (fastest, lowest compression ratio) to 9 (slowest, highest compression ratio)
file_compression = snappy

Specifies when to make fsync calls. fsync makes sure that the contents of any file system buffers kept by the operating system are flushed to disk. There is generally no need to modify this parameter.

fsync_options = [before_header, after_header, on_file_open]

This option places an upper bound on the number of databases that can be open at once. CouchDB reference counts database accesses internally and will close idle databases as needed. Sometimes it is necessary to keep more than the default open at once, such as in deployments where many databases will be replicating continuously.

max_dbs_open = 100

Changed in version 2.0.1.

Even though this setting is named max_document_size, currently it is implemented by checking HTTP request body size. For single document requests the approximation is close enough, however, when multiple documents are updated in a single request the discrepancy between document sizes and request body size could be large. Setting this to a small value might prevent replicator from writing some documents to the target database or checkpointing progress. It can also prevent configuring database security options. Note: up until and including version 2.0 this setting was not applied to PUT requests with multipart/related content type, which is how attachments can be uploaded together with document bodies in the same request.

max_document_size = 4294967296 ; 4 GB

If an external process, such as a query server or external process, runs for this amount of milliseconds without returning any results, it will be terminated. Keeping this value smaller ensures you get expedient errors, but you may want to tweak it for your specific needs.

os_process_timeout = 5000 ; 5 sec

This file contains the full URI that can be used to access this instance of CouchDB. It is used to help discover the port CouchDB is running on (if it was set to 0 (e.g. automatically assigned any free one). This file should be writable and readable for the user that runs the CouchDB service (couchdb by default).

uri_file = /var/run/couchdb/couchdb.uri

Specifies the suffix (last component of a name) of the system database for storing CouchDB users.

users_db_suffix = _users


If you change the database name, do not forget to remove or clean up the old database, since it will no longer be protected by CouchDB.


Specifies location of binary drivers (icu, ejson, etc.). This location and its contents should be readable for the user that runs the CouchDB service.

util_driver_dir = /usr/lib/couchdb/erlang/lib/couch-1.5.0/priv/lib

New in version 1.3.

Unique identifier for this CouchDB server instance.

uuid = 0a959b9b8227188afc2ac26ccdf345a6

Specifies location of CouchDB view index files. This location should be writable and readable for the user that runs the CouchDB service (couchdb by default).

view_index_dir = /var/lib/couchdb

A CouchDB node may be put into two distinct maintenance modes by setting this configuration parameter.

  • true: The node will not respond to clustered requests from other nodes and the /_up endpoint will return a 404 response.
  • nolb: The /_up endpoint will return a 404 response.
  • false: The node responds normally, /_up returns a 200 response.

It is expected that the administrator has configured a load balancer in front of the CouchDB nodes in the cluster. This load balancer should use the /_up endpoint to determine whether or not to send HTTP requests to any particular node. For HAProxy, the following config is appropriate:

http-check disable-on-404
option httpchk GET /_up

Table Of Contents

Previous topic

3.1. Introduction Into Configuring

Next topic

3.3. couch_peruser

More Help