在Spring Boot微服务使用Jedis操作Redis Zset(有序集合)

记录:411

场景:在Spring Boot微服务使用Jedis操作Redis Zset(有序集合)。

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

1.微服务中配置Redis信息

1.1在application.yml中Jedis配置信息

hub:
  example:
    redis:
      jedis:
        host: 192.168.19.203
        port: 28001
        password: 12345678
        timeout: 60000

1.2使用ConfigurationProperties加载Jedis配置

Spring Boot微服务在启动时,自动注解机制会读取application.yml的Jedis相关注入到JedisConnectProperties 对象。

在Spring环境中,注入JedisConnectProperties对象,就能获取到Redis相关配置信息。也就是Jedis客户端必须的参数。

定义JedisConnectProperties 类,扫描yml中的hub.example.redis.jedis配置。

@Component
@ConfigurationProperties(prefix="hub.example.redis.jedis")
public class JedisConnectProperties {
  private String host;
  private int port;
  private int timeout;
  private String password;
  public String getHost() {
      return host;
  }
  public void setHost(String host) {
      this.host = host;
  }
  public int getPort() {
      return port;
  }
  public void setPort(int port) {
      this.port = port;
  }
  public int getTimeout() {
      return timeout;
  }
  public void setTimeout(int timeout) {
      this.timeout = timeout;
  }
  public String getPassword() {
      return password;
  }
  public void setPassword(String password) {
      this.password = password;
  }
}

1.3在pom.xml添加依赖

在Spring Boot中默认集成jedis,使用时无需加版本号,本例版本3.7.1是Spring Boot 2.6.3对应的版本。


  redis.clients
  jedis
  3.7.1

2.微服务中配置Jedis

2.1配置Jedis

@Configuration
public class JedisConfig {
  @Autowired
  private JedisConnectProperties jedisProperties;
  @Bean("jedisPoolConfig")
  public JedisPoolConfig jedisPoolConfig() {
    JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
    jedisPoolConfig.setMaxTotal(30);
    jedisPoolConfig.setMaxIdle(30);
    jedisPoolConfig.setMinIdle(1);
    jedisPoolConfig.setNumTestsPerEvictionRun(-1);
    jedisPoolConfig.setTestOnBorrow(true);
    jedisPoolConfig.setTestOnReturn(false);
    jedisPoolConfig.setBlockWhenExhausted(false);
    return jedisPoolConfig;
  }
  @Bean("jedisPool")
  public JedisPool jedisPool(JedisPoolConfig jedisPoolConfig) {
    JedisPool jedisPool = new JedisPool(jedisPoolConfig,
        jedisProperties.getHost(),
        jedisProperties.getPort(),
        jedisProperties.getTimeout(),
        jedisProperties.getPassword());
    return jedisPool;
  }
}

2.2解析

在配置Jedis后,在Spring环境中可以使用@Autowired自动注入jedisPool,从Jedis资源池中获取Jedis就可以操作Redis了。

3.使用Jedis操作Redis Zset(有序集合)

3.1简要说明

使用Jedis操作Redis Zset(有序集合),常用操作:增、查、删、设置超时等。

3.2操作示例

@RestController
@RequestMapping("/hub/example/loadJedis")
@Slf4j
public class LoadJedisController {
  // 注入JedisPool资源池
  @Autowired
  private JedisPool jedisPool;
  /**
   * 在Spring Boot微服务使用Jedis操作Redis Zset(有序集合)
   */
  @GetMapping("/jedis06-01")
  public Object loadData06_01() {
    log.info("Jedis操作开始...");
    // 1.获取Jedis对象
    Jedis jedis = jedisPool.getResource();
    // 2.增
    // 2.1写入一条数据
    jedis.zadd("CityInfo:suzhou06:01", 30, "苏州");
    jedis.zadd("CityInfo:suzhou06:02", 30, "苏州");
    // 2.1写入批量数据
    Map scoreMembers = new HashMap<>();
    scoreMembers.put("苏州-姑苏", 35D);
    scoreMembers.put("苏州-工业园区", 60D);
    scoreMembers.put("苏州-吴江", 99D);
    jedis.zadd("CityInfo:suzhou06:01", scoreMembers);
    // 3.查
    // 3.1查询指定索引范围内的值
    Set result01 = jedis.zrange("CityInfo:suzhou06:01", 2, 3);
    // 3.2查询指定Score范围内的值
    Set result02 = jedis.zrangeByScore("CityInfo:suzhou06:01", 1, 40);
    // 3.3取出最大值
    Tuple max = jedis.zpopmax("CityInfo:suzhou06:01");
    log.info("取出最大值value = {},score={}", max.getElement(), max.getScore());
    // 3.4取出最小值
    Tuple min = jedis.zpopmin("CityInfo:suzhou06:01");
    log.info("取出最小值value = {},score={}", min.getElement(), min.getScore());
    // 4.删
    jedis.del("CityInfo:suzhou06:02");
    // 5.设置超时
    jedis.expire("CityInfo:suzhou06:01", 600L);
    // 6.释放Jedis对象
    jedis.close();
    log.info("Jedis操作结束...");
    return "执行成功";
  }
}

3.3测试验证

使用Postman测试。

请求RUL:http://127.0.0.1:18205/hub-205-redis/hub/example/loadJedis/jedis06-01

以上,感谢。

2023年4月15日

你可能感兴趣的:(L02-SpringBoot,在Spring,Boot微服务,使用Jedis,操作Redis,Zset,java)