redis实现主从复制和高可用(主从切换)
2016-07-25 20:06
801 查看
现在开始配置redis的主从配置
主从复制主要经历四个阶段:
第一阶段: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
4.然后配置slave2的redis.conf
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
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
相关文章推荐
- session入redis
- Python下redis setex函数的两种参数顺序
- Redis的调用
- 常见通用框架的理解(Redis,Zookeeper,Thrift)
- Redis简介及其使用方法
- 使用Redis存储Nginx+Tomcat负载均衡集群的Session
- 为什么Redis内存不宜过大
- redis 五种数据类型的使用场景
- Spring整合Redis
- 一个简单的redis性能测试程序和性能测试结果
- Redis ZADD命令
- ZRANGEBYSCORE
- spring-session使用教程(一):redis共享session
- redis里能不能针对set数据的每个member设置过期时间?
- redis
- Redis Expire
- linux & windows 安装redis
- Redis TTL命令
- spring集成 JedisCluster 联接 redis3.0 集群
- Windows系统如何安装Redis?