Jedis源码分析(四)-JedisSentinel与ShardedJedis介绍「建议收藏」

Jedis源码分析(四)-JedisSentinel与ShardedJedis介绍

大家好,又见面了,我是你们的朋友全栈君。

Jedis源码分析共有四个章节,以下为各章链接:

  1. Jedis源码分析(一)-Jedis介绍
  2. Jedis源码分析(二)-Jedis类结构及实现
  3. Jedis源码分析(三)- JedisCluster类结构及实现
  4. Jedis源码分析(四)-JedisSentinel与ShardedJedis介绍

1 JedisSentinel

JedisSentinel常用方式有两种:

1.使用哨兵单节点拿到主节点,从节点的信息

//通过哨兵节点的信息新建Jedis实例,然后拿到Master节点的信息
Jedis j = new Jedis(sentinel);
List<Map<String, String>> masters = j.sentinelMasters();
//拿到master的address,**MASTER_NAME**
List<String> masterHostAndPort = j.sentinelGetMasterAddrByName(**MASTER_NAME**);
HostAndPort masterFromSentinel = new HostAndPort(masterHostAndPort.get(0),Integer.parseInt(masterHostAndPort.get(1)));
assertEquals(master, masterFromSentinel);
//通过哨兵节点,拿到从节点的信息
List<Map<String, String>> slaves = j.sentinelSlaves(**MASTER_NAME**);

2.使用哨兵节点对象池

Set<String> sentinels = new HashSet<String>();
sentinels.add(new HostAndPort("localhost", 65432).toString());
sentinels.add(new HostAndPort("localhost", 65431).toString());
JedisSentinelPool pool = new JedisSentinelPool(MASTER_NAME, sentinels);
pool.destroy();

JedisSentinelPool的结构清晰,内部使用对象池存放一个个sentinel实例。图2-12和2-13分别为JedisSentinelPool的类结构和初始化流程。在使用时,我们先根据,host,port等信息,初始化一个Jedis实例,然后可以通过sentinelMasters()sentinelGetMasterAddrByName(MASTER_NAME)sentinelSlaves(MASTER_NAME)等方法拿到这个哨兵节点监听的MASTER节点信息或对应的SLAVE节点信息。

图片描述

​ 图1.1 JedisSentinelPool 的类结构

图片描述

​ 图1.2 JedisSentinelPool 的初始化流程

2 ShardedJedis

下文为构建Jedis分片的方法(单节点与对象池的模式),

  1. 单节点模式
List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>(2);
//其中一个分片
JedisShardInfo shard1 = new JedisShardInfo(redis1);
shards.add(shard1);
//另一个分片
JedisShardInfo shard2 = new JedisShardInfo(redis2);
shards.add(shard2);
@SuppressWarnings("resource")
//新建ShardedJedis实例
ShardedJedis shardedJedis = new ShardedJedis(shards);
shardedJedis.set("a", "bar");
//通过key可以查看存储在哪个jedis
JedisShardInfo ak = shardedJedis.getShardInfo("a");
assertEquals(shard2, ak);
  1. 对象池模式
ShardedJedisPool pool = new ShardedJedisPool(new GenericObjectPoolConfig(), shards);
ShardedJedis jedis = pool.getResource();
jedis.set("foo", "bar");
assertEquals("bar", jedis.get("foo"));

图片描述
图2-1 ShardedJedis的类结构

图片描述

​ 图2-2 ShardedJedis的初始化流程

​ 图2-1为ShardedJedis的类结构(其内部保存一个对象池,与常规的JedisPool的不同之处在于,内部的PooledObjectFactory实现不同),分片信息保存在基类Sharded中,Sharded保存了3个重要变量:

  1. nodes是一个TreeMap,保存了每个分片节点和对应的hash值。
  2. algo是计算hash值的函数,默认是MurmurHash,可替换。
  3. resources是一个LinkedHashMap,存放着JedisShardinfo和一个Jedis实例的对应关系。

​ 图2-2为 ShardedJedis的初始化流程,通过传入待分片的节点信息,初始化好上述3个变量。在使用时,先根据key计算出hash值,在nodes中找到对应的分片信息,再在resources中找到对应的Jedis实例,然后通过这个Jedis实例才操作redis节点。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/107443.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java传真发送,用Java发送传真解决之道

    java传真发送,用Java发送传真解决之道在传真量很大的部门,用传真机发送传真有时候不仅浪费资源(很多东西都是先需要打印出来然后再去传真),而且效率低下,也不便于归档管理。大家都知道,Windowsxp提供了传真服务组件,需要使用一个modem,就可以供传真服务。只要是能够打印的东西,都能够传真,这样确实方便不少。但是,实际使用中会有一个比较严重的问题,就是fax并不像打印机一样可以共享使用,这样网络中的其他机器就不能使用该…

  • iframe 自适应高度的多种实现方式

    iframe 自适应高度的多种实现方式iframe高度自适应内容需求:实现iframe的自适应高度,能够随着页面的长度自动的适应以免除页面和iframe同时出现滚动条的现象。设置iframe自适应高度,使其等于内嵌网页的高度

  • html里面超链接alt_怎样用HTML代码在图片插入超链接[通俗易懂]

    html里面超链接alt_怎样用HTML代码在图片插入超链接[通俗易懂]展开全部1、图像链接图片超链接和文字超链接是一样的,在e5a48de588b63231313335323631343130323136353331333366306533图像上插入链接:点击图片,跳转页面:之间插入元素。如:。(如图)2、局部链接在某种情况下,我们不希望整张图片加链接。希望的效果是:点击图片某个区域,链接到某地址。是通过map标签和标签结合使用的。如:(1)、(2)、扩展资料:元素…

  • m3u8格式视频源列表[通俗易懂]

    m3u8格式视频源列表[通俗易懂]平时,需要测试m3u8格式视频的播放,会使用一些可用的播放源,整理在这里:constsourceList=[{name:’cctv1′,src:’http://ivi.bupt.edu.cn/hls/cctv1hd.m3u8′},{name:’cctv2′,src:’http://ivi.bupt.edu.cn/hls/cc…

  • .jar中没有主清单属性[通俗易懂]

    .jar中没有主清单属性[通俗易懂].jar中没有主清单属性问题:xxx.jar中没有主清单属性背景:maven项目,springboot服务   IDEA打包,jar包运行出现上述错误解决方案:pom.xml中添加 <build><plugins><plugin><groupId>org.sp…

  • 5分钟商学院之个人篇–思考能力和谈判能力

    1.思考能力1.1六顶思考帽什么是六顶思考帽?每个人都有六顶不同颜色,代表不同思维方式的"帽子",分别是:(1)代表信息的白帽,充分搜索数据、信息和所有需要了解的情况

    2021年12月30日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号