ycache中redis主备功能设计及使用说明
方案概述:

实现说明:
- redis版本升级为3.0.1(也可以使用2.8.*的版本,但需要确保主、备版本是相同的)
- 打包新的redis rpm包
- redis使用开源的3.0.1的源码包
- 将https://github.com/zwChan/remirepo/tree/master/redis 拷贝到rpmbuild的source目录(/root/rpmbuild/SOURCES/),然后执行rpmbuild -bb redis.spec.
- 更新缺省的redis配置文件,支持aof(?)
- 检查命令的兼容情况
- yagent适配
- 读取自己管理的slave,定时更新一次这个信息(缺省10s,可配置)
- 定时检查一下slave对应的master是否正常,如果不正常,将自己设置为master,将原来的master设置为slave(缺省间隔为1s,连续检查5次失败后才算失败,所以延时5秒)
- 定时检查当前的master实例是否在zk上被配置为slave,如果是,将它转换为slave状态(5秒间隔)
- 每次一个redis实例重启后,如果它有slave且正常,都将正在起的实例变更为slave,将它原来的slave变更为master。这样做是为了避免redis实例快速重启导致数据丢失。详细的问题见: http://redis.io/topics/replication “Safety of replication when master has persistence turned off”
- 如果redis实例的主备状态和zk上的状态不一样,修改为与zk上的一样。(5秒间隔)
- yconsole适配
- 添加slaveof命令,配置和删除redis之间的主从关系;yconsole { slaveof } slave master
- 添加slaves命令,显示主从关系;同时检查zk上的主从关系是否与redis真实的主从关系一致。
- 主从关系发生变化时,通过命令行slaveof动态通知redis做出对应改变;
- add命令计算容量时不计算slave
- add/app/mod命令将slave也自动写到cache id的内容里
- list命令显示主从关系
- ycache-client适配
- slaveof目录的子节点增加和删除时,要进行重新初始化pool的处理
- 初始化pool时,将slaveof下的slave状态的实例去除
- 当slave的master变化时,不需要处理
- 每个pool只初始化一个zkproxy
- 限制:
- 每个master最多只能有一个slave,slave不能作为master;
使用方法:
- ycache-client:此功能对ycache-client使用者透明,仅须升级为2.2.0及以上版本的;
- yconsole:添加了slaves和slaveof命令,请查看 yconsole help命令获取命令格式。
- slaves: 查看slave和master对应的关系,后面的状态“ok”标识现在zk上的主备关系与redis本身主备关系的是一致的。

- slaveof:添加或删除slave/master关系(master参数为‘none’时删除关系)

刚配置后的几秒内,zk状态和redis状态可能不一致。等几秒后状态就一致了。
- 添加cache id时,如果一个redis实例已经被指定为slave,它所占用的资源不被计算到命令行指定的资源中;但如果分配后才配置slave/master关系的,cache id的容量会变少(因为slave是不参与使用)

将master添加到test中,它的slave会自动加到test中。但是,如果你单独将slave添加到test中,不会带着master加到test。 这是一种错误的配置,slave不应该直接被使用(尽管没有被禁止)
- yagent:升级版本大于等于‘2015-06-02';升级redis版本为2.8.*。 使用方法不变。redis新的rpm包在svn上。
问题与改进
- 所有的redis 的client都监听slaveof目录,很容易造成惊群问题;
- 老版本的client不能在主从环境的redis上用。所以要确保client升级后,才能用yconsole设置主从关系。
这两个问题是可以避免的,只要在cache id的内容中不记录从节点的信息即可。/redis/pools/cache-id的内容仅是master的节点,/redis/slaveof下记录slave对应的slave->master关系。每次主从关系变化时,都要确保/redis/pools/cache-id下的内容都是master,不包含slave(而且cache实例排列顺序也不能改变,之前的设计主要是考虑到这个因素)。这样就能够使得老版本的client也能使用主从关系了。同时,由于每个pool只依然仅监听自己的cache-id,不会会有惊群的现象。yagent和yconsole要确保上面提到的关系转换正确。
ycache中redis主备功能设计及使用说明的更多相关文章
- 搭建和测试 Redis 主备和集群
本文章只是自我学习用,不适宜转载. 1. Redis主备集群 1.1 搭建步骤 机器:海航云虚机(2核4GB内存),使用 Centos 7.2 64bit 操作系统,IP 分别是 192.168.10 ...
- 如何在DCS管理控制台将两个Redis主备实例建立全球灾备。
华为云分布式缓存服务DCS,具有强大的功能,现在小编教大家如何在DCS管理控制台将两个Redis主备实例建立全球灾备. 建立全球灾备,会对主实例和备实例进行升级,实例进程会重启,连接会中断.同时备实例 ...
- 阿里云ECS部署Redis主备哨兵集群遇到的问题
一.部署 详细部署步骤:https://blog.csdn.net/lihongtai/article/details/82826809 Redis5.0版本需要注意的参数配置:https://www ...
- Redis主备自动切换
Sentinel(哨兵)是用于监控redis集群中Master状态的工具. 一.Sentinel作用 1.Master状态检测 2.如果Master异常,则会进行Master-Slave切换,将 ...
- 分布式Redis主备复制
当数据落在不同节点上时,如何保证数据节点之间的一致性是非常关键的 Redis采用主备复制的方式保证一致性,所有节点中,只有一个节点为主节点(master),它对外提供写服务,然后异步的将数据复制到其他 ...
- Redis - Keepalived + redis 主备热备切换
1. 热备方案 硬件:server两台,分别用于master-redis及slave-redis 软件:redis.keepalived 实现目标: 由keepalived对外提供虚拟IP(VIP)进 ...
- Redis主备复制
Redis 支持 Master-Slave(主从)模式,Redis Server 可以设置为另一个 Redis Server 的主机(从机),从机定期从主机拿数据.特殊的,一个从机同样可以设置为一个 ...
- haproxy配置监控redis主备切换(转)
环境前提: redis sentinel配置,三台主机,且配置运行良好 配置文件中添加: frontend ft_redis bind 0.0.0.0:6379 name re ...
- 请不要用SECONDS_BEHIND_MASTER来衡量MYSQL主备的延迟时间【转】
本文来自:http://www.woqutech.com/?p=1116 MySQL 本身通过 show slave status 提供了 Seconds_Behind_Master ,用于衡量主备之 ...
随机推荐
- 09 redis中布隆过滤器的使用
我们在使用新闻客户端看新闻时,它会给我们不停地推荐新的内容,它每次推荐时要去重,去掉那些已经看过的内容.问题来了,新闻客户端推荐系统如何实现推送去重的? 会想到服务器记录了用户看过的所有历史记录,当推 ...
- C语言——指针总结
在创建指针时,我们首先要做的是先初始化它,没有初始化的指针是很危险的,因为指针可以指向一个地址后直接改变它的值,所以为了避免我们的指针在创建后指向一个危险区域(即可能指向系统文件等),我们会先给它一个 ...
- ZPL语言完成条形码的打印
近期因为项目的需求,需要使用到打印机来打印业务相关的条形码和其他信息,由于之前有操作其它打印机的经验,Leader就安排我来做这个了(凑哦,这能说我是懵逼的么).于是就开始了我的探索之旅啦,不对,是踩 ...
- ADF简单介绍
1.ADF也是用的MVC的分层模式,如下图所示 2.Model层代理数据服务将数据关联在View层,用户则是在View层的UI界面上的操作来更改Model层代理的数据,Controller控制层执行用 ...
- python 删除特定字符所在行
#查询文件中含有特殊字符串的行 #!/usr/bin/python # -*- coding:utf- -*- import re file1 = open('test.txt','r+') istx ...
- winform 导入 导出 excel
https://blog.csdn.net/pp_fzp/article/details/51502233
- java8 常用语法小结
// 判空 // 排序 //映射 //序列化
- 下一代容器技术podman简介
PODMAN主要由红帽发起和推动,是下一代的容器技术,包括如下三个模块:Podman,Skopeo和Buildah这三个工具都是符合OCI计划下的工具(github/containers).主要是由R ...
- MyBatis执行原理图
作者:W&L 推荐: 陶邦仁的博客 (1)加载配置并初始化 触发条件:加载配置文件 配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个M ...
- 7、DockerFile案例:自定义centos、自定义tomcat、webapps项目发布
1.Base镜像(scratch) Docker Hub 中 99% 的镜像都是通过在 base 镜像中安装和配置需要的软件构建出来的 2.自定义镜像mycentos 1.Hub默认CentOS镜像什 ...