关于Redis的介绍、安装不在本文做介绍,可以参考Redis单机版:https://www.jianshu.com/p/3e1c3eb2db74
1、SpringBoot集成Redis
1.1 SpringBoot缓存支持
SpringBoot提供了强大的基于注解的缓存支持,通过注解配置的方式低侵入式的原有的Spring应用增加缓存功能,提升系统数据的访问性能。SpringBoot提供了多个CacheManager的实现,缓存配置类如下图所示:
1.2 新建项目
新建一个springboot-redis工程,并引入相关依赖,默认情况下spring-boot-starter-data-redis使用的是Redis工具是Lettuce,本文使用Jedis,所以需要排除Lettuce并引入Jedis,如下图所示:
org.springframework.boot
spring-boot-starter-data-redis
io.lettuce
lettuce-core
redis.clients
jedis
org.springframework.boot
spring-boot-starter-web
1.3 配置Redis
添加配置缓存,在application.yml文件中添加如下配置信息:
spring:
redis:
# redis默认数据为0
database: 0
# 服务器地址,默认为localhost
host: 172.16.6.31
# 端口,默认为6379
port: 6379
# 密码,默认为空
password: 123456
jedis:
pool:
# Redis连接池的最大连接数
max-active: 8
# Redis连接池中的最大空闲连接数
max-idle: 8
# 连接池的最大阻塞等待时间,默认为-1,表示没有限制
max-wait: -1ms
# 连接池最小连接空闲数
min-idle: 0
SpringBoot的自动配置类中提供了RedisAutoConfiguration进行Redis的配置,源码如下:
@Configuration
@ConditionalOnClass(RedisOperations.class)
@EnableConfigurationProperties(RedisProperties.class)
@Import({ LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class })
public class RedisAutoConfiguration {
@Bean
@ConditionalOnMissingBean(name = "redisTemplate")
public RedisTemplate
从上 面这段源码可以看出,application.yml中的配置信息被注入到RedisProperties.class中,如果没有开发时自己没有提供RedisTemplate或StringRedisTemplate实例,SpringBoot默认会提供这俩个实例,这俩个实例提供了Redis的基本操作方法。
- RedisTemplate:采用的序列化方案是JdkSerializationRedisSerializer,可以用来操作对象
- StringRedisTemplate:是RedisTemplate的子类,key和value都是字符串,采用的序列化方案是StringRedisSerializer
- 二者都是通过opsForValue、opsForZSet、opsForSet等方法,首先先获取一个操作对象,再使用该操作对象来完成数据的读写
1.4 新建一个实体类
User.java
public class User implements Serializable {
private Long id;
private String name;
private Integer age;
// 省略getter、setter、toString方法
}
1.5 新建单元测试
SpringbootRedisApplicationTests.java
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringbootRedisApplicationTests {
@Autowired
RedisTemplate redisTemplate;
@Autowired
StringRedisTemplate stringRedisTemplate;
@Test
public void contextLoads() {
ValueOperations operations = stringRedisTemplate.opsForValue();
operations.set("name", "小H");
System.out.println("获取name:" + operations.get("name"));
ValueOperations operations1 = redisTemplate.opsForValue();
User user = new User();
user.setId(1L);
user.setName("xiaoH");
user.setAge(29);
operations1.set("user", user);
User user1 = (User) operations1.get("user");
System.out.println("获取用户信息:" + user1);
}
}
1.6 验证
执行单元测试,结果如下:
本文由博客一文多发平台 OpenWrite 发布!