主从模式和哨兵部署

一、Redis主从模式配置

 

1.1、案例拓扑

 

 

 

 

 

 

 

 

1.2、环境说明

主机名称

IP地址

redis版本和角色说明

master

20.0.0.10

redis 5.0.7(主)

slave1

20.0.0.20

redis 5.0.7(从)

slave2

20.0.0.30

redis 5.0.7(从)

 

1.3、Redis安装

所有服务器上安装,在master上演示

[root@master ~]# tar zxf redis-5.0.7.tar.gz
[root@master ~]# cd redis-5.0.7/
[root@master redis-5.0.7]# make -j2
[root@master redis-5.0.7]# make PREFIX=/usr/local/redis install
[root@master redis-5.0.7]# ln -s /usr/local/redis/bin/* /usr/local/bin/
[root@master redis-5.0.7]# cd utils/
[root@master utils]# ./install_server.sh
Welcome to the redis service installer
This script will help you easily set up a running redis server

Please select the redis port for this instance: [6379]
Selecting default: 6379
Please select the redis config file name [/etc/redis/6379.conf]
Selected default - /etc/redis/6379.conf
Please select the redis log file name [/var/log/redis_6379.log]
Selected default - /var/log/redis_6379.log
Please select the data directory for this instance [/var/lib/redis/6379]
Selected default - /var/lib/redis/6379
Please select the redis executable path [/usr/local/bin/redis-server]
Selected config:
Port           : 6379
Config file    : /etc/redis/6379.conf
Log file       : /var/log/redis_6379.log
Data dir       : /var/lib/redis/6379
Executable     : /usr/local/bin/redis-server
Cli Executable : /usr/local/bin/redis-cli
Is this ok? Then press ENTER to go on or Ctrl-C to abort.
Copied /tmp/6379.conf => /etc/init.d/redis_6379
Installing service...
Successfully added to chkconfig!
Successfully added to runlevels 345!
Starting Redis server...
Installation successful!

1.4、修改配置文件

1.4.1、master配置文件修改

[root@master src]# vim /etc/redis/6379.conf
#69行 修改监听地址为20.0.0.10(在实验环境使用),现网环境建议绑定从服务器IP地址
bind 20.0.0.10
#136行 开启守护进程
daemonize yes
#171行 修改日志文件目录
logfile /var/log/redis_6379.log
#263行 修改工作目录
dir /var/lib/redis/6379
#699行 开启AOF持久化功能
appendonly yes

[root@master utils]# /etc/init.d/redis_6379 restart      #开启Redis

[root@master utils]# netstat -anpt | grep redis
tcp        0      0 20.0.0.10:6379          0.0.0.0:*               LISTEN      57685/redis-server

1.4.2、slave1配置文件修改

[root@slave1 src]# vim /etc/redis/6379.conf
#69行 修改监听地址为20.0.0.10(在实验环境使用),现网环境建议绑定从服务器IP地址
bind 20.0.0.20
#136行 开启守护进程
daemonize yes
#171行 修改日志文件目录
logfile /var/log/redis_6379.log
#263行 修改工作目录
dir /var/lib/redis/6379
#699行 开启AOF持久化功能
appendonly yes
#287行  修改IP和端口
replicaof 20.0.0.10 6379

[root@slave1 utils]# /etc/init.d/redis_6379 restart      #开启Redis

[root@slave1 utils]# netstat -anpt | grep redis          #查看端口号
tcp        0      0 20.0.0.20:6379          0.0.0.0:*               LISTEN      19037/redis-server
tcp        0      0 20.0.0.20:34397         20.0.0.10:6379          ESTABLISHED 19037/redis-server

1.4.2、slave2配置文件修改  

 

[root@slave2 src]# vim /etc/redis/6379.conf
#69行 修改监听地址为20.0.0.10(在实验环境使用),现网环境建议绑定从服务器IP地址
bind 20.0.0.30
#136行 开启守护进程
daemonize yes
#171行 修改日志文件目录
logfile /var/log/redis_6379.log
#263行 修改工作目录
dir /var/lib/redis/6379
#699行 开启AOF持久化功能
appendonly yes
#287行  修改IP和端口
replicaof 20.0.0.10 6379

[root@slave2 utils]# /etc/init.d/redis_6379 restart      #开启Redis

[root@slave2 utils]# netstat -anpt | grep redis
tcp        0      0 20.0.0.30:6379          0.0.0.0:*               LISTEN      59182/redis-server
tcp        0      0 20.0.0.30:46648         20.0.0.10:6379          ESTABLISHED 59182/redis-server

1.5、测试效果

1.5.1、验证主从效果(master上看日志)

[root@master utils]# vi /var/log/redis_6379.log
......省略部分内容
57685:M 11 Nov 2020 10:51:17.605 * Replica 20.0.0.20:6379 asks for synchronization         #slave1服务器IP
57685:M 11 Nov 2020 10:51:17.605 * Full resync requested by replica 20.0.0.20:6379
57685:M 11 Nov 2020 10:51:17.605 * Starting BGSAVE for SYNC with target: disk
57685:M 11 Nov 2020 10:51:17.606 * Background saving started by pid 57691
57691:C 11 Nov 2020 10:51:17.607 * DB saved on disk
57691:C 11 Nov 2020 10:51:17.607 * RDB: 4 MB of memory used by copy-on-write
57685:M 11 Nov 2020 10:51:17.658 * Background saving terminated with success
57685:M 11 Nov 2020 10:51:17.658 * Synchronization with replica 20.0.0.20:6379 succeeded
57685:M 11 Nov 2020 10:55:07.287 * Replica 20.0.0.30:6379 asks for synchronization          #slave2服务器IP
57685:M 11 Nov 2020 10:55:07.287 * Full resync requested by replica 20.0.0.30:6379
57685:M 11 Nov 2020 10:55:07.287 * Starting BGSAVE for SYNC with target: disk
57685:M 11 Nov 2020 10:55:07.288 * Background saving started by pid 57734
57734:C 11 Nov 2020 10:55:07.290 * DB saved on disk
57734:C 11 Nov 2020 10:55:07.290 * RDB: 4 MB of memory used by copy-on-write
57685:M 11 Nov 2020 10:55:07.372 * Background saving terminated with success
57685:M 11 Nov 2020 10:55:07.372 * Synchronization with replica 20.0.0.30:6379 succeeded

1.5.2、master上验证从节点 

[root@master utils]# redis-cli -h 20.0.0.10 -p 6379
20.0.0.10:6379> info replication
# Replication
role:master
connected_slaves:2
slave0:ip=20.0.0.20,port=6379,state=online,offset=2702,lag=0
slave1:ip=20.0.0.30,port=6379,state=online,offset=2702,lag=1

1.5.3、插入数据验证

master上插入数据
20.0.0.10:6379> set name lisi
OK
20.0.0.10:6379> set score 80
OK
20.0.0.10:6379> keys *
1) "score"
2) "name"
20.0.0.10:6379> get name
"lisi"
20.0.0.10:6379> get score
"80"

slave1上查看
[root@slave1 utils]# redis-cli -h 20.0.0.20 -p 6379
20.0.0.20:6379> keys *
1) "score"
2) "name"
20.0.0.20:6379> get name
"lisi"
20.0.0.20:6379> get score
"80"

slave2上查看
[root@slave2 utils]# redis-cli -h 20.0.0.30 -p 6379
20.0.0.30:6379> keys *
1) "score"
2) "name"
20.0.0.30:6379> get name
"lisi"
20.0.0.30:6379> get score
"80"

二、Redis哨兵模式

 

2.1、Redis sentinel介绍

Redis Sentinel是Redis高可用的实现方案。Sentinel是一个管理多个Redis实例的工具,它可以实现对Redis的监控、通知、自动故障转移。

 

2.2、哨兵模式的作用

① 监控

不断的检查master和slave是否正常运行。master存活检测、master与slave运行情况检测

② 通知(提醒)

当被监控的服务器出现问题时,向其他(哨兵间,客户端)发送通知。

③ 自动故障转移

断开master与slave连接,选取一个slave作为master,将其他slave连接到新的master,并告知客户端新的服务器地址

PS:哨兵也是一台redis服务器,只是不提供数据服务

哨兵的启动依赖于主从模式,所以须把主从模式安装好的情况下再去做哨兵模式,所有节点上都需要部署哨兵模式,哨兵模式会监控所有的redis工作节点是否正常,当

master出现问题的时候,因为其他节点与主节点失去联系,因此会投票,投票过半就认为这个master的确出现问题,然后会通知哨兵间,然后从slaves中选取一个作为新的

master,至少需要3个或3个以上服务器

 

2.3、环境说明

主机名称IP地址redis版本和角色说明
master 20.0.0.10:6379 redis 5.0.7(主)
slave1 20.0.0.20:6379 redis 5.0.7(从)
slave2 20.0.0.30:6379 redis 5.0.7(从)
master 20.0.0.10:26379 Sentinel1
slave1 20.0.0.20:26379 Sentinel2
slave2 20.0.0.30:26379 Sentinel3

 

2.4、哨兵模式配置

所有节点都需要修改

[root@master ~]# vi redis-5.0.7/sentinel.conf
17行/protected-mode no                                  #关闭保护模式
26行/daemonize yes                                      #指定sentinel为后台启动
36行/logfile "/var/log/sentinel.log"                    #指定日志存放路径
65行/dir "/var/lib/redis/6379"                          #指定数据库存放路径
84行/sentinel monitor mymaster 20.0.0.10 6379 2         #至少几个哨兵检测到主服务器故障了,才会进行故障迁移,全部指向masterIP
113行/sentinel down-after-milliseconds mymaster 30000    #判定服务器down掉的时间周期,默认30000毫秒(30秒)
146行/sentinel failover-timeout mymaster 180000         #故障节的的最大超时时间为180000(180秒)

2.5、启动哨兵模式

[root@master ~]# redis-sentinel redis-5.0.7/sentinel.conf &
[1] 58571

[root@slave1 ~]# redis-sentinel redis-5.0.7/sentinel.conf &
[1] 19812

[root@slave2 ~]# redis-sentinel redis-5.0.7/sentinel.conf &
[1] 59917

2.6、查看哨兵信息

master查看
[root@master ~]# redis-cli -h 20.0.0.10 -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.10:6379,slaves=2,sentinels=3

slave1查看
[root@slave1 ~]# redis-cli -h 20.0.0.20 -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.10:6379,slaves=2,sentinels=3

slave2上查看
[root@slave2 ~]# redis-cli -h 20.0.0.20 -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.10:6379,slaves=2,sentinels=3

2.7、故障模拟

查看master进程号
[root@master ~]# ps -ef | grep redis
root      57685      1  0 10:51 ?        00:00:06 /usr/local/bin/redis-server 20.0.0.10:6379
root      58567      1  0 12:07 ?        00:00:01 redis-sentinel *:26379 [sentinel]
root      58649  58470  0 12:15 pts/1    00:00:00 grep --color=auto redis

杀死master上redis-server的进程号
[root@master ~]# kill -9 57685     #master上redis-server的进程号

 2.7.2、验证结果

 

[root@master ~]# tail -f /var/log/sentinel.log
58567:X 11 Nov 2020 12:18:14.388 # +failover-state-reconf-slaves master mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:14.467 * +slave-reconf-sent slave 20.0.0.20:6379 20.0.0.20 6379 @ mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:14.776 # -odown master mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:15.428 * +slave-reconf-inprog slave 20.0.0.20:6379 20.0.0.20 6379 @ mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:15.428 * +slave-reconf-done slave 20.0.0.20:6379 20.0.0.20 6379 @ mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:15.483 # +failover-end master mymaster 20.0.0.10 6379
58567:X 11 Nov 2020 12:18:15.483 # +switch-master mymaster 20.0.0.10 6379 20.0.0.30 6379                        #从master转到了slave2上
58567:X 11 Nov 2020 12:18:15.483 * +slave slave 20.0.0.20:6379 20.0.0.20 6379 @ mymaster 20.0.0.30 6379
58567:X 11 Nov 2020 12:18:15.483 * +slave slave 20.0.0.10:6379 20.0.0.10 6379 @ mymaster 20.0.0.30 6379
58567:X 11 Nov 2020 12:18:45.535 # +sdown slave 20.0.0.10:6379 20.0.0.10 6379 @ mymaster 20.0.0.30 6379

[root@master ~]# redis-cli -p 26379 INFO Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.30:6379,slaves=2,sentinels=3 

重新启动原旧master

[root@master ~]# /etc/init.d/redis_6379 restart
Stopping ...
Could not connect to Redis at 127.0.0.1:6379: Connection refused
Waiting for Redis to shutdown ...
Waiting for Redis to shutdown ...
Waiting for Redis to shutdown ...
Waiting for Redis to shutdown ...
Waiting for Redis to shutdown ...
直接重启无法启动,需要进入/var/run 讲pid文件删除
[root@master run]# rm -rf  redis_6379.pid
[root@master run]# /etc/init.d/redis_6379 restart
/var/run/redis_6379.pid does not exist, process is not running
Starting Redis server...
[root@master run]# netstat -anpt | grep redis
tcp        0      0 20.0.0.10:6379          0.0.0.0:*               LISTEN      60732/redis-server  
tcp        0      0 20.0.0.10:6379          20.0.0.30:43102         ESTABLISHED 60732/redis-server 
启动成功

  

  

  

  

  

  

 

  

 

  

 

posted @ 2020-11-12 21:20  孙天飞  阅读(357)  评论(0编辑  收藏  举报