[发明专利]基于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实例对象上处理多键值命令。

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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