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 模式,配置方式略有不同。

相关推荐
宁小法19 小时前
Redis evalsha 可能返回的错误类型
redis·php·lua报错
ch.ju19 小时前
Java Programming Chapter 4——Inherited call
java·开发语言
是有头发的程序猿19 小时前
竞品分析 + 用户洞察自动化|基于 item_review 评论接口 + 多 AI Agent 实现淘宝评论全量采集与智能分析(附python源码)
java·python·自动化
凤凰院凶涛QAQ19 小时前
《Java版数据结构 & 集合类剖析》链表与LinkedList:节点手拉手,增删不用愁
java·数据结构·链表
唐青枫19 小时前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
码语智行19 小时前
MQTT 配置、依赖与使用说明
java·物联网·mt
_日拱一卒19 小时前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
我是一颗柠檬19 小时前
【Redis】Redis面试高频考点汇总Day15(2026年)
数据库·redis·缓存·面试
郝学胜-神的一滴19 小时前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
仙俊红19 小时前
反射到底解决什么问题?
java·开发语言