Non-Root Install and Upgrade
Couchbase Server can be installed on any supported Linux distribution by users who do not have root or sudo privileges. A non-root server, once installed, can be upgraded by the same users.
Understanding Non-Root Install
Whereas the standard package-based installation of Couchbase Server requires root or sudo privileges on all supported Linux distributions, an alternative, non-root installation can be also performed on all such distributions: this does not require root or sudo privileges.
The procedures for non-root install, uninstall, stopping, and starting are:
Identical across all supported Linux distributions.
In each case, different from the equivalent procedure used for standard, package-based installation.
All non-root procedures are described below.
Before non-root install can be performed, the machine must be appropriately prepared. Note that preparations typically will require root or sudo privileges.
Transparent Huge Pages are enabled by default on most Linux systems; but are detrimental to the performance of Couchbase Server, and should therefore be disabled. To do this, follow the instructions provided in Disabling Huge Transparent Pages (THP).
Configure Kernel Swappiness
Optimal Couchbase-Server performance can be achieved by appropriately configuring kernel swappiness. To do this, follow the instructions provided in Swap Space and Kernel Swappiness.
Establish Limits for User Processes and File Descriptors
The maximum permitted number of concurrent user processes, and the maximum permitted number of currently open file descriptors, are both established on Linux systems with default values that are too low for running Couchbase Server with optimal performance and scale. The maximum number of user processes must therefore be reset to at least 10,000; and the maximum number of file descriptors to at least 70,000.
Note that Linux establishes such limits per user; and that since Couchbase Server will not, following non-root install, run as a service, but as a user process, the limits must be established separately for each user or group designated to run the non-root Couchbase Server.
Proceed as follows:
Check the current setting for user processes, as it applies to the current administrator:
The response indicates the maximum number of user processes currently permitted for the administrator, which this example assumes to be the default value, applied to all users.
In this case, the number,
3829, is evidently lower than the Couchbase-Server requirement of
Check the current setting for file descriptors as follows:
The response indicates the maximum number of file descriptors currently permitted for the administrator, which this example assumes to be the default value, applied to all users.
Again, in this case, the number,
1024, is lower than the Couchbase-Server requirement of
Raise the current limits on user processes and file descriptors, for the user or group designated to perform non-root install and then run Couchbase Server. To do this, access
/etc/security/limits.conf, and add
softlines for the
nofiletypes, specifying appropriate values. The
domainvalue, in the left-most column, should be the user-name of the user, or the group-name of the group, designated to install and run Couchbase Server.
Following these additions, the lines should appear as follows:
nameofuserorgroup soft nproc 10000 nameofuserorgroup hard nproc 10000 nameofuserorgroup soft nofile 70000 nameofuserorgroup hard nofile 70000
Save the file and exit.
Reboot the machine.
Following reboot, the designated user or group-member can check all the limits that currently apply to them, as follows:
This displays a list of limits for the designated user or group, among which appear the modified values for user processes and file descriptors:
core file size (blocks, -c) 0 data seg size (kbytes, -d) unlimited scheduling priority (-e) 0 file size (blocks, -f) unlimited pending signals (-i) 3829 max locked memory (kbytes, -l) 64 max memory size (kbytes, -m) unlimited open files (-n) 70000 pipe size (512 bytes, -p) 8 POSIX message queues (bytes, -q) 819200 real-time priority (-r) 0 stack size (kbytes, -s) 8192 cpu time (seconds, -t) unlimited max user processes (-u) 10000 virtual memory (kbytes, -v) unlimited file locks (-x) unlimited
This concludes the procedure for establishing and verifying new limits for user processes and file descriptors.
To perform a non-root installation of Couchbase Server on any supported Linux distribution, proceed as follows:
Download the Couchbase Server RPM, using
curl, download the https://packages.couchbase.com/cb-non-package-installer/cb-non-package-installer binary. Note that the URI is the same for all supported Linux distributions.
Make the binary executable.
chmod u+x ./cb-non-package-installer
Choose — and if necessary, create — an empty directory into which installation will occur. For example:
cb-non-package-installerbinary, to install Couchbase Server. For example:
./cb-non-package-installer --install --install-location ./cb-install \ --package ./couchbase-server-enterprise-6.6.0-7853-centos7.x86_64.rpm
Note that the program performs dependency checking, prior to installation. If installation cannot proceed, due to missing dependencies, the program displays corresponding notifications, and stops running.
If dependencies have been flagged as missing, restore those dependencies by performing the necessary installations. Then, run the
When installation is complete, the following notification is displayed:
Couchbase Server can now be started: see immediately below.
Start, Stop, and Get Status
To start, stop, or get status on a non-root Couchbase Server, use the
couchbase-server command, provided in the
opt/couchbase/bin directory that now resides under the specified install location.
For example, the command’s directory might be accessed as follows:
Note that a reference page for this command is provided at couchbase-server.
To start a non-root Couchbase Server, enter the following command:
This starts a non-root Couchbase Server. No output is displayed.
To get status on whether a non-root Couchbase Server is running, enter the following command.
If a non-root Couchbase Server is running, the following is displayed:
Couchbase Server is running
If a non-root-installed Couchbase Server is not running, the following is displayed:
Couchbase Server is not running
To stop a non-root Couchbase Server, enter the following command:
This stops a running, non-root Couchbase Server. The output might appear as follows:
2020-06-30 09:33:03 cb_dist: terminating with reason: shutdown
If no non-root Couchbase Server was running, no output is displayed.
To uninstall, stop the running non-root Couchbase Server, then remove the directory used as the install location, along with all its contents. For example:
./cb-install/opt/couchbase/bin/couchbase-server --stop rm -rf ./cb-install
To upgrade an existing non-root Couchbase Server,
Ensure that the previous version of Couchbase Server is still installed, and has been configured (since the upgrade process will make use of the post-configuration install location and directory contents).
Stop the server, if it is still running.
cb-non-package-installerbinary again, this time specifying the
--upgradeflag, instead of the
--installflag. Specify the new package to be used for upgrade; and specify the install location of the currently resident Couchbase Server. For example:
./cb-non-package-installer --upgrade --install-location ./cb-install \ --package ./couchbase-server-enterprise-6.6.0-7854-centos7.x86_64.rpm
During upgrade, the following message may appear:
Running cbupgrade this could take some time
When upgrade has completed, the following notification is displayed:
Upgrade has completed successfully
Note that important, additional information on upgrade is provided in Upgrading Couchbase Server.