在Spring Boot微服务使用HashOperations操作Redis集群Hash哈希散列

news/2024/10/17 18:30:34/

记录:445

场景:在Spring Boot微服务使用RedisTemplate的HashOperations操作Redis集群的Hash哈希散列数据类型。

版本:JDK 1.8,Spring Boot 2.6.3,redis-6.2.5。

1.微服务中配置Redis信息

1.1在pom.xml添加依赖

pom.xml文件:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><version>2.6.3</version>
</dependency>

解析:spring-boot-starter-data-redis和spring-boot版本保持一致。

1.2在application.yml中配置Redis集群信息

(1)application.yml配置内容

spring:redis:cluster:nodes:- 192.168.19.161:27001- 192.168.19.161:27002- 192.168.19.162:27001- 192.168.19.162:27002- 192.168.19.163:27001- 192.168.19.163:27002password: demo12345678timeout: 60000

(2)解析

配置内容来源。

jar包:spring-boot-autoconfigure-2.6.3.jar。

类:org.springframework.boot.autoconfigure.data.redis.RedisProperties。

当引入spring-boot-starter时,此包已经引入。

当需要配置集群其它信息时,在RedisProperties类中查找并配置到application.yml就能生效。

1.3加载简要逻辑

Spring Boot微服务在启动时,自动注解机制会读取application.yml的配置信息注入到RedisProperties对象的对应属性。因此,在Spring环境中就能取到Redis集群的配置信息。

Spring从RedisProperties对象中取配置注入到RedisTemplate客户端中。因此,RedisTemplate客户端就能对Redis集群做增、删、改、查等操作。

2.配置RedisTemplate

RedisTemplate是springframework框架中封装的操作Redis的客户端。

类全称:org.springframework.data.redis.core.RedisTemplate

2.1配置RedisTemplate

@Configuration
public class RedisConfig {@Bean("redisTemplate")public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory) {// 1.创建RedisTemplate对象RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();// 2.加载Redis配置redisTemplate.setConnectionFactory(lettuceConnectionFactory);// 3.配置key序列化RedisSerializer<?> stringRedisSerializer = new StringRedisSerializer();redisTemplate.setKeySerializer(stringRedisSerializer);redisTemplate.setHashKeySerializer(stringRedisSerializer);// 4.配置Value序列化Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);ObjectMapper objMapper = new ObjectMapper();objMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);objMapper.activateDefaultTyping(objMapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(objMapper);redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);// 5.初始化RedisTemplateredisTemplate.afterPropertiesSet();return redisTemplate;}@Beanpublic HashOperations<String, Object, Object> hashOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForHash();}
}

2.2解析

使用@Configuration和@Bean配置RedisTemplate后,使用@Autowired注解注入RedisTemplate和HashOperations实例操作Redis集群。

3.使用HashOperations操作Redis集群Hash哈希散列

3.1简要说明

使用ValueOperations操作字符串,常用操作:增、查、改、删、设置超时等。

3.2操作示例

@RestController
@RequestMapping("/hub/example/operateCluster")
@Slf4j
public class OperateClusterController {@Autowiredprivate RedisTemplate redisTemplate;@Autowiredprivate HashOperations hashOperations;/*** 使用HashOperations,操作Hash类型数据*/@GetMapping("/f04")public Object f04() {log.info("HashOperations操作Redis集群开始...");// 1.增hashOperations.put("D:2023060804:01", "hangzhou", "杭州");hashOperations.put("D:2023060804:01", "suzhou", "苏州");hashOperations.put("D:2023060804:01", "nanjing", "南京");// 2.1查-获取map键值对数据Map resultMap = hashOperations.entries("D:2023060804:01");resultMap.forEach((key, value) -> {System.out.println("key=" + key + ",value=" + value);});// 2.2查-获取Map的全部keySet set = hashOperations.keys("D:2023060804:01");set.forEach((key) -> {System.out.println("key=" + key);});// 2.3查-获取Map的全部valueList list = hashOperations.values("D:2023060804:01");list.forEach((value) -> {System.out.println("value=" + value);});// 3.改hashOperations.put("D:2023060804:01", "hangzhou", "杭州-西湖");long time = 5000;log.info("{}秒后,删除D:2023060804:01队列", time / 1000);ThreadUtil.sleep(time);// 4.1删,(删除指定值)hashOperations.delete("D:2023060804:01", "hangzhou", "suzhou");// 4.2删,(删除全部)redisTemplate.delete("D:2023060804:01");// 5.设置超时hashOperations.put("D:2023060804:02", "hangzhou", "杭州");redisTemplate.boundValueOps("D:2023060804:02").expire(5, TimeUnit.MINUTES);redisTemplate.expire("D:2023060804:02", 10, TimeUnit.MINUTES);// 6.查询Hash的元素个数Long size = hashOperations.size("D:2023060804:02");System.out.println("查询Hash的元素个数,size=" + size);log.info("HashOperations操作Redis集群结束...");return "执行成功";}}

3.3测试验证

使用Postman测试。

请求RUL:http://127.0.0.1:18205/hub-205-redis/hub/example/operateCluster/f04

以上,感谢。

2023年6月8日


http://www.ppmy.cn/news/285042.html

相关文章

led1和led2轮流闪烁c语言,一台48V/20Ah型电动自行车,开机时LED1和LED2同时闪烁不止,无法充电...

使用多年的48V/20Ah型电动自行车。将充电器接通市电220V后&#xff0c;电源红色指示灯LED1和双发光二极管LED2中的绿灯显示一段时间后自动熄灭。再开机时LED1和LED2同时闪烁不止&#xff0c;无法充电。 为便于故障分析&#xff0c;笔者根据实物绘制出的主电源开关电路原理图。如…

简单逆向18

诺莫18 原题&#xff1a; 开始&#xff1a; 放入IDA&#xff1a; int __usercall wmain<eax>(int a1<ebx>) {FILE *v1; // eaxFILE *v2; // eaxchar v4; // [esp3h] [ebp-405h]char v5; // [esp4h] [ebp-404h]char v6; // [esp5h] [ebp-403h]char v7; // [esp1…

汇编语言-课程设计2

;OVERVIEW DOG.exe 中 装载了程序 installer1, installer2, installer3, booter, newint, mainsub, set_ui, wait_choice, f1, f2, f3, f4, f5, show_str; mainsub 拥有五个功能函数 f1~f5, 两个子函数 set_ui & wait_choice, 一个通用的 show_str; installer1 将 boote…

【学习笔记】Flutter重要知识点

学习资料 4月28日-5月11日 按照这个视频边学习边敲代码 视频学习 争取两个星期把flutter和dart搞定&#xff01;&#xff01;&#xff01;&#xff01; 5月12日半夜更新学习日志 基本内容学的超不多了&#xff0c;感觉声明式编程真的好爱~~Android原生好久没搞了。接下来练几…

细说SSRF

目录 什么是SSRF形成原因容易出现SSRF的地方SSRF的危害脑图函数file_get_contents()fsockopen()curl_exec() 协议 漏洞检测常用绕过方式限制为http://www.xxx.com 域名时&#xff08;利用&#xff09;限制请求IP不为内网地址限制请求只为http协议利用[::]利用句号利用特殊地址利…

面试准备知识

信息收集 假如给你一个网站你怎么去渗透 步骤 首先看是什么类型的网站&#xff0c;大型网站可以去天眼查等查询法人股份等信息&#xff0c;小型网站可以查询使用了哪类建站系统。 whois信息查询 获取注册者邮箱姓名电话等 查询服务器旁站及子域名站点&#xff0c;因为主站一…

细说——SSRF

目录 什么是SSRF形成原因容易出现SSRF的地方SSRF的危害脑图SSRF相关函数和协议函数file_get_contents()fsockopen()curl_exec() 协议 漏洞检测常用绕过方式限制为http://www.xxx.com 域名时&#xff08;利用&#xff09;限制请求IP不为内网地址限制请求只为http协议利用[::]利用…

变电站综合自动化系统是将变电站内的二次设备经过功能的组合和优化设计

1.概述 本次建设内容包括&#xff1a;危险废物处理中心、有机废弃物处理中心、配套建设园区污水处理厂和园区管理中心等&#xff0c;该建设内容包括了安庆市静脉产业园项目红线范围内得所有固体废弃物处理子项目&#xff0c;以及园区红线范围内、外为园区配套的市政设施。全厂共…