如何在Spring Boot微服务使用ValueOperations操作Redis集群String字符串
记录:443
场景:在Spring Boot微服务使用RedisTemplate的ValueOperations操作Redis集群String字符串类型数据。
版本: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:27002 password: demo12345678 timeout: 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.初始化RedisTemplate redisTemplate.afterPropertiesSet(); return redisTemplate; } @Bean public ValueOperations<String, Object> valueOperations(RedisTemplate<String, Object> redisTemplate) { return redisTemplate.opsForValue(); } }
2.2解析
使用@Configuration和@Bean配置RedisTemplate后,使用@Autowired注解注入RedisTemplate和ValueOperations实例操作Redis集群。
3.使用ValueOperations操作Redis String字符串
3.1简要说明
使用ValueOperations操作字符串,常用操作:增、查、改、删、设置超时等。
3.2操作示例
@RestController @RequestMapping("/hub/example/operateCluster") @Slf4j public class OperateClusterController { @Autowired private RedisTemplate redisTemplate; @Autowired private ValueOperations valueOperations; /** * 使用ValueOperations,操作String类型数据 */ @GetMapping("/f02") public Object f02() { log.info("ValueOperations操作Redis集群开始..."); // 1.增 valueOperations.set("D:2023060802:01", "浙江-杭州"); valueOperations.set("D:2023060802:02", "浙江-萧山"); // 2.查 Object result01 = valueOperations.get("D:2023060802:01"); log.info("查询 D:2023060802:01 = " + result01.toString()); // 3.改 valueOperations.set("D:2023060802:01", "浙江-宁波"); result01 = valueOperations.get("D:2023060802:01"); log.info("修改后,查询 D:2023060802:01 = " + result01.toString()); // 4.删 long time = 5000; log.info("{}秒后,删除D:2023060802:01.", time / 1000); ThreadUtil.sleep(time); String result02 = (String) valueOperations.getAndDelete("D:2023060802:01"); redisTemplate.delete("D:2023060802:02"); // 5.1设置超时(方式一) valueOperations.set("D:2023060802:03", "浙江-杭州"); valueOperations.getAndExpire("D:2023060802:03", 5, TimeUnit.MINUTES); // 5.2设置超时(方式二) valueOperations.set("D:2023060802:04", "浙江-杭州-西湖"); redisTemplate.expire("D:2023060802:04", 10, TimeUnit.MINUTES); // 6.查询Value的字节大小 Long size = valueOperations.size("D:2023060802:04"); log.info("缓存字节大小,size=" + size + " bytes"); log.info("ValueOperations操作Redis集群结束..."); return "执行成功"; } }
3.3测试验证
使用Postman测试。
请求RUL:http://127.0.0.1:18205/hub-205-redis/hub/example/operateCluster/f02
以上,感谢。
2023年6月8日
到此这篇关于在Spring Boot微服务使用ValueOperations操作Redis集群String字符串的文章就介绍到这了,更多相关Spring Boot微服务操作Redis集群String字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
记一次线上SpringCloud Feign请求服务超时异常排查问题
这篇文章主要介绍了记一次线上SpringCloud Feign请求服务超时异常排查问题,本项目与下游项目均注册在Eureka上面,对这个1秒就超时感到很迷惑,于是开始查阅底层源码之旅。需要的朋友可以参考下2022-01-01Springboot2.x 使用 Log4j2 异步打印日志的实现
这篇文章主要介绍了Springboot2.x 使用 Log4j2 异步打印日志的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-12-12详解SpringBoot中@NotNull,@NotBlank注解使用
这篇文章主要为大家详细介绍了Spring Boot中集成Validation与@NotNull,@NotBlank等注解的简单使用,感兴趣的小伙伴可以跟随小编一起学习一下2022-08-08
最新评论