[发明专利]基于redis集群的多键值命令处理方法及系统在审
申请号: | 201810220133.8 | 申请日: | 2018-03-16 |
公开(公告)号: | CN108509540A | 公开(公告)日: | 2018-09-07 |
发明(设计)人: | 黄河峰 | 申请(专利权)人: | 中国银行股份有限公司 |
主分类号: | G06F17/30 | 分类号: | G06F17/30 |
代理公司: | 北京三友知识产权代理有限公司 11127 | 代理人: | 贾磊;王涛 |
地址: | 100818 *** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 多键 节点信息 命令处理 实例对象 哈希 集群 数据库连接池 映射关系 应用程序编程接口 高可用性 业务模块 确定键 调用 | ||
本发明提供一种基于redis集群的多键值命令处理方法及系统。该基于redis集群的多键值命令处理方法包括:根据键值确定键值对应的哈希槽;获取哈希槽与节点信息的映射关系;根据哈希槽和映射关系获取节点信息;根据节点信息确定数据库连接池;从数据库连接池中获取jedis实例对象;在jedis实例对象上处理多键值命令。本发明支持在jedis实例对象上处理多键值命令,只需要一个应用程序编程接口,方便业务模块调用,具备高可用性。
技术领域
本发明涉及通信技术领域,具体地,涉及一种基于redis集群的多键值命令处理方法及系统。
背景技术
Redis在3.0版正式引入了集群(Cluster)这个特性,令扩展变得非常简单。但Redis集群并不支持处理多键值命令,比如pipeline命令。因为这需要在不同的节点间移动数据,因此达不到像Redis那样的性能,在高负载的情况下可能会导致不可预料的错误。
发明内容
本发明实施例的主要目的在于提供一种基于redis集群的多键值命令处理方法及系统,以支持处理多键值命令,方便业务模块进行调用。
为了实现上述目的,本发明实施例提供一种基于redis集群的多键值命令处理方法,包括:
根据键值确定键值对应的哈希槽;
获取哈希槽与节点信息的映射关系;
根据哈希槽和映射关系获取节点信息;
根据节点信息确定数据库连接池;
从数据库连接池中获取jedis实例对象;
在jedis实例对象上处理多键值命令。
在其中一种实施例中,节点信息包括:主节点的ip地址、主节点的端口地址、从节点的ip地址和从节点的端口地址。
在其中一种实施例中,根据节点信息确定数据库连接池,具体包括:
当未收到jedis连接异常信息时,根据主节点的ip地址和主节点的端口地址确定数据库连接池。
在其中一种实施例中,根据节点信息确定数据库连接池,具体包括:
当收到jedis连接异常信息时,根据从节点的ip地址和从节点的端口地址确定数据库连接池。
在其中一种实施例中,从数据库连接池中获取jedis实例对象之后,还包括:
使用类型检测命令判断jedis实例对象是否正确;
当jedis实例对象不正确时,生成jedis数据移动异常信息,数据移动异常信息包括正确的节点信息;
根据正确的节点信息确定正确的数据库连接池;
从正确的数据库连接池中获取正确的jedis实例对象。
本发明实施例还提供一种基于redis集群的多键值命令处理系统,包括:
哈希槽确定单元,用于根据键值确定键值对应的哈希槽;
映射关系获取单元,用于获取哈希槽与节点信息的映射关系;
节点信息获取单元,用于根据哈希槽和映射关系获取节点信息;
数据库连接池确定单元,用于根据节点信息确定数据库连接池;
jedis实例对象获取单元,用于从数据库连接池中获取jedis实例对象;
多键值命令处理单元,用于在jedis实例对象上处理多键值命令。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国银行股份有限公司,未经中国银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810220133.8/2.html,转载请声明来源钻瓜专利网。
- 上一篇:信息处理方法电子设备
- 下一篇:一种消息读取方法、消息读取装置及移动终端