CouchDB is a non-relational document based database. Like other entrants into the "NoSQL" field, CouchDB attempts to provide a more flexible data storage system for use in custom application development. CouchDB is written in the Erlang programing language and uses an HTTP interface and JSON as a data format for easy integration in application development.
Before installing CouchDB, it is assumed that you have followed our getting started guide. If you're new to Linux server administration, you may be interested in our using Linux document series including the beginner's guide and administration basics guide.
The packages required to install CouchDB and its dependencies are not available in the standard CentOS repositories. As a result, "EPEL" must be installed in order to install CouchDB. EPEL, or "Extra Packages for Enterprise Linux", is a product of the Fedora Project that attempts to provide current versions of software packages that may not be available in the CentOS repositories. Enable EPEL with the following command:
rpm -Uvh http://download.fedora.redhat.com/pub/epel/5/i386/epel-release-5-4.noarch.rpm
Before proceeding with the installation of CouchDB, make sure your package repositories and installed programs are up to date by issuing the following command:
To install CouchDB and all of its dependencies, issue the following command:
yum install couchdb
The installation process will prompt you to accept the repository key for EPEL. After you confirm the key, the installation will complete. To start CouchDB, use the "init script" located at /etc/init.d/couchdb. Issue the following commands to start CouchDB:
If you need to restart or stop CouchDB, you can use the following commands:
/etc/init.d/couchdb restart /etc/init.d/couchdb stop
To ensure that CouchDB starts following the next system reboot, issue the following command:
chkconfig couchdb on
Congratulations! You have successfully installed CouchDB. In most cases, you will not need to modify CouchDB's configuration file; however, a number of options are set in the /etc/couchdb/local.ini file if you need to edit them in the future.
CouchDB comes with a web-based administrative interface called "Futon". Since CouchDB is only accessible over the local interface by default, you will want to create a secure ssh tunnel in order to access CouchDB or Futon from your local machine to avoid sending data in the clear.
Once the SSH tunnel is in place or you have configured your Linode, you can access the CouchDB HTTP interface by making a request for http://localhost:5984. If you would like to install a simple command line HTTP client, you may wish to use curl You can test your CouchDB instance by issuing the following command:
In response, CouchDB will return the following:
With the SSH tunnel active, you can access the Futon interface by visiting the URL "http://localhost:5984/_utils/" in a web browser on your local system.
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
This guide is licensed under a Creative Commons Attribution-NoDerivs 3.0 United States License.
Last edited by System on Friday, April 29th, 2011 (r1437).