[发明专利]一种Redis通用代理的实现方法在审
申请号: | 201410471813.9 | 申请日: | 2014-09-17 |
公开(公告)号: | CN104199957A | 公开(公告)日: | 2014-12-10 |
发明(设计)人: | 严国涛;张宇峰;彭锦臻;姚键;潘柏宇;卢述奇 | 申请(专利权)人: | 合一网络技术(北京)有限公司 |
主分类号: | G06F17/30 | 分类号: | G06F17/30;H04L29/06 |
代理公司: | 无 | 代理人: | 无 |
地址: | 100080 北京市海淀区*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 redis 通用 代理 实现 方法 | ||
1.一种Redis通用代理的实现方法,包括如下步骤:
Redis通用代理时,首先要实现初始化,包括如下步骤1- 3:
步骤1:配置Redis实例组,各个组内的实例采用一致性哈希进行分布;
步骤2:客户端调用Redis通用代理接口,生成一个全局句柄,之后通过该全局句柄执行相应的Redis命令;
步骤3:生成全局句柄时,Redis通用代理会对组内的各个实例生成一个一致性哈希环。
2.根据权利要求1所述的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:客户端得到响应命令的返回值。
3.根据权利要求2所述的Redis通用代理的实现方法,其特征在于:
在步骤6中,先判断配置文件是否指定了key的前缀分割符,如果是则按key的前缀部分生成hash值,选择hash环中的Redis实例,否则按照完整key生成的hash值,选择hash环中的Redis实例。
4.根据权利要求3所述的Redis通用代理的实现方法,其特征在于:
在步骤4中,调用接口时还指定Redis实例名,则在步骤6中,首先判断是否指定Redis实例名,如果是,则直接进入到步骤7,否则,进一步判断配置文件是否指定了key的前缀分割符,如果是则按key的前缀部分生成hash值,选择hash环中的Redis实例,否则按照完整key生成的hash值,选择hash环中的Redis实例。
5.根据权利要求2-4中任意一项所述的Redis通用代理的实现方法,其特征在于:
Redis进行主从切换时,包括如下步骤101-105:
步骤101:配置Redis实例的主从关系;
步骤102:配置Redis Sentinel监控Redis主实例;
步骤103:当与现在的主实例连接丢失时或无法建立连接时 ,Redis通用代理定期给从实例发送info命令;
步骤104:在故障发生时,sentinel将某个从实例选为新的主实例;
步骤105:在sentinel完成切换后, Redis通用代理从步骤103中的所述info命令返回的信息中学习到新的主实例,从而连接新的主实例。
6.根据权利要求5所述的Redis通用代理的实现方法,其特征在于:
在步骤1中,设置各个实例的权重。
7.根据权利要求6所述的Redis通用代理的实现方法,其特征在于:
在步骤1中,缺省情况时,各个实例的权重相同。
8.根据权利要求5所述的Redis通用代理的实现方法,其特征在于:
在步骤7中,如果没有可用的到选定Redis实例的TCP长连接,则建立新的到该Redis实例的TCP长连接,然后执行步骤8。
9.根据权利要求6-8中任意一项所述的Redis通用代理的实现方法,其特征在于:
当结束使用Redis通用代理时,执行步骤11:
步骤11:在程序退出时,释放步骤2得到的所述全局句柄。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于合一网络技术(北京)有限公司;,未经合一网络技术(北京)有限公司;许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410471813.9/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种基于数据库中数据创建信息搜索的方法
- 下一篇:落地页的加参方法和装置