封装自定义的redis切库工具类ByteArrayRedisTemplate,读取byte数组反序列化成List<Object>

封装自定义的redis切库工具类ByteArrayRedisTemplate,读取byte数组反序列化成List<Object>(使用lettuce连接池)

    • 代码环境
      • 框架:springboot
      • 依赖:spring-boot-starter-data-redis
    • 步骤1:注入LettuceConnectionFactory连接池代码思路
      • 参数1:RedisStandaloneConfiguration配置实例代码
      • 参数2:LettuceClientConfiguration配置实例思路
      • 参数2:LettuceClientConfiguration配置关键代码
    • 步骤2:封装自定义的redis切库工具
      • 实现一个自定义的RedisTemplate需要什么?
      • 切库关键代码
    • 步骤3:redis中读取List序列化的byte数组
      • 实例化ByteArrayRedisTemplate

代码环境

框架:springboot

依赖:spring-boot-starter-data-redis

步骤1:注入LettuceConnectionFactory连接池代码思路

首先注入bean的方法中返回LettuceConnectionFactory对象:

//伪代码
LettuceConnectionFactory lettuceConnectionFactory = new LettuceConnectionFactory(RedisStandaloneConfiguration类型 standaloneConfig,LettuceClientConfiguration类型 clientConfig);

需要两个参数:
1)RedisStandaloneConfiguration是单机配置。
2)LettuceClientConfiguration是LettuceClient连接池配置。
下文详细讲解。

参数1:RedisStandaloneConfiguration配置实例代码

RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration();redisStandaloneConfiguration.setDatabase(database);redisStandaloneConfiguration.setHostName(host);redisStandaloneConfiguration.setPort(port);if (StringUtils.isNotEmpty(password)) {redisStandaloneConfiguration.setPassword(password);}

RedisStandaloneConfiguration可改其他配置:RedisSentinelConfiguration是哨兵配置,RedisClusterConfiguration是集群模式。

参数2:LettuceClientConfiguration配置实例思路

查看LettuceClientConfiguration源码,发现LettuceClientConfiguration是一个接口。没办法直接new一个了。

不急,源码看一下。
有没有配置连接池的方法。LettuceClientConfiguration中发现有个builder():

static LettuceClientConfigurationBuilder builder() {return new LettuceClientConfigurationBuilder();}

点进去查看LettuceClientConfigurationBuilder类,未发现连接池的配置方法。

换个思路:看看LettuceClientConfigurationBuilder的子类。发现子类LettucePoolingClientConfigurationBuilder有一个poolConfig。

瞧,找到配置连接池的地方了。如图:

在这里插入图片描述
poolConfig方法如下,想想怎么实现一下?

public LettucePoolingClientConfigurationBuilder poolConfig(GenericObjectPoolConfig poolConfig)

GenericObjectPoolConfig类可以new一个实例设置一下连接池参数。
接着思考,需要一个LettucePoolingClientConfigurationBuilder实例来调poolConfig。
LettucePoolingClientConfigurationBuilder怎么构造呢?注意仔细看下面图片,LettucePoolingClientConfigurationBuilder是接口LettucePoolingClientConfiguration中的类。
在这里插入图片描述
注意:LettucePoolingClientConfiguration接口有一个builder()方法可以返回一个LettucePoolingClientConfigurationBuilder。

那么,直接

LettucePoolingClientConfiguration.builder()

就可以得到LettucePoolingClientConfigurationBuilder。

LettucePoolingClientConfigurationBuilder有了。就可以设置连接池配置。

LettucePoolingClientConfigurationBuilder.poolConfig(GenericObjectPoolConfig poolConfig)

连一起就是:

//伪代码
LettucePoolingClientConfiguration.builder().poolConfig(GenericObjectPoolConfig poolConfig)

注意:返回的仍然是LettucePoolingClientConfigurationBuilder。可以继续配置其他数据。例如

//配置超时时间
.commandTimeout(Duration.ofMillis(timeout))

但是,得到的是LettucePoolingClientConfigurationBuilder。

那我需要的是一个LettuceClientConfiguration接口啊,怎么联系起来。看看它的子类,有一个子类接口:LettucePoolingClientConfiguration。可以用它LettucePoolingClientConfiguration来替代

看看LettucePoolingClientConfigurationBuilder类中有没有什么方法可以返回LettucePoolingClientConfiguration。巧了,看下图蓝色框框:build()方法。
在这里插入图片描述

参数2:LettuceClientConfiguration配置关键代码

//伪代码
LettucePoolingClientConfiguration.builder().poolConfig(GenericObjectPoolConfig poolConfig).build();

返回一个LettucePoolingClientConfiguration。是LettuceClientConfiguration的子类接口。
然后就可以实现一个LettuceConnectionFactory了。

步骤2:封装自定义的redis切库工具

实现一个自定义的RedisTemplate需要什么?

1)LettuceConnectionFactory连接池。上一节已经注入实现。这里直接作为自定义的redisUtil中的生成generateRedisTemplate的方法,作为参数传入。
2)设置key、value的序列化方式。传入参数keySerializer,valueSerializer。

RedisTemplate redisTemplate = new RedisTemplate();redisTemplate.setKeySerializer(keySerializer);
redisTemplate.setHashKeySerializer(keySerializer);
redisTemplate.setValueSerializer(valueSerializer);
redisTemplate.setHashValueSerializer(valueSerializer);

keySerializer类型是:RedisSerializer<?> , valueSerializer类型是:RedisSerializer<?> 。

3)注意:返回RedisTemplate实例前需要执行redisTemplate.afterPropertiesSet()来初始化bean。

切库关键代码

//切库
lettuceConnectionFactory.setDatabase(database);
lettuceConnectionFactory.afterPropertiesSet();
lettuceConnectionFactory.resetConnection();//传入LettuceConnectionFactory连接池对象
redisTemplate.setConnectionFactory(lettuceConnectionFactory);
redisTemplate.afterPropertiesSet();

步骤3:redis中读取List序列化的byte数组

利用上一节实现的自定义的RedisTemplate来实例化一个ByteArrayRedisTemplate<String, byte[]>。

实例化ByteArrayRedisTemplate<String, byte[]>关键步骤

keySerializer类型传入参数:RedisSerializer.string() , valueSerializer类型传入参数:RedisSerializer.byteArray()。

使用byteArrayRedisTemplate实例读取数据代码示例

例如:redis中数据类型是List< UserEventAction>实例进行序列化成的byte[]。

byte[] tmp = byteArrayRedisTemplate.opsForValue().get(prefix + userKey);
//读取后对数据进行反序列化后进行强转
List<UserEventAction> obj = (List<UserEventAction>) SerializeUtil.unserialize(tmp);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/549157.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

随便唠叨下 最近的事情

闵行交大 闵行公安 闵行建交委 闵行大联动 闵行人口办 闵行... 看来到上海后,一直跟闵行有缘啊. 某天早上起来,赶紧洗个衣服,其实也就是几件衣服. 在卫生间冲洗后,晾晒时发现:一只袜子跑了. 望着手中仅剩的一只白袜,我感到很蛋疼.马上找了一遍,无果 这件灵异事件一直困扰着我,导…

redis的zset使用(java)——存取List< Object>

1 需求 要往redis存取List< Object>。 2 条件 1&#xff09;Object&#xff1a;是一个UserEvent对象&#xff0c;对应3个字段&#xff1a; Integer productId; String eventCode; Long timestamp;2&#xff09;要求 每个key里存取对象个数不超过xx个。 超过xx个&…

ogre研究之第一个程序(一)

第一次发送超过字数了&#xff0c;被迫剪成两篇&#xff01; 上一篇我们介绍了如何搭建开发环境&#xff0c;并创建了一个空白的窗口程序。 这里我们主要是实现在程序中装载一个简单的模型并显示出来。 首先看一下效果吧&#xff0c;&#xff08;模型就是ogre例子中的robot.mes…

Executor源码解读

Executor源码解读〇、[源码版本] jdk 1.8一、不再显式创建线程[举例1]代码示例二、不严格要求执行是异步的[举例1]代码示例三、任务在调用者线程之外的某个线程中执行[举例1]代码示例四、施加了某种限制的复合执行器[举例1]代码示例五、concurrent包中提供的Executor的实现对象…

Javascript高级程序设计第二版第十二章--Event--笔记

今天给诸位分享一下 chapter 12 Events所谓事件就是页面与文档窗口发生交互的瞬间。当年事件发生时它可以被预定&#xff08;程序处理&#xff09;。事件有两个过程&#xff0c;冒泡过程&#xff0c;或捕获过程。冒泡是自上而下&#xff0c;捕获是自下而上。这个顺序是document…

ExecutorService源码解读

ExecutorService源码解读〇、[源码版本] jdk 1.8一、ExecutorService接口详解1、ExecutorService关闭方法概述[举例1]代码示例2、ExecutorService任务执行方法概述3、Executors工厂方法概述[举例1]代码示例4、内存一致性影响二、接口方法详解1、shutdown方法2、shutdownNow方法…

英语生词本

英语生词本 1、daemon [di:mən] 守护进程2、phase [英] [feiz] 阶段, 时期3、methodology [英] [ˌmeθəˈdɔlədʒi:] 方法学,方法论4、algorithmalgorithm [英] [ˈlɡəriəm] [美] [ˈlɡəˌrɪəm] 运算法则2. 算法&#xff1b;演算法&#xff1b;计算程序3. 演示5、…

Executors源码解读——创建ExecutorService线程池

Executors源码解读——创建ExecutorService线程池〇、[源码版本] jdk 1.8一、线程池概述二、线程池创建三、Executors源码解读newFixedThreadPool()newWorkStealingPool()newSingleThreadExecutor()newCachedThreadPool()newSingleThreadScheduledExecutor()〇、[源码版本] jdk…

《大话设计模式》读书笔记-索引

《大话设计模式》读书笔记-第1章 简单工厂模式 《大话设计模式》读书笔记-第2章 策略模式 《大话设计模式》读书笔记-第3章 单一职责原则 《大话设计模式》读书笔记-第4章 开放-封闭原则 《大话设计模式》读书笔记-第5章 依赖倒转原则 《大话设计模式》读书笔记-第6章 装饰模式…

Future源码解读

Future源码解读〇、[源码版本] jdk 1.8一、Future概述[举例1]示例代码[举例2]示例代码内存一致性影响二、Future接口的方法cancel方法isCancelled方法isDone方法get方法〇、[源码版本] jdk 1.8 一、Future概述 Future表示异步计算的结果。提供了检查计算是否完成、等待计算完…

RIP,EIGRP,OSPF融合网络互通实验(原创)

首先看拓扑&#xff1a; 一个面试考官问我一个这样的问题&#xff0c;拓扑如上&#xff0c;为什么R1上的lo0 PING 不通 R6 上的lo0,说是一切都按正常配置&#xff0c;说是考我EIGRP的特性。我当然很纳闷&#xff0c;如果都正常配置怎么会不通呢&#xff0c;最后他告诉我主要是考…

谷歌A/B实验——重叠实验基础设施解读

谷歌A/B实验——重叠实验基础设施解读〇、来源一、背景介绍二、如何划分参数三、谷歌设计的ab实验系统3.1 域和层的设计3.1.1 基础重叠域和层设计3.1.2 具备非重叠和重叠的域和层设计3.1.2 具备非重叠的域的嵌套设计优点3.1.3 具备非重叠的域的嵌套设计缺点3.1.4 启动层&#x…

oracle 备份

1.首先以 sysdba的身份登录数据库 SQL> conn sys/oracle as sysdba SQL> col name for a50 SQL> select * from v$controlfile; 找到控制文件所在目录 STATUS ------- NAME --------------------------------------- F:\ORACLE\ORADATA\AFIS40\CONTROL01.CTL F:\O…

Mysql 5.7 创建索引官方解读

一、环境 Mysql 5.7 二、Mysql索引创建解读 1.概述 通常我们在使用CREATE TABLE时会创建所有的索引。索引的创建对于 InnoDB 表尤其重要&#xff0c;其中主键决定了数据文件中行的物理布局。 CREATE INDEX是另一种添加索引的方式&#xff0c;针对已经创建的表添加索引。注…

ntp时间服务解析

网络时间协议NTP&#xff08;Network Time Protocol&#xff09;是用于互联网中时间同步的标准互联网协议。NTP的用途是把计算机的时间同步到某些时间标准。目前采用的时间标准是世界协调时UTC&#xff08;Universal Time Coordinated&#xff09;。NTP的主要开发者是美国特拉华…

java循环中list.add对象的坑——后加入元素覆盖早期数据成相同值问题

原因 list.add&#xff08;对象&#xff09;&#xff0c;放入的实质是对象的引用。当对象在循环外进行new后&#xff0c;第一次循环add对象1&#xff0c;第二次循环add对象2&#xff0c;由于放入实质是对象的引用&#xff0c;引用指向了对象2&#xff0c;故变成list里有两个对…

AspectJ切面自定义注解实现参数分组校验——基础概念(1)

AspectJ切面自定义注解实现参数分组校验——基础概念&#xff08;1&#xff09;一、环境二、validation-api源码解读2-1.Default源码解读2-2.valid源码解读2-3.Validation源码解读一、环境 maven 需要引入的依赖&#xff1a; <dependency><groupId>javax.valida…

【注册机】ColorSchemer Studio 2.1.0 注册机

下载地址&#xff1a;http://files.cnblogs.com/boringlamb/keygencs.rar转载于:https://www.cnblogs.com/boringlamb/archive/2010/09/01/1815264.html

AspectJ切面自定义注解实现参数分组校验——基础概念(2)

AspectJ切面自定义注解实现参数分组校验——基础概念&#xff08;2&#xff09;一、环境二、创建AspectJ2-1.基础概念2-2.Pointcut规则表达式2-3.切点标志符pointcut designator (PCD)1&#xff09;execution2&#xff09;within3&#xff09;this和target4&#xff09;args5&a…

5230主题下载

最近朋友买了新手机&#xff0c;可是她又是电脑白痴&#xff0c;告诉她要她用百度搜&#xff0c;硬是没找到&#xff0c;百般无奈我千挑万选&#xff0c;找到了这个网站&#xff0c;让方便也同样带给同样不知道怎么用百度的朋友了5230主题下载网址&#xff1a;http://d.958shop…