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节点。

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • navicat连接mysql失败是什么原因?_mysql1045错误代码

    navicat连接mysql失败是什么原因?_mysql1045错误代码1:2003错误不能连接到mysql服务解决方法:在Windows服务中将mysql服务手动打开或右键设置为开机延迟启动(连接失败一次后再连接即可成功连接)后续待补充

    2022年10月14日
    3
  • smalldatetime和datetime的差别

    smalldatetime和datetime的差别碰上了这件事,才学到教训,一直以为smalldatetime和datetime的差别只是在于时间范围:smalldatetime的有效时间范围1900/1/1~2079/6/6datetime的有效时间范围1753/1/1~9999/12/31所以我判断如果该值不用到太远的日期范围,就会使用smalldatetime。但我忽略了更关键的差别,那就是smalldatetime只精准到分,而datet…

    2022年5月19日
    32
  • ANT安装(亲测可用)「建议收藏」

    ANT安装(亲测可用)「建议收藏」ANT在win10x64系统上进行安装,安装步骤如下。1、打开官网2、选择要下载版本3、配置环境变量在path里配置ant安装地址\binant安装地址\lib4、在cmd里验证:Linux上安装ANT:1、下载apache-ant-1.10.5-bin.tar.gz到home目录2、cpapache-ant-1.10.5-bin.tar.gz/usr/local3、cd/usr/local4、tar-zxvfapache-ant-1.10.5-bin.ta

    2022年7月18日
    19
  • 使用pycharm安装第三方库_pycharm找不到第三方库

    使用pycharm安装第三方库_pycharm找不到第三方库Pycharm是我比较喜欢的一款编辑器。  学习python有半年左右,安装第三方库都是通过 pip install 或者 easy_install。每次都要打开命令行感觉太麻烦。还好Pycharm提供了安装第三方库和安装插件的功能。   首先打开Pycharm,点击左上角 >>File >>Setting。    打开之后点击>>Project:

    2022年8月29日
    3
  • chrome插件演示,经js转让chrome api清除浏览器缓存

    chrome插件演示,经js转让chrome api清除浏览器缓存

    2022年1月12日
    59
  • 矩阵相乘详解

    矩阵相乘详解首先要知道矩阵是怎么相乘的首先,两个矩阵要是想相乘需要满足,第一个矩阵的列数等于第二个矩阵的行数满足的话就可以相乘得到新的矩阵了举个例子嗷:矩阵a:123322212矩阵b:223121a矩阵是3*3(3行3列)的矩阵,b矩阵是3*2(3行2列)的矩阵,满足第一个矩阵的列数等于第二个矩阵的行数。那我们就可以相乘了一个m*n的矩阵和一个…

    2022年6月28日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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