Spring Data Redis

Spring Data Redis

一、Spring Data Redis 是什么?

可以把 Spring Data 理解成一个"数据库访问全家桶",它把各种数据库的访问都封装成统一的接口,让开发者不用去写一堆重复的"连接、关闭、异常处理"代码。Redis 作为内存数据库,自然也被收编进来,这就是 Spring Data Redis。

它的核心目标:用更少的代码,做更多的 Redis 操作,而且还能保持优雅。

二、为什么用 RedisTemplate 而不是 Jedis?

Jedis 是 Redis 官方推荐的 Java 客户端,功能齐全,但 Spring Boot 2.x 之后,默认底层换成了 Lettuce。

  • Lettuce vs Jedis:Lettuce 基于 Netty,支持异步和响应式编程,在高并发场景下表现更优秀。Jedis 是阻塞式的,多线程环境下需要自己管理连接池。
  • RedisTemplate 的优势:Spring 提供的 RedisTemplate 对底层客户端(无论是 Lettuce 还是 Jedis)做了高度封装,提供了统一的操作接口,并且支持灵活的序列化策略。
三、快速上手

引入依赖

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置文件(application.yml)

yaml 复制代码
spring:
  redis:
    host: localhost
    port: 6379
    password: yourpassword  # 如果没有密码可以删掉这行
    database: 0
    lettuce:
      pool:
        max-active: 8
        max-idle: 8
        min-idle: 0
        max-wait: -1ms

配置 RedisTemplate(解决序列化乱码问题)

java 复制代码
@Configuration
public class RedisConfig {
    
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(factory);
        
        // 使用 StringRedisSerializer 序列化 key
        template.setKeySerializer(new StringRedisSerializer());
        template.setHashKeySerializer(new StringRedisSerializer());
        
        // 使用 GenericJackson2JsonRedisSerializer 序列化 value,避免 JDK 序列化乱码
        GenericJackson2JsonRedisSerializer jsonSerializer = new GenericJackson2JsonRedisSerializer();
        template.setValueSerializer(jsonSerializer);
        template.setHashValueSerializer(jsonSerializer);
        
        template.afterPropertiesSet();
        return template;
    }
}

常用操作示例

java 复制代码
@Service
public class UserService {
    
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    
    // 存储字符串
    public void saveUser(String userId, User user) {
        redisTemplate.opsForValue().set("user:" + userId, user, 1, TimeUnit.HOURS);
    }
    
    // 获取字符串
    public User getUser(String userId) {
        return (User) redisTemplate.opsForValue().get("user:" + userId);
    }
    
    // 操作哈希(适合存储对象字段)
    public void saveUserProfile(String userId, Map<String, Object> profile) {
        redisTemplate.opsForHash().putAll("user:profile:" + userId, profile);
    }
    
    // 操作列表(消息队列)
    public void addMessage(String queue, String message) {
        redisTemplate.opsForList().rightPush(queue, message);
    }
    
    // 操作集合(去重)
    public void addUserTag(String userId, String tag) {
        redisTemplate.opsForSet().add("user:tags:" + userId, tag);
    }
    
    // 操作有序集合(排行榜)
    public void updateScore(String userId, double score) {
        redisTemplate.opsForZSet().add("leaderboard", userId, score);
    }
}
四、补充知识点

序列化器对比

序列化器 适用场景 可读性
StringRedisSerializer 纯字符串 优秀
JdkSerializationRedisSerializer Java 对象 差(乱码)
GenericJackson2JsonRedisSerializer Java 对象 优秀(JSON)

StringRedisTemplate:如果只操作字符串,可以直接用 StringRedisTemplate,它默认已经配置好了字符串序列化器。

缓存注解:Spring Data Redis 还支持 @Cacheable、@CacheEvict 等注解,可以更方便地实现缓存功能。

连接池:生产环境建议配置连接池参数,避免连接泄露。

集群支持:Spring Data Redis 支持 Redis Sentinel 和 Cluster 模式,配置方式略有不同。

相关推荐
贫民窟的勇敢爷们16 小时前
SpringBoot整合AOP切面编程实战,实现日志统一记录+接口权限校验
java·spring boot·spring
Mahir0816 小时前
Redis 与 MySQL 数据同步:一致性保证的完整解决方案
数据库·redis·mysql·缓存·面试·数据一致性
AC赳赳老秦17 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
迈巴赫车主17 小时前
Java基础:list、set、map一遍过
java·开发语言
灵犀学长17 小时前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
多加点辣也没关系18 小时前
Redis 的安装(详细教程)
数据库·redis·缓存
好家伙VCC19 小时前
【无标题】
java
数据库小学妹19 小时前
数据库连接池避坑指南:告别“连接超时”与“资源耗尽”,让系统跑得更快!
数据库·redis·sql·mysql·缓存·dba
小碗羊肉19 小时前
【JavaWeb | 第十一篇】文件上传(本地&阿里云OSS)
java·阿里云·servlet
吾疾唯君医19 小时前
Java SpringBoot集成积木报表实操记录
java·spring boot·spring·导出excel·积木报表·数据文件下载