[发明专利]一种基于Redis通用代理的实现方法、存储介质及电子设备在审
申请号: | 201711020724.2 | 申请日: | 2017-10-26 |
公开(公告)号: | CN108023932A | 公开(公告)日: | 2018-05-11 |
发明(设计)人: | 彭少毅;杨左元 | 申请(专利权)人: | 康美健康云服务有限公司 |
主分类号: | H04L29/08 | 分类号: | H04L29/08;G06F9/54 |
代理公司: | 广州市越秀区哲力专利商标事务所(普通合伙) 44288 | 代理人: | 代春兰;徐燕萍 |
地址: | 515300 广东省深圳市福田区华*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 redis 通用 代理 实现 方法 存储 介质 电子设备 | ||
1.一种基于Redis通用代理的实现方法,其特征在于包括以下步骤:
Redis通用代理时,首先需要进行初始化,包括以下步骤:
步骤1:Redis通用代理连接配置,配置集群内所述Redis Sentinel的连接信息;
步骤2:连接到Redis Sentinel,通过Sentinel Masters命令获取Master实例,并记录到集合Masters;
步骤3:连接到Redis Sentinel,遍历集合Masters通过Sentinel Slaves命令获取所述Master实例关联的Slave实例,记录所述Master实例与所述Slave实例之间的关系;
步骤4:将所述Master实例、所述Slave实例通过采用一致性哈希算法进行分布;
步骤5:通过Redis Sentinel PSUBSCRIBE命令订阅switch-master消息;
步骤6:客户端调用Redis代理接口,创建代理连接句柄,通过连接所述代理句柄执行Redis命令。
2.如权利要求1所述的一种基于Redis通用代理的实现方法,其特征在于:
当调用Redis通用代理执行命令时,执行以下步骤:
步骤A:判断是否指定了Key的业务前缀,若是,则计算Key业务前缀的Hash值,若否,则计算完整Key的Hash值;
步骤B:通过Hash值选择Redis的实例;
步骤C:查看连接池中是否有可用的到选定Redis实例的TCP长连接,如果有则使用所述TCP长连接;
步骤D:在所述TCP长连接上发送Redis命令;
步骤E:收到Redis响应报文后,执行Redis协议解释流程;
步骤F:将响应命令的返回值发送至客户端。
3.如权利要求2所述的一种基于Redis通用代理的实现方法,其特征在于:所述计算Key业务前缀的Hash值具体为通过哈希一致性算法计算Key业务前缀的Hash值;所述计算完整Key的Hash值具体为:通过哈希一致性算法计算完整Key的Hash值。
4.如权利要求2中任意一项所述的一种基于Redis通用代理的实现方法,其特征在于:
Redis发生主从切换时,执行以下步骤:
步骤G:处理PSubscribe命令订阅到的switch-master消息,并获取Redis Sentinel实例连接信息;
步骤H:通过Sentinel Slave命令,获取Master实例对应所有的Slave实例并重新更新Master与Slave实例之间的关系;
步骤I:释放连接池中与所述Master和Slave实例相关的TCP长连接。
5.一种电子设备,其特征在于包括:处理器;
存储器;以及程序,其中所述程序被存储在所述存储器中,并且被配置成由处理器执行,所述程序包括用于执行权利要求1-4任意一项所述的方法。
6.一种计算机可读存储介质,其上存储有计算机程序,其特征在于:所述计算机程序被处理器执行如权利要求1-4任意一项所述的方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于康美健康云服务有限公司,未经康美健康云服务有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711020724.2/1.html,转载请声明来源钻瓜专利网。