Differences between revisions 19 and 28 (spanning 9 versions)
Revision 19 as of 2021-01-02 00:19:42
Size: 1991
Comment:
Revision 28 as of 2021-01-02 01:52:11
Size: 3890
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
INCOMPLETE DO NOT USE DISCLAIMER!
THIS ONLY WORKS IN BUSTER
INCOMPLETE DO NOT USE ON STRETCH
Line 7: Line 9:
 * 192.168.1.58 redis01
 * 192.168.1.59 redis02
 * 192.168.1.60 redis03
 * 192.168.1.59 redis01
 * 192.168.1.60 redis02
 * 192.168.1.61 redis03
Line 14: Line 16:
apt-get install redis-server redis-sentinel apt-get install redis-server
Line 21: Line 23:
Make sure the apache servers can reach redis. Change `bind 127.0.0.1` in `/etc/redis/redis.conf`. Each of the redis servers needs to listen on its own IP-address. Change the contents of the redis configuration file in `/etc/redis/redis.conf`.
Line 23: Line 25:
Add the IP-address for each of the servers. Each of the redis servers needs to listen on its own IP-address. Due to a bug in redis, the added IP-address will have to be in the beginning of the line, right next to `bind`. If the IP-address is added in the end of the line, then the cluster will not initialize itself, and a `Waiting for the cluster to join...` message will continuously write dots.
Line 24: Line 27:
bind 127.0.0.1 192.168.1.58 bind 192.168.1.58 127.0.0.1 ::1
Line 28: Line 31:
Enable Redis to listen on the network
Enable redis to listen on the network, instead of only listening on the loopback device.
Line 34: Line 36:
Stop the redis server on all hosts. Redis stores its data in memory only, hence its speed. To make sure redis does not loose its state, in case of a hardware failure, this will enable it to store the state as it changes in a file on disk.
Line 36: Line 38:
service redis-server stop appendonly yes
Line 39: Line 41:
To enable replication we need to consider one of the redis servers the master. Here it will be redis01. On the two other hosts add the following to `/etc/redis/redis.conf`. Activate redis cluster features
Line 41: Line 43:
slaveof 192.168.1.58 6379 cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000
Line 44: Line 48:
Start the redis servers again, but start it on redis01 first. Restart redis on all hosts.
Line 46: Line 50:
service redis-server start service redis-server restart
Line 48: Line 52:
redis01 should now be the master.
Line 50: Line 53:
=== Redis Sentinel === Next we will need to configure the servers to run as a cluster
{{{
redis-cli --cluster create 192.168.1.59:6379 192.168.1.60:6379 192.168.1.61:6379
}}}
Line 52: Line 58:
The same goes for `/etc/redis/sentinel.conf` You should get output similar to this
Line 54: Line 60:
bind 127.0.0.1 192.168.1.58 >>> Performing hash slots allocation on 3 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
M: 78252519c58c5e7651554b3c82ba5800e4c11c41 192.168.1.59:6379
   slots:[0-5460] (5461 slots) master
M: b26d5a1ebe4891c68acf1d6b7cea5cc19057849f 192.168.1.60:6379
   slots:[5461-10922] (5462 slots) master
M: 0db96b401cca249b61660ed4d2945d658dcdc6e1 192.168.1.61:6379
   slots:[10923-16383] (5461 slots) master
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join

>>> Performing Cluster Check (using node 192.168.1.59:6379)
M: 78252519c58c5e7651554b3c82ba5800e4c11c41 192.168.1.59:6379
   slots:[0-5460] (5461 slots) master
M: 0db96b401cca249b61660ed4d2945d658dcdc6e1 192.168.1.61:6379
   slots:[10923-16383] (5461 slots) master
M: b26d5a1ebe4891c68acf1d6b7cea5cc19057849f 192.168.1.60:6379
   slots:[5461-10922] (5462 slots) master
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
Line 56: Line 88:
Line 68: Line 101:
 * https://www.tecmint.com/setup-redis-cluster-in-centos-8/
 * https://stackoverflow.com/questions/39568561/how-to-solve-redis-cluster-waiting-for-the-cluster-to-join-issue

DISCLAIMER! THIS ONLY WORKS IN BUSTER INCOMPLETE DO NOT USE ON STRETCH

Redis

Redis is an in memory data structure storage. It will be used to share PHP-sessions between the apache servers. To guarantee a robust deployment three redis servers will be configured.

  • 192.168.1.59 redis01
  • 192.168.1.60 redis02
  • 192.168.1.61 redis03

Software

apt-get install redis-server

Configuration

Redis Server

Change the contents of the redis configuration file in /etc/redis/redis.conf.

Add the IP-address for each of the servers. Each of the redis servers needs to listen on its own IP-address. Due to a bug in redis, the added IP-address will have to be in the beginning of the line, right next to bind. If the IP-address is added in the end of the line, then the cluster will not initialize itself, and a Waiting for the cluster to join... message will continuously write dots.

bind 192.168.1.58 127.0.0.1 ::1

Enable redis to listen on the network, instead of only listening on the loopback device.

protected-mode no

Redis stores its data in memory only, hence its speed. To make sure redis does not loose its state, in case of a hardware failure, this will enable it to store the state as it changes in a file on disk.

appendonly yes

Activate redis cluster features

cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000

Restart redis on all hosts.

service redis-server restart

Next we will need to configure the servers to run as a cluster

redis-cli --cluster create 192.168.1.59:6379 192.168.1.60:6379 192.168.1.61:6379

You should get output similar to this

>>> Performing hash slots allocation on 3 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
M: 78252519c58c5e7651554b3c82ba5800e4c11c41 192.168.1.59:6379
   slots:[0-5460] (5461 slots) master
M: b26d5a1ebe4891c68acf1d6b7cea5cc19057849f 192.168.1.60:6379
   slots:[5461-10922] (5462 slots) master
M: 0db96b401cca249b61660ed4d2945d658dcdc6e1 192.168.1.61:6379
   slots:[10923-16383] (5461 slots) master
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join

>>> Performing Cluster Check (using node 192.168.1.59:6379)
M: 78252519c58c5e7651554b3c82ba5800e4c11c41 192.168.1.59:6379
   slots:[0-5460] (5461 slots) master
M: 0db96b401cca249b61660ed4d2945d658dcdc6e1 192.168.1.61:6379
   slots:[10923-16383] (5461 slots) master
M: b26d5a1ebe4891c68acf1d6b7cea5cc19057849f 192.168.1.60:6379
   slots:[5461-10922] (5462 slots) master
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

References

None: Redis (last edited 2022-01-03 22:09:21 by Kristian Kallenberg)