springboot3整合redis

本文介绍了如何在SpringBoot项目中集成Redis,包括添加依赖、配置Redis连接参数,使用Spring官方提供的RedisTemplate进行操作,以及自定义RedisTemplate以支持复杂项目的需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

  <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

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

版本:springboot3.2.2    redis7.0.12

2、配置相应的yml文件:

spring:
  data:
  # redis配置
    redis:
      # Redis服务器地址
      host: 192.168.231.110
      database: 0
      # Redis服务器连接端口
      port: 6379
      # Redis服务器连接密码(默认为空)
      password: 123456
      # 连接超时时间
      timeout: 10s
      lettuce:
        pool:
          # 连接池最大连接数
          max-active: 200
          # 连接池最大阻塞等待时间(使用负值表示没有限制)
          max-wait: -1ms
          # 连接池中的最大空闲连接
          max-idle: 10
          # 连接池中的最小空闲连接
          min-idle: 0

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

3、直接进行操作

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

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


      @Resource
    private RedisTemplate<String,String> redisTmplate;

测试代码:

@Test
void ee() {

    redisTmplate.opsForValue().set("name", "李四");
    System.out.println(redisTmplate.opsForValue().get("name"));
}

运行结果:

在redis中查看:

查看具体详情:

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

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

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

redis-cli -a 123456 --raw

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

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

如StringRedisTemplate

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

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

@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate<String,Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory ){
        RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(lettuceConnectionFactory);
//        设置key序列化方式为StringRedisSerializer
        redisTemplate.setKeySerializer(new StringRedisSerializer());
//        设置value序列化方式为json,使用GenericJackSonJsonRedisSerializer替换默认的jdk序列化
        redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }
}

使用我们自定义的RedisTemplate

@Autowired
    private RedisTemplate<String,Object> redisTmplate2;

@Test
    void contextLoads() {
    List<String> list = new ArrayList<>();
    list.add("张三");
    list.add("李四");
        redisTmplate2.opsForValue().set("testList", list);
        System.out.println(redisTmplate2.opsForValue().get("testList"));
    }
}

运行结果:

redis客户端的数据:

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

### 整合 Redis 到 Spring Boot 3 的教程 在现代应用程序开发中,Redis 是一种广泛使用的内存数据存储解决方案。通过将其集成到 Spring Boot 应用程序中,可以显著提高性能并支持缓存功能。以下是关于如何在 Spring Boot 3整合 Redis 的详细说明。 #### 配置依赖项 为了使 Spring Boot 和 Redis 能够协同工作,需要引入必要的 Maven 或 Gradle 依赖项。这些依赖项提供了与 Redis 进行交互所需的功能库[^1]。 对于 Maven 构建工具,可以在 `pom.xml` 文件中添加以下内容: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!-- 如果计划使用 Lettuce 客户端 --> <dependency> <groupId>io.lettuce.core</groupId> <artifactId>lettuce-core</artifactId> </dependency> ``` 如果项目基于 Gradle,则应在 `build.gradle` 文件中加入如下配置: ```gradle implementation &#39;org.springframework.boot:spring-boot-starter-data-redis&#39; // 可选:Lettuce 客户端 implementation &#39;io.lettuce.core:lettuce-core&#39; ``` 上述依赖会自动导入所需的类和方法来操作 Redis 数据库[^2]。 --- #### 配置文件设置 完成依赖项的添加之后,在项目的 `application.properties` 或者 `application.yml` 文件中定义 Redis 的连接参数。例如: ##### 使用 application.properties: ```properties spring.redis.host=localhost spring.redis.port=6379 spring.redis.password= spring.redis.database=0 ``` ##### 使用 application.yml: ```yaml spring: redis: host: localhost port: 6379 password: "" database: 0 ``` 以上属性指定了 Redis 实例的位置以及访问权限等信息[^3]。 --- #### 创建 Redis 配置类 可以通过创建自定义配置类进一步调整默认行为或者启用特定特性。下面是一个简单的例子展示如何声明一个 Bean 来管理 RedisTemplate 对象实例化过程中的序列化策略。 ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.StringRedisTemplate; @Configuration public class RedisConfig { @Bean public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory connectionFactory){ return new StringRedisTemplate(connectionFactory); } } ``` 此代码片段展示了如何利用 Spring 提供的支持机制轻松实现对字符串键值对的操作能力提升效率的同时也增强了灵活性。 --- #### 编写服务逻辑 最后一步就是编写实际业务逻辑去调用 Redis 功能了。这里给出一段示范性的 Java 方法用于保存及检索用户登录状态记录至 Redis 缓存之中: ```java @Service public class LoginService { private final StringRedisTemplate template; public LoginService(StringRedisTemplate template) { this.template = template; } public void saveLoginStatus(String userId, boolean status) { template.opsForValue().set(userId, Boolean.toString(status)); } public Optional<Boolean> getLoginStatus(String userId) { String value = template.opsForValue().get(userId); if (value != null && !value.isEmpty()) { return Optional.of(Boolean.parseBoolean(value)); } else { return Optional.empty(); } } } ``` 这段示例演示了一个典型场景——即当某个用户的在线离线情况发生变化时更新其对应的标记位;而查询部分则负责读取当前已知的状态以便后续处理流程继续执行下去。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张乔24

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值