您的位置:首页 > 数据库 > Redis

redis实现主从复制和高可用(主从切换)

myhuashengmi 2016-07-24 20:46 225 查看


当用单个redis服务器压力过大时,就要考虑redis主从复制了,主master复制写入,从slave复制读取


,从而缓解服务器压力

接下来就配置一个reids的主从复制

127.0.0.1 :6379(主)

127.0.0.1 :6380(从)

127.0.0.1 :6381(从)

主从复制主要经历四个阶段: 

第一阶段:slave与master建立连接 

第二阶段:slave向master发起同步请求

第三阶段:slave接受master发来的dump.rdb数据 

第四阶段:slave载入dumo.rdb文件 

1.首先要有3个redis实例,安装1个redis,复制2个redis

进入/etc文件夹将redis.conf复制两份

  


2.分别配置redis.conf  不同的port 不同的pid 不同的redis文件夹

  配置master的redis.conf
配置不用改变,默认的就行


3.然后配置slave1的redis.conf
pidfile /var/run/redis1.pid #改变pid的文件名
port 6380                   #改变port端口号
dir /usr/local/redis1       #改变路径
slaveof 127.0.0.1 6379      #绑定主的ip和端口


 4.然后配置slave2的redis.conf

 
pidfile /var/run/redis2.pid #改变pid的文件名
port 6381                   #改变port端口号
dir /usr/local/redis2       #改变路径
slaveof 127.0.0.1 6379      #绑定主的ip和端口


 

5.配置完成后就开启这三个redis



6.启动成功后如图所示



7用master进入redis-cli查看info信息



如上图所示,角色信息是mater,有两个从分别是6380,6381

8.注意:master是写入的,slave是读的,我们用master-cli测试一下

首先来测试一下master



从上面看出redis是只允许写入的set,禁止读的get

9.测试一下主从复制

master负责写入设置一个键test,值为1111



 slave负责读取如图:取出test,值为11111

 


  

但是当主从的主,发生宕机时,数据肯定就断了,导致数据不能写入,reids的作者也想到了这一点,所以在redis2.6以上中就有了reids的监控软件sentinel(哨兵),sentinel会监控redis的主从是否存在,如果监控到主断掉了,那么就把从提升到主

下面配置下这个redis的sentinel.config

port 26379
port 26379
#master
sentinel monitor master1 127.0.0.1 6379 1   #主redis的ip和端口 1是有一个哨兵发生故障时就进行故障转移
sentinel down-after-milliseconds master1 3000 #多少毫米检测一次
sentinel failover-timeout master1 900000  多少毫秒进行故障转移
sentinel can-failover master1 yes
sentinel parallel-syncs master1 2

哨兵的启动:进入/usr/lcoal/redis目录

redis-server sentinel.conf --sentinel

其他参考连接:http://www.linuxidc.com/Linux/2013-11/92287p2.htm
标签: