在Spring Boot微服务使用SetOperations操作Redis集群Set集合(无序集合)

news/2024/11/30 1:46:22/

记录:446

场景:在Spring Boot微服务使用RedisTemplate的SetOperations操作Redis集群的Set集合(无序集合)数据类型。

版本: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 SetOperations<String, Object> setOperations(RedisTemplate<String, Object> redisTemplate) {return redisTemplate.opsForSet();}
}

2.2解析

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

3.使用SetOperations操作Redis集群Set集合(无序集合)

3.1简要说明

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

3.2操作示例

@RestController
@RequestMapping("/hub/example/operateCluster")
@Slf4j
public class OperateClusterController {@Autowiredprivate RedisTemplate redisTemplate;@Autowiredprivate SetOperations setOperations;/*** 使用SetOperations,操作操作Set类型数据,无序排列且无重复数据*/@GetMapping("/f05")public Object f05() {log.info("SetOperations操作Redis集群开始...");// 1.增setOperations.add("D:2023060805:01", "杭州", "苏州", "上海");// 2.查Set set = setOperations.members("D:2023060805:01");set.forEach((value) -> {System.out.println("value=" + value);});long time = 5000;log.info("{}秒后,删除D:2023060805:01队列", time / 1000);ThreadUtil.sleep(time);// 3.1删(删除指定元素)setOperations.remove("D:2023060805:01", "杭州", "苏州");// 3.2删(删除全部)redisTemplate.delete("D:2023060805:01");// 4.设置超时setOperations.add("D:2023060805:02", "杭州", "苏州", "上海");redisTemplate.boundValueOps("D:2023060805:02").expire(5, TimeUnit.MINUTES);redisTemplate.expire("D:2023060805:02", 10, TimeUnit.MINUTES);// 5.查询Set的元素个数Long size = setOperations.size("D:2023060805:02");System.out.println("查询Set的元素个数,size=" + size);log.info("SetOperations操作Redis集群结束...");return "执行成功";}
}

3.3测试验证

使用Postman测试。

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

以上,感谢。

2023年6月8日


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

相关文章

<DB2>《DB2数据库健康检查》第1部分

《DB2数据库健康检查》第1部分 1 进程检查1.1 检查管理服务器是否启动1.2. 检查DB2实例是否已经启动 2 数据库对象检查2.1 数据库能否正常连接2.2 查看表空间状态是否正常2.3 监控开关是否开启2.4 数据库大小2.5. 检查容器状态是否正常2.6 查看bufferpool属性2.7 查看表的状态2…

Kafka-Eagle安装及连接成功web端登陆不了问题解决

kafka自身并没有集成监控管理系统&#xff0c;因此对kafka的监控管理比较不便&#xff0c;好在有大量的第三方监控管理系统来使用&#xff0c;常见的有&#xff1a; Kafka EagleKafkaOffsetMonitorKafka Manager&#xff08;雅虎开源的Kafka集群管理器&#xff09;Kafka Web C…

WiFi芯片出现Kr00k漏洞

RSA大会上&#xff0c;WiFi芯片的一个漏洞引起了专家们的广泛讨论。该漏洞名为Kr00k&#xff0c;编号CVE-2019-15126&#xff0c;由ESET研究员发现于Broadcom 和Cypress的WiFi芯片中。 事件概要 ESET研究员在分析KRAC时发现WiFi芯片中的漏洞&#xff0c;命名为Kr00k&#xff0c…

数十亿个 Wi-Fi 设备存在缺陷,通信易被窃听!

作者 | DAN GOODIN 译者 | 弯月&#xff0c;责编 | 屠敏 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 以下为译文&#xff1a; 在最近的RSA安全会议上&#xff0c;研究人员表示&#xff0c;数十亿设备&#xff08;其中许多已打补丁&#xff09;受到Wi-Fi漏洞的…

【大杂烩】杂7杂8的东西

2013.8.21 今天是第一天搬到5栋&#xff0c;新的环境&#xff0c;新的面孔。工作上暂时没有安排&#xff0c;可以先看看资料&#xff0c;早上把iptables重新看了一下&#xff0c;整理了一下链和表的关系&#xff0c;并且在MR3080上进行了实验。 2013.8.27 项目移交整理&#xf…

Ficus 第二弹,突破限制器的 Markdown 编辑管理软件!

大家好&#xff0c;我们是 ggG 团队&#xff0c;我们开发的 markdown 笔记管理软件 Ficus Beta 版本正式发布了。详情可以见我们官网&#xff0c;也可以来我们仓库查看。 相对于 Alpha 版本&#xff08;可以在我们之前的博客中查看&#xff09;&#xff0c;主要有 3 点明显的提…

C++ 面试题:C++哪种静态成员变量可以在类内初始化?

在 C 中&#xff0c;只有静态常量整型成员&#xff08;包括整型、字符型、布尔型等&#xff09;可以在类内初始化。这是因为静态成员是属于类的&#xff0c;而不是属于类的某个具体对象的&#xff0c;所以它们的初始化不依赖于类的对象。 对于非静态成员变量&#xff0c;无论它…

腾讯qq接口

<a title"点击这里给我发消息" href"http://wpa.qq.com/msgrd?V1&uin1179085381&Site&Menuyes"> </a> 转载于:https://www.cnblogs.com/nonoleng/p/4530808.html