当前位置:   article > 正文

springboot3整合redis_springboot3集成redis

springboot3集成redis

redis在我们的日常开发中是必不可少的,本次来介绍使用spring boot整合redis实现一些基本的操作;

1、新建一个spring boot项目,并导入相应的依赖;

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-data-redis</artifactId>
  4. </dependency>

这个依赖内部已经包含了lettuce,所以我们要操作redis数据库只需要引入一个依赖即可。

版本:springboot3.2.2    redis7.0.12

2、配置相应的yml文件:

  1. spring:
  2. data:
  3. # redis配置
  4. redis:
  5. # Redis服务器地址
  6. host: 192.168.231.110
  7. database: 0
  8. # Redis服务器连接端口
  9. port: 6379
  10. # Redis服务器连接密码(默认为空)
  11. password: 123456
  12. # 连接超时时间
  13. timeout: 10s
  14. lettuce:
  15. pool:
  16. # 连接池最大连接数
  17. max-active: 200
  18. # 连接池最大阻塞等待时间(使用负值表示没有限制)
  19. max-wait: -1ms
  20. # 连接池中的最大空闲连接
  21. max-idle: 10
  22. # 连接池中的最小空闲连接
  23. min-idle: 0

在spring boot3版本之前,是spring.redis;但是在3.0版本之后,默认就是spring.data.redis。

3、直接进行操作

spring官方已经封装了用于操作redis的模板类,我们可以直接使用。

RedisTemplate是spring官方封装好的类,我们可以直接使用来进行对redis的操作。(注意使用的时候,要注入相应的泛型,不然会提示找不到相应的依赖)在spring boot3版本之前,如果不注入泛型也可以,但是在3.0版本之后,如果不指定相应的泛型,那么在启动的时候就会报错,显示找不到相应的类型

  1. @Resource
  2. private RedisTemplate<String,String> redisTmplate;

测试代码:

  1. @Test
  2. void ee() {
  3. redisTmplate.opsForValue().set("name", "李四");
  4. System.out.println(redisTmplate.opsForValue().get("name"));
  5. }

运行结果:

在redis中查看:

查看具体详情:

可以看到我们存入的“李四”是一堆乱码,这主要是redis内部的编码问题。我们只是在redis内部查看的时候显示乱码,并不影响我们在Java客户端的使用。

如果想要在redis内部也显示中文,可以在连接redis的时候在命令的最后加上 --raw

--raw选项用于指示redis-cli在交互中使用原始格式输出。

redis-cli -a 123456 --raw

我们再次进入redis的客户端,再次查看我们存入redis中的数据:

RedisTemplate有许多的子类,我们也可以使用它的子类,这样功能更强大一些;

如StringRedisTemplate

这个效果与我们使用RedisTemplate<String,String>的效果一样。

当然我们也可以自定义redis的实现逻辑,以适应我们不同的项目需求;

  1. @Configuration
  2. public class RedisConfig {
  3. @Bean
  4. public RedisTemplate<String,Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory ){
  5. RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
  6. redisTemplate.setConnectionFactory(lettuceConnectionFactory);
  7. // 设置key序列化方式为StringRedisSerializer
  8. redisTemplate.setKeySerializer(new StringRedisSerializer());
  9. // 设置value序列化方式为json,使用GenericJackSonJsonRedisSerializer替换默认的jdk序列化
  10. redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
  11. redisTemplate.setHashKeySerializer(new StringRedisSerializer());
  12. redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
  13. redisTemplate.afterPropertiesSet();
  14. return redisTemplate;
  15. }
  16. }

使用我们自定义的RedisTemplate

  1. @Autowired
  2. private RedisTemplate<String,Object> redisTmplate2;
  3. @Test
  4. void contextLoads() {
  5. List<String> list = new ArrayList<>();
  6. list.add("张三");
  7. list.add("李四");
  8. redisTmplate2.opsForValue().set("testList", list);
  9. System.out.println(redisTmplate2.opsForValue().get("testList"));
  10. }
  11. }

运行结果:

redis客户端的数据:

可以看到,我们选择自定义redis的实现之后。使用起来就方便了很多,如果是比较简单的项目,那么使用StringRedisTemplate就可以解决相应的业务问题,但是在复杂的项目中,建议还是自定义一个RedisTemplate的实现类,使用自己的实现类会更方便一些,也更利于项目的扩展。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/838838
推荐阅读
相关标签
  

闽ICP备14008679号