Redis支持主从同步。数据能够从主服务器向任意数量的从服务器上同步,同步使用的是发布/订阅机制。redis
Mater Slave的模式,从Slave向Master发起SYNC命令。bash
能够是1 Master 多Slave,能够分层,Slave下能够再接Slave,可扩展成树状结构。服务器
配置很是简单,只需在slave的设定文件中指定master的ip和portless
Master: test166工具
修改设定文件,服务绑定到ip上spa
1
2
|
# vi /etc/redis.conf
bind 10.86.255.166
|
重启Redis命令行
# systemctl restart redis3d
1
|
# less /etc/redis.conf
|
Slave: test167rest
修改设定文件,指定Master日志
1
2
3
|
slaveof <masterip> <masterport> 指定master的ip和port
masterauth <master-password> master有验证的状况下
slave-
read
-only
yes
设置slave为只读模式
|
也能够用命令行设定:
1
2
|
redis 127.0.0.1:9999> slaveof localhost 6379
OK
|
Master:
1
2
3
4
5
6
|
127.0.0.1:6379> INFO replication
# Replication
role:master
connected_slaves:1
slave0:ip=10.86.255.167,port=6379,state=online,offset=309,lag=1
……
|
Slave:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
127.0.0.1:6379> INFO replication
# Replication
role:slave
master_host:10.86.255.166
master_port:6379
master_link_status:up
master_last_io_seconds_ago:7
master_sync_in_progress:0
slave_repl_offset:365
slave_priority:100
slave_read_only:1
connected_slaves:0
master_repl_offset:0
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
|
同期正常时:
master_link_status:up
master_repl_offset和slave_repl_offset相等,
master_last_io_seconds_ago在10秒内。
Master不可用的状况下,中止Master,将Slave的设定无效化后,Slave升级为Master
1
2
3
4
5
6
7
|
redis 127.0.0.1:9999> SLAVEOF NO ONE
OK
redis 127.0.0.1:9999> info
......
role:master
......
|
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
|
127.0.0.1:6379> monitor
OK
1448515184.249169 [0 10.86.255.166:6379]
"PING"
|
2.8之后,能够在设定文件中设置,Master只有当有N个Slave处于链接状态时,接受写操做
1
2
|
min-slaves-to-write 3
min-slaves-max-lag 10
|
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的动做,设定文件能够根据具体状况自行调整
参照上文设定Master,Slave,并确认Mater和2个Slave的同期状态正常
1
2
3
|
# vi /etc/redis-sentinel.conf
daemonize
yes
sentinel monitor mymaster <master ip> 6379 2
|
启动sentinel
1
2
3
|
# redis-sentinel /etc/redis-sentinel.conf
或
# redis-server /etc/redis-sentinel.conf --sentinel
|
确认
1
2
|
# redis-cli -p 26379
127.0.0.1:26379> INFO sentinel
|
确认Master信息
1
|
127.0.0.1:26379> sentinel masters
|
确认Slave信息
1
|
127.0.0.1:26379> sentinel slaves mymaster
|
在slave1上设定sentinel
1
2
3
|
# vi /etc/redis-sentinel.conf
daemonize
yes
sentinel monitor mymaster <master ip> 6379 2
|
启动slave1
1
|
# redis-sentinel /etc/redis-sentinel.conf
|
在slave2上设定sentinel
1
2
3
4
|
# less /etc/redis-sentinel_36379.conf
daemonize
yes
port 36379
sentinel monitor mymaster <master ip> 6379 2
|
启动slave2
1
|
# redis-sentinel /etc/redis-sentinel_36379.conf
|
中止Master
1
|
127.0.0.1:6379> SHUTDOWN
|
确认日志发生fail over
1
|
# tail /var/log/redis/sentinel.log
|
确认Slave2变成Master,Slave1是Slave
1
|
test167:7379> info replication
|
1
|
test166:6379> info replication
|
启动刚才停掉的Master,确认变为Slave
1
|
10.86.255.167:6379> info replication
|
1
2
3
4
5
6
|
127.0.0.1:26379> sentinel masters
127.0.0.1:26379> sentinel slaves mymaster
127.0.0.1:26379> SENTINEL get-master-addr-by-name mymaster
127.0.0.1:26379> SENTINEL reset mymaster
127.0.0.1:26379> SENTINEL failover mymaster
127.0.0.1:26379> SENTINEL flushconfig mymaster
|
本文介绍了Redis主从同步,读写分离,及HA,后续会继续研究Redis。