1. Redis主从同步
Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,同步使用的是发布/订阅机制。
2. 配置主从同步
Mater Slave的模式,从Slave向Master发起SYNC命令。
可以是1 Master 多Slave,可以分层,Slave下可以再接Slave,可扩展成树状结构。
2.1 配置Mater,Slave
配置非常简单,只需在slave的设定文件中指定master的ip和port
Master: test166
修改设定文件,服务绑定到ip上
1 2 |
|
重启Redis
# systemctl restart redis
1 |
|
Slave: test167
修改设定文件,指定Master
1 2 3 |
|
也可以用命令行设定:
1 2 |
|
2.2 同期情况确认
Master:
1 2 3 4 5 6 |
|
Slave:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
同期正常时:
master_link_status:up
master_repl_offset和slave_repl_offset相等,
master_last_io_seconds_ago在10秒内。
2.3 Slave升级为Master
Master不可用的情况下,停止Master,将Slave的设定无效化后,Slave升级为Master
1 2 3 4 5 6 7 |
|
2.4 Health Check
Slave按照repl-ping-slave-period的间隔(默认10秒),向Master发送ping。
如果主从间的链接中断后,再次连接的时候,2.8以前按照full sync再同期。2.8以后,因为有backlog的设定,backlog存在master的内存里,重新连接之前,如果redis没有重启,并且offset在backlog保存的范围内,可以实现从断开地方同期,不符合这个条件,还是full sync
用monitor命令,可以看到slave在发送ping
1 2 3 |
|
2.5 设置Master的写行为
2.8以后,可以在设定文件中设置,Master只有当有N个Slave处于连接状态时,接受写操作
1 2 |
|
3. Redis HA管理工具
redis-sentinel 能监视同期的状态,发现Master down的时候,会进行failover,将Slave升级为Master,启动后会自动更新sentinel设定文件,发生failover时,会自动修改sentinel和redis的设定文件
环境:
Master: 10.86.255.167 :6379 sentinel:26379
Slave1: 10.86.255.166 :6379 sentinel:26379
Slave2: 10.86.255.167 :7379 sentinel:36379
Sentinel的设定文件在/etc/redis-sentinel.conf,对failover的动作等可以进行一些定义,本次主要验证Sentinel的动作,设定文件可以根据具体情况自行调整
3.1 设定Master,Slave
参照上文设定Master,Slave,并确认Mater和2个Slave的同期状态正常
3.2 Master上设定Sentinel
1 2 3 |
|
启动sentinel
1 2 3 |
|
确认
1 2 |
|
确认Master信息
1 |
|
确认Slave信息
1 |
|
3.3 Slave上设定Sentinel
在slave1上设定sentinel
1 2 3 |
|
启动slave1
1 |
|
在slave2上设定sentinel
1 2 3 4 |
|
启动slave2
1 |
|
3.4 动作确认
停止Master
1 |
|
确认日志发生fail over
1 |
|
确认Slave2变成Master,Slave1是Slave
1 |
|
1 |
|
启动刚才停掉的Master,确认Master变为Slave
1 |
|
3.5 Sentinel命令
1 2 3 4 5 6 |
|
4. 后记
本文介绍了Redis主从同步,读写分离,及HA,后续会继续研究Redis。
专注服务器运维十年,欢迎技术上的交流。微信:ee900222 QQ:176539854
http://www.cnblogs.com/ee900222/p/redis_2.html