Redis项目实战---应用及理论(三)---Jedis使用

Jedis即redis java客户端,源码地址:https://github.com/xetorthio/jedis

pom配置:

<dependency>

<groupId>redis.clients</groupId>

<artifactId>jedis</artifactId>

<version>3.0.1</version>

<type>jar</type>

<scope>compile</scope>

</dependency>

1)连接单机版

     public void testJedis() throws Exception {
          // 第一步:创建一个Jedis对象。需要指定服务端的ip及端口。
          Jedis jedis = new Jedis("192.168.**.**", 6379);
          // 第二步:使用Jedis对象操作数据库,每个redis命令对应一个方法。
          String result = jedis.get("hello");
          // 第三步:打印结果。
          System.out.println(result);
          // 第四步:关闭Jedis
          jedis.close();
     }

2) 连接单机版使用连接池

     public void testJedisPool() throws Exception {
          // 第一步:创建一个JedisPool对象。需要指定服务端的ip及端口。
          JedisPool jedisPool = new JedisPool("192.168.**.**", 6379);
          // 第二步:从JedisPool中获得Jedis对象。
          Jedis jedis = jedisPool.getResource();
          // 第三步:使用Jedis操作redis服务器。
          jedis.set("jedis", "test");
          String result = jedis.get("jedis");
          System.out.println(result);
          // 第四步:操作完毕后关闭jedis对象,连接池回收资源。
          jedis.close();
          // 第五步:关闭JedisPool对象。
          jedisPool.close();
     }

3) 连接集群版

     public void testJedisCluster() throws Exception {
          // 第一步:使用JedisCluster对象。需要一个Set<HostAndPort>参数。Redis节点的列表。
          Set<HostAndPort> nodes = new HashSet<>();
          nodes.add(new HostAndPort("192.168.**.**", 7001));
          nodes.add(new HostAndPort("192.168.**.**", 7002));
          nodes.add(new HostAndPort("192.168.**.**", 7003));
          nodes.add(new HostAndPort("192.168.**.**", 7004));
          nodes.add(new HostAndPort("192.168.**.**", 7005));
          nodes.add(new HostAndPort("192.168.**.**", 7006));
          JedisCluster jedisCluster = new JedisCluster(nodes);
          // 第二步:直接使用JedisCluster对象操作redis。在系统中单例存在。
          jedisCluster.set("hello", "100");
          String result = jedisCluster.get("hello");
          // 第三步:打印结果
          System.out.println(result);
          // 第四步:系统关闭前,关闭JedisCluster对象。
          jedisCluster.close();
     }

4)JedisPool初始化配置:

private static final int taskCount = 50; // 并发任务
private static final int batchSize = 10; // pipeline大小
private static final int cmdCount = 1000;// 每个任务处理命令数
private static final boolean usePipeline = true;

JedisPoolConfig poolConfig = new JedisPoolConfig();
poolConfig.setMaxActive(200);
poolConfig.setMaxIdle(100);
poolConfig.setMaxWait(2000);
poolConfig.setTestOnBorrow(false);
poolConfig.setTestOnReturn(false);
jedisPool = new JedisPool(poolConfig, host, port);

5)Jedis 消息发布与订阅API

5.1)消息订阅

   

   public void subscribeChannal(){       //从jedisPool中获取一个jedis对象
       Jedis jds = RedisInsUtil.getJedis();
       // 方式1 订阅得到信息在lister的onPMessage(...)方法中进行处理
       jds.psubscribe(this, new String[]{"channal01","channal02"});
      // 方式2 订阅得到信息在lister的onMessage(...)方法中进行处理  (普通订阅方式)
      //jedis.subscribe(listener, "foo", "watson");      }

    // 初始化订阅时候的处理
    @Override
    public void onSubscribe(String channel, int subscribedChannels) {
    } 

     // 初始化按表达式的方式订阅时候的处理
     @Override
     public void onPSubscribe(String pattern, int subscribedChannels) {
     }

     @Override
     // 取得按表达式的方式订阅的消息后的处理
     public void onPMessage(String pattern, String channel, String message) {
         LOG.info("onPMessage()," + pattern + "=" + channel + ",msg="+ message);
     }

     // 取得订阅的消息后的处理
     public void onMessage(String channel, String message) {
     }

5.2)消息发布

发布消息只用调用Jedis的publish(...)方法即可。

    Jedis jedis = ru.getConnection(); //获取一个jedis对象,自行封装工具类
    jedis.publish("hello_foo", "bar123");  

6) 管道

原理:

Redis客户端与Redis服务器之间使用TCP协议进行连接,管道(pipeline)可以一次性发送多条命令并在执行完后一次性将结果返回,pipeline通过减少客户端与redis的通信次数来实现降低往返延时时间,而且Pipeline 实现的原理是队列,而队列的原理是时先进先出,这样就保证数据的顺序性。

缺陷:需要注意到是用 pipeline方式打包命令发送,redis必须在处理完所有命令前先缓存起所有命令的处理结果。打包的命令越多,缓存消耗内存也越多。所以并不是打包的命令越多越好。具体多少合适需要根据具体情况测试。

备注:Pipeline 的默认的同步的个数为53个,也就是说arges中累加到53条数据时会把数据提交;

7)扩展:

由于redis-cluster的hash分片,JedisCluster对象原生并不支持Pipline管道和keys方法。然而,实际项目中在追求性能以及考虑到Redis集群版和单机版兼容或切换问题,往往需要支持这些方法,通过整理网上的部分资料,现给出以下思路,具体方法可参考gitHub示例

管道Pipline实现思路:

Redis集群规范: Redis 集群的键空间被分割为 16384 个槽(slot), 集群的最大节点数量也是 16384 个。每个主节点都负责处理 16384 个哈希槽的其中一部分。当一个集群处于“稳定”(stable)状态时(群没有在执行重配置(reconfiguration)操作), 每个哈希槽都只由一个节点进行处理(hash Slot的分配是由CRC16算法计算)。

故,

1.根据要插入的key知道这个key所对应的槽的号码(JedisClusterCRC16.getSlot(key)), 再通过这个槽的号码从集群中找到对应Jedis(通过每个节点的slot分布,就知道了哪些key应该在哪些节点上)。

2.相同槽位的key,使用同一个jedis.pipeline去执行命令。

3.合并此次pipeline所有的response返回。

keys实现思路:

循环集群中所有的节点(分别获取j对应的client对象),然后每个节点做keys,最后再加到一块返回。

备注:每次执行前需要刷新以获取最新的slot分布。

原文地址:https://www.cnblogs.com/huyangshu-fs/p/11256001.html

时间: 2024-10-31 16:47:50

Redis项目实战---应用及理论(三)---Jedis使用的相关文章

Redis项目实战 .net StackExchange.Redis

StackExchange.Redis 免费.支持异步.用的最多 常用对象 源码地址:https://github.com/StackExchange/StackExchange.Redis    用vs2017打开 ConnectionMultiplexer 中文意思  连接复用器 注释:Represents an inter-related group of connections to redis servers      表示一群相互关联的redis服务,就相当于一个对redis数据库操

Java企业级电商项目实战 Tomcat集群与Redis分布式

本套课程包含:java电商项目实战课程 Tomcat集群视频教程 Redis项目实战课程课程目录1-1 课程导学1-2 大型Java项目架构演进解析1-3 一期课程与问答服务回顾1-4 一期项目结构和代码回顾1-5 课程使用系统及技术版本介绍(一期+二期)1-6 二期项目初始化第2章 Lombok框架集成及原理解析本章会对Lombok框架进行介绍,同时会讲解Lombok的原理.并手把手领着小伙伴们实战,引入Lombok以及IDE安装Lombok插件.然后会带着大家实战Coding,讲解@Data

黑马2018年最新kotlin项目实战视频 (手机影音、即时通讯、黑马外卖、坦克大战等)

├─1.kotlin简介和学习方法│ 01_kotlin课程简介_01.mp4│ 02_kotlin学习方法_01.mp4│ 03_kotlin选好教练车_01.mp4│ 03_kotlin选好教练车_02.mp4│ 04_kotlin你好世界_01.mp4│ 05_kotlin变量与输出_01.mp4│ 05_kotlin变量与输出_02.mp4│ ├─10.类,对象和接口(三)│ 38_kotlin面向对象-抽象类和接口_01.mp4│ 38_kotlin面向对象-抽象类和接口_02.mp4

【无私分享:ASP.NET CORE 项目实战(第十一章)】Asp.net Core 缓存 MemoryCache 和 Redis

目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 经过 N 久反复的尝试,翻阅了网上无数的资料,GitHub上下载了十几个源码参考, Memory 和 Redis 终于写出一个 简陋 的 封装,为了统一和易用,我们两种缓存都统一实现了一个接口 ICacheService,微软也有很多是通过IDistributedCache,大家可以参考 https://docs.asp.net/en/latest/performance/caching/distributed.html 

大型分布式项目项目实战Springmvc+Spring+Mybatis+Maven+CMS+Redis+Solr+Linux+Nginx+单点登录、分布式缓存、负载均衡视频课程

* { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩 展.高性能.高并发.性能优化.Spring boot.Redis.ActiveMQ.Nginx.Mycat.Netty.Jvm大型分布 式项目实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  cloud.Dubbo.Redis.ActiveMQ.Nginx.Mycat

java架构师负载均衡、高并发、nginx优化、tomcat集群、异步性能优化、Dubbo分布式、Redis持久化、ActiveMQ中间件、Netty互联网、spring大型分布式项目实战视频教程百度网盘

15套Java架构师详情 * { font-family: "Microsoft YaHei" !important } h1 { background-color: #006; color: #FF0 } 15套java架构师.集群.高可用.高可扩展.高性能.高并发.性能优化.Spring boot.Redis.ActiveMQ.Nginx.Mycat.Netty.Jvm大型分布式项目实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  clo

Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式项目实战视频教程

15套java架构师.集群.高可用.高可扩展.高性能.高并发.性能优化.Spring boot.Redis.ActiveMQ.Nginx.Mycat.Netty.Jvm大型分布式项目实战视频教程 视频课程内容包含: 高级Java架构师包含:Spring boot.Spring  cloud.Dubbo.Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.ZeroMQ.Git.Nosql.Jvm.Mecached.Netty.Nio.Mina.性能调优.高并发.to

Linux程序设计从入门到精通(理论讲解+实际演示+项目实战)视频教程

Linux程序设计从入门到精通(理论讲解+实际演示+项目实战)视频教程下载    联系QQ:1026270010 本门课程的最终目的: 这门课程主要突出“实用”的C语言,即我们重点详细讲解真实项目开发和运用中实际运用的C语言知识,及容易犯错的地方,包括对一个C程序怎么去调试的技术.这有别于大学里直接去讲诉C语言的内容,也有别于全国计算机考试二级C里针对考试的C课程.这是一门实用的C语言课程,是你以后从事C语言开发过程中最需要的知识.当然,如果这个课程你认真的听过之后,面对大学的课程或者全国计算机

【无私分享:ASP.NET CORE 项目实战(第三章)】EntityFramework下领域驱动设计的应用

目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 在我们 [无私分享:从入门到精通ASP.NET MVC] 系列中,我们其实也是有DDD思想的,但是没有完全的去实现,因为并不是所有的好的东西都必须要用到的,还是根据实际情况,DDD在大型的系统中是非常好的一种设计思想,这点不否认.但是根据具体情况而言,在我们小型的项目中,我们设计框架的更多考虑的是让使用者快速.便捷的开发,能快速的了解框架进行项目开发. 重构我们的思路 最近研究了一下几位大神的博客,特别是:@腾飞(Jess