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

相关推荐
我头发多我先学12 分钟前
C++ 模板全解:从泛型编程初阶到特化、分离编译进阶
java·开发语言·c++
mfxcyh24 分钟前
使用MobaXterm配置nginx
java·服务器·nginx
木叶子---40 分钟前
Spring 枚举转换器冲突问题分析与解决
java·python·spring
standovon43 分钟前
SpringSecurity的配置
java
小小小米粒43 分钟前
redis命令集合
数据库·redis·缓存
霸道流氓气质1 小时前
SpringBoot+LangChain4j+Ollama+RAG(检索增强生成)实现私有文档向量化检索回答
java·spring boot·后端
就叫飞六吧1 小时前
Docker Hub 上主流的nginx发行
java·nginx·docker
旷世奇才李先生1 小时前
Redis高级实战:分布式锁、缓存穿透与集群部署(附实战案例)
redis·分布式·缓存
MiNG MENS1 小时前
基于SpringBoot和Leaflet的行政区划地图掩膜效果实战
java·spring boot·后端
2601_949814691 小时前
Spring Boot中的404错误:原因、影响及处理策略
java·spring boot·后端