[发明专利]一种Redis通用代理的实现方法在审

专利信息
申请号: 201410471813.9 申请日: 2014-09-17
公开(公告)号: CN104199957A 公开(公告)日: 2014-12-10
发明(设计)人: 严国涛;张宇峰;彭锦臻;姚键;潘柏宇;卢述奇 申请(专利权)人: 合一网络技术(北京)有限公司
主分类号: G06F17/30 分类号: G06F17/30;H04L29/06
代理公司: 代理人:
地址: 100080 北京市海淀区*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 redis 通用 代理 实现 方法
【说明书】:

技术领域

 本申请涉及数据库领域,具体的,涉及一种Redis通用代理的实现方法。

背景技术

Redis是一款开源的、高性能的键-值存储(key-value store)系统。Redis的所有键值都存储在内存中,具有很高的单机读写性能。与其他缓存服务器如memcached对比,Redis提供了更加丰富的数据结构。Redis的Value不仅包括字符串(strings)类型,同时它还包括哈希(hashes)、列表(lists)、集合(sets)和 有序集合(sorted sets)等数据类型。从Redis2.8.9开始还引入了HyperLogLogs数据结构(一种基于概率的计数估算算法)。另外Redis还支持发布/订阅功能,支持lua脚本,以及数据的持久化操作。Redis支持的持久化方式有两种:快照方式(snapshot)以及AOF(追加式操作记录)。

Redis是一个单机系统,各个Redis实例之间不会相互通信(主从模式除外)。操作Redis时,需要按照Redis协议规范与Redis服务器进行通信。Redis服务器采用异步网络模型方式,具有很高的性能,能处理大并发的客户端请求。Redis本身自带了一个客户端Hiredis。

在现有技术中,Redis存在如下问题:在一个Redis集群中通常包含多个Redis实例,Redis自带的客户端Hiredis无法提供不同的key与集群中实例的对应关系。并且,Redis从2.8版本开始提供了sentinel功能,当Redis配置了主从模式时,通过sentinel可以进行主从切换,现有的Redis客户端在主从切换之后,无法发现新的主。

Redis的命令无法跨越多个Redis实例,比如Redis的一端lua脚本可能操作多个key,现有的Redis客户端无法保证多个key在同一个Redis实例上。并且,现有的Redis客户端在主从切换之后,无法发现新的主。

发明内容

本发明的目的在于提出一种Redis通用代理的实现方法,能够对key在集群中的分布进行管理,进一步的,能够对主从切换后,对新的主进行通信。

为达此目的,本发明采用以下技术方案:

一种Redis通用代理的实现方法,包括如下步骤:

Redis通用代理时,首先要实现初始化,包括如下步骤1- 3:

步骤1:配置Redis实例组,各个组内的实例采用一致性哈希进行分布;

步骤2:客户端调用Redis通用代理接口,生成一个全局句柄,之后通过该全局句柄执行相应的Redis命令;

步骤3:生成全局句柄时,Redis通用代理会对组内的各个实例生成一个一致性哈希环。

优选地,当需要调用Redis通用代理时,执行如下的步骤4-10:

步骤4: 客户端调用Redis通用代理的接口执行相应的Redis命令,调用接口时传入步骤2中生成的所述全局句柄,以及组名;

步骤5:根据命令参数生成相应的Redis协议格式的报文;

步骤6:按照key中的哈希值,选择哈希环中的Redis实例;

步骤7:Redis通用代理查看连接池中是否有可用的到选定Redis实例的TCP长连接,如果有则使用所述TCP长连接;

步骤8:在TCP长连接上发送Redis命令;

步骤9:收到Redis响应报文后,执行Redis协议解释流程;

步骤10:客户端得到响应命令的返回值。

优选地,在步骤6中,先判断配置文件是否指定了key的前缀分割符,如果是则按key的前缀部分生成hash值,选择hash环中的Redis实例,否则按照完整key生成的hash值,选择hash环中的Redis实例。

进一步优选地,在步骤4中,调用接口时还指定Redis实例名,则在步骤6中,首先判断是否指定Redis实例名,如果是,则直接进入到步骤7,否则,进一步判断配置文件是否指定了key的前缀分割符,如果是则按key的前缀部分生成hash值,选择hash环中的Redis实例,否则按照完整key生成的hash值,选择hash环中的Redis实例。

优选地,Redis进行主从切换时,包括如下步骤101-105:

步骤101:配置Redis实例的主从关系;

步骤102:配置Redis Sentinel监控Redis主实例;

步骤103:当与现在的主实例连接丢失时或无法建立连接时 ,Redis通用代理定期给给从实例发送info命令;

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于合一网络技术(北京)有限公司;,未经合一网络技术(北京)有限公司;许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201410471813.9/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top