springbioot使用lettuce集成redis

本文介绍了SpringBoot从1.5.x升级到2.x后,默认Redis客户端由Jedis变为Lettuce,并提供了如何配置Lettuce连接池以及自定义RedisTemplate的方法,包括配置项如shutdown-timeout、pool参数,以及序列化方式的设置。同时展示了如何在代码中使用RedisTemplate进行数据存取。

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

在 springboot 1.5.x版本的默认的Redis客户端是 Jedis实现的,springboot 2.x版本中默认客户端是用 lettuce实现的。

添加依赖

 <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
        </dependency>
</dependencies>

配置

spring:
  redis:
    lettuce:
      shutdown-timeout: 100
      pool:
        max-active: 200
        max-wait: 30
        max-idle: 8
        min-idle: 8
    port: 6379
    cluster:
      nodes: '10.0.17.15:36379,10.0.17.15:36479,10.0.17.15:36579'

自定义redisTemplate

@Configuration
@EnableAutoConfiguration
@Slf4j
public class RedisConfig {

    @Bean("redisTemplate")
    public RedisTemplate<String, Object> getRedisTemplate(LettuceConnectionFactory connectionFactory){
    	RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
        redisTemplate.setConnectionFactory(connectionFactory);
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        // 设置value的序列化规则
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        // 设置key序列-String序列化
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashValueSerializer(new StringRedisSerializer());
        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }
}

使用

    public PaidMemberCardDTO findByActiveUser(Long userId) {
        PaidMemberCardDTO card = (PaidMemberCardDTO) redisTemplate.opsForValue().get(RedisConstant.PAID_MEMBER_CARD + userId);
        if (card == null) {
            card = memberCardMapper.findActiveCardByUser(userId);
            redisTemplate.opsForValue().set(RedisConstant.ACTIVE_CARD + userId, 
            }
        }
        return card;
    }
Spring Boot与RabbitMQ集成主要用于利用Spring Boot简化RabbitMQ的配置和管理,但在Spring Boot中整合Redis通常通过Lettuce库来实现。Lettuce是一个高效的Redis客户端,它提供了一种简单的方式来连接、操作和管理Redis数据库。 以下是使用LettuceSpring Boot项目中配置Redis的基本步骤: 1. 添加依赖:在你的`pom.xml`或`build.gradle`文件中添加Spring Data RedisLettuce的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>io.lettuce</groupId> <artifactId>lettuce-core</artifactId> </dependency> ``` 2. 配置Redis:在`application.properties`或`application.yml`文件中设置Redis的相关信息,如主机名、端口和密码等: ``` spring.redis.host=localhost spring.redis.port=6379 spring.redis.password=your-password ``` 3. 创建RedisTemplate:在Spring Boot配置类中,注入`RedisConnectionFactory`并创建`RedisTemplate`实例: ```java @Bean public LettuceConnectionFactory redisConnectionFactory() { return new LettuceConnectionFactory("localhost", 6379); } @Bean public StringRedisTemplate stringRedisTemplate() { return new StringRedisTemplate(redisConnectionFactory()); } ``` 4. 使用RedisTemplate:现在你可以使用`StringRedisTemplate`来执行各种Redis操作,如set、get、delete等: ```java @Autowired private StringRedisTemplate stringRedisTemplate; public void set(String key, String value) { stringRedisTemplate.opsForValue().set(key, value); } public String get(String key) { return stringRedisTemplate.opsForValue().get(key); } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值