Install Redis on Linux, macOS, and Windows
This is a an installation guide. You'll learn how to install, run, and experiment with the Redis server process.
While you can install Redis on any of the platforms listed below, you might also consider using Redis Cloud by creating a free account.
How you install Redis depends on your operating system and whether you'd like to install it bundled with Redis Stack and Redis UI. See the guide below that best fits your needs:
- Install Redis from Source
- Install Redis on Linux
- Install Redis on macOS
- Install Redis on Windows
- Install Redis with Redis Stack and RedisInsight
Test if you can connect using the CLI
Once you have Redis up and running, you can connect using
External programs talk to Redis using a TCP socket and a Redis specific protocol. This protocol is implemented in the Redis client libraries for the different programming languages. However to make hacking with Redis simpler Redis provides a command line utility that can be used to send commands to Redis. This program is called redis-cli.
The first thing to do in order to check if Redis is working properly is sending a PING command using redis-cli:
$ redis-cli ping PONG
Running redis-cli followed by a command name and its arguments will send this command to the Redis instance running on localhost at port 6379. You can change the host and port used by
redis-cli - just try the
--help option to check the usage information.
Another interesting way to run
redis-cli is without arguments: the program will start in interactive mode. You can type different commands and see their replies.
$ redis-cli redis 127.0.0.1:6379> ping PONG
By default Redis binds to all the interfaces and has no authentication at all. If you use Redis in a very controlled environment, separated from the external internet and in general from attackers, that's fine. However if an unhardened Redis is exposed to the internet, it is a big security concern. If you are not 100% sure your environment is secured properly, please check the following steps in order to make Redis more secure:
- Make sure the port Redis uses to listen for connections (by default 6379 and additionally 16379 if you run Redis in cluster mode, plus 26379 for Sentinel) is firewalled, so that it is not possible to contact Redis from the outside world.
- Use a configuration file where the
binddirective is set in order to guarantee that Redis listens on only the network interfaces you are using. For example only the loopback interface (127.0.0.1) if you are accessing Redis just locally from the same computer, and so forth.
- Use the
requirepassoption in order to add an additional layer of security so that clients will require to authenticate using the
- Use spiped or another SSL tunneling software in order to encrypt traffic between Redis servers and Redis clients if your environment requires encryption.
Note that a Redis instance exposed to the internet without any security is very simple to exploit, so make sure you understand the above and apply at least a firewall layer. After the firewall is in place, try to connect with
redis-cli from an external host in order to prove yourself the instance is actually not reachable.
Use Redis from your application
Of course using Redis just from the command line interface is not enough as the goal is to use it from your application. In order to do so you need to download and install a Redis client library for your programming language.
You'll find a full list of clients for different languages in this page.
You can learn how Redis persistence works on this page, however what is important to understand for a quick start is that by default, if you start Redis with the default configuration, Redis will spontaneously save the dataset only from time to time (for instance after at least five minutes if you have at least 100 changes in your data), so if you want your database to persist and be reloaded after a restart make sure to call the SAVE command manually every time you want to force a data set snapshot. Otherwise make sure to shutdown the database using the SHUTDOWN command:
$ redis-cli shutdown
This way Redis will make sure to save the data on disk before quitting. Reading the persistence page is strongly suggested in order to better understand how Redis persistence works.
Install Redis more properly
Running Redis from the command line is fine just to hack a bit or for development. However, at some point you'll have some actual application to run on a real server. For this kind of usage you have two different choices:
- Run Redis using screen.
- Install Redis in your Linux box in a proper way using an init script, so that after a restart everything will start again properly.
A proper install using an init script is strongly recommended.
The available packages for supported Linux distributions already include the capability of starting the Redis server from
The remainder of this section assumes you've installed Redis from its source code. If instead you have installed Redis Stack, you will need to download a basic init script and then modify both it and the following instructions to conform to the way Redis Stack was installed on your platform. For example, on Ubuntu 20.04 LTS, Redis Stack is installed in
/usr/local, so you'll need to adjust accordingly.
The following instructions can be used to perform a proper installation using the init script shipped with the Redis source code,
If you have not yet run
make install after building the Redis source, you will need to do so before continuing. By default,
make install will copy the
redis-cli binaries to
Create a directory in which to store your Redis config files and your data:
sudo mkdir /etc/redis sudo mkdir /var/redis
Copy the init script that you'll find in the Redis distribution under the utils directory into
/etc/init.d. We suggest calling it with the name of the port where you are running this instance of Redis. Make sure the resulting file has
sudo cp utils/redis_init_script /etc/init.d/redis_6379
Edit the init script.
sudo vi /etc/init.d/redis_6379
Make sure to set the REDISPORT variable to the port you are using. Both the pid file path and the configuration file name depend on the port number.
Copy the template configuration file you'll find in the root directory of the Redis distribution into
/etc/redis/using the port number as the name, for instance:
sudo cp redis.conf /etc/redis/6379.conf
Create a directory inside
/var/redisthat will work as both data and working directory for this Redis instance:
sudo mkdir /var/redis/6379
Edit the configuration file, making sure to perform the following changes:
- Set daemonize to yes (by default it is set to no).
- Set the pidfile to
/var/run/redis_6379.pid, modifying the port as necessary.
- Change the port accordingly. In our example it is not needed as the default port is already
- Set your preferred loglevel.
- Set the logfile to
- Set the dir to
/var/redis/6379(very important step!)
Finally, add the new Redis init script to all the default runlevels using the following command:
sudo update-rc.d redis_6379 defaults
You are done! Now you can try running your instance with:
sudo /etc/init.d/redis_6379 start
Make sure that everything is working as expected:
- Try pinging your instance within a
redis-clisession using the
- Do a test save with
redis-cli saveand check that a dump file is correctly saved to
- Check that your Redis instance is logging to the
- If it's a new machine where you can try it without problems, make sure that after a reboot everything is still working.
The above instructions don't include all of the Redis configuration parameters that you could change. For example, to use AOF persistence instead of RDB persistence, or to set up replication, and so forth.