码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 在Spring Boot微服务使用RedisTemplate操作Redis集群


    记录:442

    场景:在Spring Boot微服务使用RedisTemplate操作Redis集群的缓存和队列等数据类型。

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

    1.微服务中配置Redis信息

    1.1在pom.xml添加依赖

    pom.xml文件:

    1. <dependency>
    2. <groupId>org.springframework.bootgroupId>
    3. <artifactId>spring-boot-starter-data-redisartifactId>
    4. <version>2.6.3version>
    5. dependency>

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

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

    (1)application.yml配置内容

    1. spring:
    2. redis:
    3. cluster:
    4. nodes:
    5. - 192.168.19.161:27001
    6. - 192.168.19.161:27002
    7. - 192.168.19.162:27001
    8. - 192.168.19.162:27002
    9. - 192.168.19.163:27001
    10. - 192.168.19.163:27002
    11. password: demo12345678
    12. 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

    1. @Configuration
    2. public class RedisConfig {
    3. @Bean("redisTemplate")
    4. public RedisTemplate redisTemplate(LettuceConnectionFactory lettuceConnectionFactory) {
    5. // 1.创建RedisTemplate对象
    6. RedisTemplate redisTemplate = new RedisTemplate();
    7. // 2.加载Redis配置
    8. redisTemplate.setConnectionFactory(lettuceConnectionFactory);
    9. // 3.配置key序列化
    10. RedisSerializer stringRedisSerializer = new StringRedisSerializer();
    11. redisTemplate.setKeySerializer(stringRedisSerializer);
    12. redisTemplate.setHashKeySerializer(stringRedisSerializer);
    13. // 4.配置Value序列化
    14. Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
    15. ObjectMapper objMapper = new ObjectMapper();
    16. objMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
    17. objMapper.activateDefaultTyping(objMapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
    18. jackson2JsonRedisSerializer.setObjectMapper(objMapper);
    19. redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
    20. redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
    21. // 5.初始化RedisTemplate
    22. redisTemplate.afterPropertiesSet();
    23. return redisTemplate;
    24. }
    25. }
    26. 2.2解析

      配置RedisTemplate后,在Spring环境中,可以使用@Autowired注解注入RedisTemplate实例操作Redis集群。也可以使用cn.hutool.extra.spring.SpringUtil工具等从Spring 中获取RedisTemplate实例操作Redis集群。

      3.使用@Autowired注入RedisTemplate的方式操作Redis集群

      3.1简要说明

      使用@Autowired注入RedisTemplate,操作Redis集群的增、查、改、删等操作。

      3.2操作示例

      1. @RestController
      2. @RequestMapping("/hub/example/operateCluster")
      3. @Slf4j
      4. public class OperateClusterController {
      5. @Autowired
      6. private RedisTemplate redisTemplate;
      7. /**
      8. * 注入方式使用RedisTemplate
      9. */
      10. @GetMapping("/f01_01")
      11. public Object f01_01() {
      12. log.info("RedisTemplate操作Redis集群开始...");
      13. // 1.增
      14. redisTemplate.boundValueOps("D:2023060801:01").set("浙江-杭州");
      15. // 2.查
      16. Object result01 = redisTemplate.boundValueOps("D:2023060801:01").get();
      17. log.info("查询 D:2023060801:01 = " + result01.toString());
      18. // 3.改
      19. redisTemplate.boundValueOps("D:2023060801:01").set("浙江-宁波");
      20. result01 = redisTemplate.boundValueOps("D:2023060801:01").get();
      21. log.info("修改后,查询 D:2023060801:01 = " + result01.toString());
      22. // 4.删
      23. long time = 5000;
      24. log.info("{}秒后,删除D:2023060801:01.",time/1000);
      25. ThreadUtil.sleep(time);
      26. redisTemplate.delete("D:2023060801:01");
      27. // 5.1设置超时(方式一)
      28. redisTemplate.boundValueOps("D:2023060801:02").set("浙江-杭州");
      29. redisTemplate.expire("D:2023060801:02", 5, TimeUnit.MINUTES);
      30. // 5.2设置超时(方式二)
      31. redisTemplate.boundValueOps("D:2023060801:03").set("浙江-宁波", 5, TimeUnit.MINUTES);
      32. log.info("RedisTemplate操作Redis集群结束...");
      33. return "执行成功";
      34. }
      35. }

      3.3测试验证

      使用Postman测试。

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

      4.使用SpringUtil从Spring中获取RedisTemplate的方式操作Redis集群

      4.1简要说明

      使用SpringUtil从Spring中获取RedisTemplate的方式,操作Redis集群的增、查、改、删等操作。

      jar包:hutool-all-5.8.12.jar。

      类:cn.hutool.extra.spring.SpringUtil

      4.2操作示例

      1. @RestController
      2. @RequestMapping("/hub/example/operateCluster")
      3. @Slf4j
      4. public class OperateClusterController {
      5. @Autowired
      6. private RedisTemplate redisTemplate;
      7. /**
      8. * 使用工具获取RedisTemplate
      9. */
      10. @GetMapping("/f01_02")
      11. public Object f01_02() {
      12. log.info("RedisTemplate操作Redis集群开始...");
      13. RedisTemplate template = SpringUtil.getBean("redisTemplate");
      14. // 1.增
      15. template.boundValueOps("D:2023060801:04").set("浙江-杭州");
      16. // 2.查
      17. Object result01 = template.boundValueOps("D:2023060801:04").get();
      18. log.info("查询 D:2023060801:04 = " + result01.toString());
      19. // 3.改
      20. template.boundValueOps("D:2023060801:04").set("浙江-宁波");
      21. result01 = template.boundValueOps("D:2023060801:04").get();
      22. log.info("修改后,查询 D:2023060801:04 = " + result01.toString());
      23. // 4.删
      24. long time = 5000;
      25. log.info("{}秒后,删除D:2023060801:04.",time/1000);
      26. ThreadUtil.sleep(time);
      27. template.delete("D:2023060801:04");
      28. // 5.1设置超时(方式一)
      29. template.boundValueOps("D:2023060801:05").set("浙江-杭州");
      30. template.expire("D:2023060801:05", 5, TimeUnit.MINUTES);
      31. // 5.2设置超时(方式二)
      32. template.boundValueOps("D:2023060801:06").set("浙江-宁波", 10, TimeUnit.MINUTES);
      33. log.info("RedisTemplate操作Redis集群结束...");
      34. return "执行成功";
      35. }
      36. }

      4.3测试验证

      使用Postman测试。

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

      5.小结

      使用RedisTemplate操作Redis集群和Redis单机版两种场景。

      差异:在application.yml配置中,使用集群时配置节点使用spring.redis.cluster.nodes配置IP和端口;单机版时,使用spring.redis.host配置IP和使用spring.redis.port配置端口。

      共同:其它方面基本相同。

      以上,感谢。

      2023年6月8日

    27. 相关阅读:
      MCU软核 2. Xilinx Artix7上运行tinyriscv
      用docker部署公司的一个web系统
      软件外包开发文档
      新手编码指北(持续更新...)
      仅凭一图,即刻定位,AI图像定位技术
      [dp]Task Computing 2022牛客多校第4场 A
      【CEEMDAN-VMD-CNN-LSTM】双重分解+卷积神经网络+长短期记忆神经网络多变量回归预测,多变量输入模型
      个人博客类网站为什么更适合虚拟主机?
      Line Out vs Headphone Out 有什么区别
      一道数学题,让芯片巨头亏了5亿美金!
    28. 原文地址:https://blog.csdn.net/zhangbeizhen18/article/details/131114421
      • 最新文章
      • 攻防演习之三天拿下官网站群
        数据安全治理学习——前期安全规划和安全管理体系建设
        企业安全 | 企业内一次钓鱼演练准备过程
        内网渗透测试 | Kerberos协议及其部分攻击手法
        0day的产生 | 不懂代码的"代码审计"
        安装scrcpy-client模块av模块异常,环境问题解决方案
        leetcode hot100【LeetCode 279. 完全平方数】java实现
        OpenWrt下安装Mosquitto
        AnatoMask论文汇总
        【AI日记】24.11.01 LangChain、openai api和github copilot
      • 热门文章
      • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
        奉劝各位学弟学妹们,该打造你的技术影响力了!
        五年了,我在 CSDN 的两个一百万。
        Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
        面试官都震惊,你这网络基础可以啊!
        你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
        心情不好的时候,用 Python 画棵樱花树送给自己吧
        通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
        13 万字 C 语言从入门到精通保姆级教程2021 年版
        10行代码集2000张美女图,Python爬虫120例,再上征途
      Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
      正则表达式工具 cron表达式工具 密码生成工具

      京公网安备 11010502049817号