Redis系列之(二):Redis主从同步,读写分离
《Redis系列之(二):Redis主从同步,读写分离》要点: 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上 # vi /etc/redis.confbind 10.86.255.166 重启Redis # systemctl restart redis Slave: test167 修改设定文件,指定Master slaveof <masterip> <masterport> 指定master的ip和portmasterauth <master-password> master有验证的情况下slave-read-only yes 设置slave为只读模式 也可以用命令行设定: redis 127.0.0.1:9999> slaveof localhost 6379OK 2.2 同期情况确认Master: 127.0.0.1:6379> INFO replication# Replicationrole:masterconnected_slaves:1slave0:ip=10.86.255.167,port=6379,state=online,offset=309,lag=1…… Slave: 127.0.0.1:6379> INFO replication# Replicationrole:slavemaster_host:10.86.255.166master_port:6379master_link_status:upmaster_last_io_seconds_ago:7master_sync_in_progress:0slave_repl_offset:365slave_priority:100slave_read_only:1connected_slaves:0master_repl_offset:0repl_backlog_active:0repl_backlog_size:1048576repl_backlog_first_byte_offset:0repl_backlog_histlen:0 同期正常时: master_link_status:up master_repl_offset和slave_repl_offset相等, master_last_io_seconds_ago在10秒内. 2.3 Slave升级为MasterMaster不可用的情况下,停止Master,将Slave的设定无效化后,Slave升级为Master redis 127.0.0.1:9999> SLAVEOF NO ONE OKredis 127.0.0.1:9999> info......role:master...... 2.4 Health CheckSlave依照repl-ping-slave-period的间隔(默认10秒),向Master发送ping. 如果主从间的链接中断后,再次连接的时候,2.8以前依照full sync再同期.2.8以后,因为有backlog的设定,backlog存在master的内存里,重新连接之前,如果redis没有重启,并且offset在backlog保存的范围内,可以实现从断开地方同期,不符合这个条件,还是full sync 用monitor命令,可以看到slave在发送ping 127.0.0.1:6379> monitorOK1448515184.249169 [0 10.86.255.166:6379] "PING" 2.5 设置Master的写行为2.8以后,可以在设定文件中设置,Master只有当有N个Slave处于连接状态时,接受写操作 min-slaves-to-write 3min-slaves-max-lag 10 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# vi /etc/redis-sentinel.confdaemonize yessentinel monitor mymaster <master ip> 6379 2 启动sentinel # redis-sentinel /etc/redis-sentinel.conf或# redis-server /etc/redis-sentinel.conf --sentinel 确认 # redis-cli -p 26379127.0.0.1:26379> INFO sentinel 确认Master信息 127.0.0.1:26379> sentinel masters 确认Slave信息 127.0.0.1:26379> sentinel slaves mymaster 3.3 Slave上设定Sentinel在slave1上设定sentinel # vi /etc/redis-sentinel.confdaemonize yessentinel monitor mymaster <master ip> 6379 2 启动slave1 # redis-sentinel /etc/redis-sentinel.conf 在slave2上设定sentinel # less /etc/redis-sentinel_36379.confdaemonize yesport 36379sentinel monitor mymaster <master ip> 6379 2 启动slave2 # redis-sentinel /etc/redis-sentinel_36379.conf 3.4 动作确认停止Master 确认日志发生fail over # tail /var/log/redis/sentinel.log 确认Slave2变成Master,Slave1是Slave test167:7379> info replication test166:6379> info replication 启动刚才停掉的Master,确认Master变为Slave 10.86.255.167:6379> info replication 3.5 Sentinel命令127.0.0.1:26379> sentinel masters127.0.0.1:26379> sentinel slaves mymaster127.0.0.1:26379> SENTINEL get-master-addr-by-name mymaster127.0.0.1:26379> SENTINEL reset mymaster127.0.0.1:26379> SENTINEL failover mymaster127.0.0.1:26379> SENTINEL flushconfig mymaster 4. 跋文本文介绍了Redis主从同步,读写分离,及HA,后续会继续研究Redis. 欢迎参与《Redis系列之(二):Redis主从同步,读写分离》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |