学习目标:
- Spring Boot项目如何集成Redis
- Redis实现缓存数据的创建、更新以及缓存失效操作
- 介绍如何将Redis的相关操作封装成通用的工具类
1.Spring Boot对Redis的支持
Spring Boot提供了集成Redis的组件包spring-boot-starter-data-redis,能够非常方便地集成到项目中。spring-boot-starter-data-redis组件主要依赖spring-data-redis和lettuce库。Spring Boot 1.0默认使用的是Jedis客户端,Spring Boot 2.0版本之后改为Lettuce客户端。
1.1 Jedis与Lettuce的区别
虽然Lettuce与Jedis都是连接Redis的客户端程序,但是两者在实现上还是有些不同的:
- Jedis在实现上直连Redis服务器,在多线程环境下是非线程安全的,除非使用连接池为每个Jedis实例增加物理连接。
- Lettuce基于Netty的连接实例(StatefulRedisConnection)可以在多个线程间并发访问,并且是线程安全的,它支持多线程环境下的并发访问,同时也是可伸缩的设计,在一个连接实例不够的情况下可以按需增加连接实例。
因此,SpringBoot 2.0之后将之前的Jedis改成了Lettuce。
1.2 组件的依赖关系
Spring Boot提供的Redis组件spring-boot-starter-data-redis也是基于Spring Data封装的,它们之间的依赖关系如图所示。
如图所示,spring-boot-starter-data-redis和Spring Data Redis两者是包含与被包含的关系,或者说前者更好地封装了后者。
- Lettuce:可伸缩的Redis客户端,基于Netty NIO框架来有效地管理多个连接。
- Spring Data Redis:Spring Data项目中的模块,封装了多个Redis客户端,让开发者对Redis的操作更加高效便捷。
- Spring Data:Spring框架中的重要组成部分,它极大地简化了构建基于Spring框架应用的数据操作,包括非关系数据库、Map-Reduce框架、云数据服务等,同时也支持关系数据库。
- spring-boot-starter-data-redis:Spring Boot提供的Redis集成启动器(Starter),依赖于spring-data-redis和lettuce库。
2.RedisTemplate
Spring Boot提供的Redis组件spring-boot-starter-data-redis,其中重要的是RedisTemplate。与JdbcTemplate类似,RedisTemplate是Spring针对Redis封装的一个比较强大的模板,以方便使用。只要在所需的地方注入RedisTemplate即可,无须其他额外配置,开箱即用。
RedisTemplate有两个方法经常用到:
opsForXXX()
boundXXXOps()
XXX是value(值)的数据类型。opsForXXX获取到一个操作(Operation),但是没有指定操作的key(键),可以在一个连接(事务)内操作多个key以及对应的value;boundXXXOps获取到一个指定key的操作,在一个连接内只操作这个key对应的value。
2.1 操作
RedisTemplate针对Redis的String、List、Hash、Set、ZSet五种数据类型提供了下面五个基本类来操作对应的数据类型:
- ValueOperations:针对String类型,实现简单的键-值操作。
- SetOperations:针