在Spring Boot中,默认集成Spring Data Redis,Spring Data Redis针对Redis提供了非常方便的操作模版RedisTemplate,并且可以进行连接池自动管理。
先导入依赖
org.springframework.boot spring-boot-starter-data-redis org.apache.commons commons-pool2 com.fasterxml.jackson.core jackson-databind com.fasterxml.jackson.datatype jackson-datatype-jsr310
写配置文件application.yml
spring:
redis:
host: 192.168.47.130
port: 6379
database: 0
password: #默认为空
timeout: 3000ms #最大等待时间,超时则抛出异常,否则请求一直等待
lettuce:
pool:
max-active: 20 #最大连接数,负值表示没有限制,默认8
max-wait: -1 #最大阻塞等待时间,负值表示没限制,默认-1
max-idle: 8 #最大空闲连接,默认8
min-idle: 0 #最小空闲连接,默认0
虚拟机启动redis
#先查看进程 ps -ef|grep redis #如果没启动,则先将redis起来,进入redis的bin目录下 bin/redis-server redis.conf #启动后可以选择性开启client(如未配置后台启动可以开启新的会话框) ./redis-cli #查看一下key的情况 keys *
在windows中开启redis desktop manager查看连接情况
连不上可以先ping一下,ping不通就是网络设置问题了,ping通连不上,建议杀死进程,重启redis。
以上就绪后,我们可以在项目中创建测试类(如下是查询数据库,存一个dict对象)
@SpringBootTest
@RunWith(SpringRunner.class)
public class RedisTemplateTests {
@Resource
private RedisTemplate redisTemplate;
@Resource
private DictMapper dictMapper;
@Test
public void saveDict(){
Dict dict = dictMapper.selectById(1);
//向数据库中存储string类型的键值对, 过期时间5分钟
redisTemplate.opsForValue().set("dict", dict, 5, TimeUnit.MINUTES);
}
}
@Configuration
public class RedisConfig {
写config配置类,配置Redis序列化方案
@Bean
public RedisTemplate redisTemplate(LettuceConnectionFactory redisConnectionFactory) {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
//首先解决key的序列化方式
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringRedisSerializer);
//解决value的序列化方式
Jackson2JsonRedisSerializer
最后进test写入测试取值
@Test
public void getDict(){
Dict dict = (Dict)redisTemplate.opsForValue().get("dict");
System.out.println(dict);
}
接下来编写实现类,具体代码就不写了,写一下逻辑
1.redisTemplate.opsForValue().get()查询出是否存在数据,如果不为null,直接取值
2.catch (Exception e),有可能出现redis失效的情况,我们选择继续执行不抛出异常log.error()
3.如果不存在则从数据库取值
4.redisTemplate.opsForValue().set()将数据存入redis后,return返回结果
以上就是一套完整的redis缓存调试及编写业务过程



