Nick Fisher's tech blog

Set up a Basic Leader/Follower Redis Cluster Locally using Docker

In general, you will want to keep your development environment and your higher environments as similar as makes sense [times it doesn’t make sense: when it costs too much], to catch bugs early and often. Here, we’ll quickly run through how to set up a leader/follower topology for redis using docker/docker-compose on your local machine.

The redis documentation on replication is a very good read to get more familiar with the details, but you basically just need to pass a flag/config value to the follower to tell it to start replicating. This will also, by default, make the replica reject all write requests [you want this–trust me]. Here’s a docker-compose file that does just that:

version: '3.8'

services:
  leader:
    image: redis
    ports:
      - "6379:6379"
      - 6379
    networks:
      - local
  follower:
    image: redis
    ports:
      - "6380:6379"
      - 6379
    networks:
      - local
    command: ["--replicaof", "leader", "6379"]

networks:
  local:
    driver: bridge

You can, somewhat obviously, start this up like:

$ docker-compose up -d

We can then test this with the cli like so:

$ redis-cli set 3 "something"
OK
$ redis-cli -p 6380 set 3 "something" # fails because you're trying to write to the replica
(error) READONLY You can't write against a read only replica.
$ redis-cli -p 6380 get 3 # get from replica, same value
"something"

If you’re running a redis leader/follower topology in your staging/production environments or if you just want to experiment with how that might affect your application, this is probably the best place to start.