Redis is an open-source in-memory data structure store. It can be  used as a database, cache and message broker and supports various data  structures such as Strings, Hashes, Lists, Sets etc. Redis provides high  availability via Redis Sentinel including monitoring, notifications  Automatic failover. It also provides automatic partitioning across  multiple Redis nodes with Redis Cluster.

This tutorial describes  how to install and configure Redis on an Ubuntu 18.04 server. The same  instructions apply for Ubuntu 16.04 and any Ubuntu-based distribution.


Before starting with the tutorial, make sure you are logged in as a user with sudo privileges.

Installing Redis on Ubuntu

Redis  package is included in the default Ubuntu 18.04 repositories. The  installation is pretty straightforward, just follow the steps below:

Start by updating the apt packages list by running the following command in your SSH terminal:

sudo apt update

Install Redis by typing:

sudo apt install redis-server

Once  the installation is completed, the Redis service will start  automatically. To check the status of the service, enter the following  command:

sudo systemctl status redis-server

You should see something like this:

● redis-server.service - Advanced key-value store
   Loaded: loaded (/lib/systemd/system/redis-server.service; enabled; vendor preset: enabled)
   Active: active (running) since Sun 2018-10-28 05:10:45 PDT; 2h ago
  Process: 2197 ExecStop=/bin/kill -s TERM $MAINPID (code=exited, status=0/SUCCESS)
  Process: 2201 ExecStart=/usr/bin/redis-server /etc/redis/redis.conf (code=exited, status=0/SUCCESS)
 Main PID: 2226 (redis-server)
    Tasks: 4 (limit: 2319)
   CGroup: /system.slice/redis-server.service
           `-2226 /usr/bin/redis-server

Redis service will fail to start if IPv6 is disabled on your server.

Congratulations, at this point you have Redis installed and running on your Ubuntu 18.04 server.

Configure Redis Remote Access

By  default, Redis doesn’t allow remote connections. You can connect to the  Redis server only from (localhost) - the machine where Redis  is running.

Perform  the following steps only if you want to connect to your Redis server  from remote hosts. If you are using a single server setup, where the  application and Redis are running on the same machine then you should  not enable remote access.

To configure Redis to accept remote connections open the Redis configuration file with your text editor:

sudo nano /etc/redis/redis.conf

Locate the line that begins with bind ::1 and replace with


# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
bind ::1


Save the file and close the editor.

Restart the Redis service for changes to take effect:

sudo systemctl restart redis-server

Use the following command to verify that redis is listening on all interfaces on port 6379:

ss -an | grep 6379

You should see something like below. means all IPv4 addresses on the machine.

tcp  LISTEN 0   128*
tcp  LISTEN 0   128      [::]:6379      [::]:*  

Next, you’ll need to add a firewall rule that enables traffic from your remote machines on TCP port 6379.

Assuming you are using UFW to manage your firewall and you want to allow access from the subnet you would run the following command:

sudo ufw allow proto tcp from to any port 6379

At this point, Redis server will accept remote connections on TCP port 6379.

Make sure your firewall is configured to accept connections only from trusted IP ranges.

To verify that everything is set up properly, you can try to ping the Redis server from your remote machine using the redis-cli utility:

redis-cli -h <REDIS_IP_ADDRESS> ping

The command should return a response of PONG:



Congratulations, you  have successfully installed Redis on your Ubuntu 18.04 server. To find  more information about how to manage your Redis installation visit the Redis documentation page.

If you hit a problem or have feedback, leave a comment below.