java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Spring Boot微服务操作Redis集群String字符串

如何在Spring Boot微服务使用ValueOperations操作Redis集群String字符串

作者:zhangbeizhen18

这篇文章主要介绍了在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字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文