[发明专利]一种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命令;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于合一网络技术(北京)有限公司;,未经合一网络技术(北京)有限公司;许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410471813.9/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种基于数据库中数据创建信息搜索的方法
- 下一篇:落地页的加参方法和装置