注意:
这个是基于IDEA之快速搭建SpringBoot+MyBatis项目开发的
只是本人用来入门的学习示例,开发前请安装redis以及启动redis服务
将redis作为缓存组件在项目中使用
- 优先查询redis中是否存在该数据
- 如果没有,则访问mysql数据库
- 若mysql存在查询的数据,则返回数据,并将数据存放到redis中
一、添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-redis</artifactId>
<version>1.3.8.RELEASE</version>
</dependency>
二、配置文件
在application.yml中配置redis的一些基础配置
# redis 配置
redis :
host : 127.0.0.1
port : 6379
pool :
max-active: 100
max-idle: 10
max-wait: 100000
timeout: 0
三、redis操作方式
可以通过RedisTemplate、JedisPool和Jedis操作redis。
3.1 RedisTemplate
SpringBoot为我们操作Redis提供了两个API:
- StringRedisTemplate(默认采用的是StringRedisSerializer序列化策略)、对key value都是字符串的数据进行操作
- RedisTemplate<String,Object>(默认采用的是JdkSerializationRedisSerializer序列化策略),value可以放对象。
本质上StringRedisTemplate继承的是RedisTemplate<String,String>
3.1.1 redis配置类
创建配置类用于处理序列化,同时对实体类进行序列化(即实现Serializable 接口)
- 什么是序列化?
将 Java 对象转换成字节流的过程。- 为什么要进行序列化?
Java 对象需要在网络上传输 或者 持久化存储到文件中时,就需要对 Java 对象进行序列化处理- 实现Serializable接口有什么意义?
这个接口没有需要实现的方法。实现 Serializable 接口是为了告诉 jvm 这个类的对象可以被序列化。
@Configuration
@AutoConfigureAfter(RedisAutoConfiguration.class)
public class RedisCacheAutoConfiguration {
public RedisTemplate<String, Serializable> redisCacheTemplate(LettuceConnectionFactory redisConnectionFactory){
RedisTemplate<String, Serializable> template = new RedisTemplate<>();
//key序列化方式
template.setKeySerializer(new StringRedisSerializer());
//value序列化
template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
//value hashmap序列化
template.setConnectionFactory(redisConnectionFactory);
return template;
}
}
3.1.2 使用redis
StringRedisTemplate和RedisTemplate提供了下面几种访问数据的方法
方法 | 描述 |
---|---|
opsForValue() | 操作只有简单属性的数据 |
opsForList() | 操作含有list的数据 |
opsForSet() | 操作含有set的数据 |
opsForZSet() | 操作含有ZSet的数据 |
opsForHash() | 操作含有hash的数据 |
访问数据后,可以对对应数据使用redis的操作方法,具体操作方法可以看这个Redis入门(一)——了解Redis
3.1.3 示例
根据id查询用户数据
- 先到redis中查询时,有则返回用户list,然后再根据id过滤,存在数据则返回,否则进行下一步
- 前往数据库中根据用户id查询数据,无则返回空,有则返回数据,并存放到redis中
@Service
public class UserServiceImpl implements UserService {
@Autowired
RedisTemplate redisTemplate;//专门操作key-value都是对象的
@Autowired
private UserDao userDao;
@Override
public String selectById(String id){
List<UserBean> userBeans =redisTemplate.opsForList().range("redis_user",0,-1);
if(userBeans.size()>0){
System.out.println("redis有数据");
userBeans = userBeans.stream().filter(u->id.equals(u.getId())).collect(Collectors.toList());
if(userBeans.size()>0){
return userBeans.get(0).toString();
}
}
System.out.println("redis未找到数据,查询数据库");
//查询数据库
UserBean userBean = userDao.getUserById(id);
if(userBean!=null){
redisTemplate.opsForList().rightPush("redis_user",userBean);
return userBean.toString();
}
return "当前无该用户";
}
}
3.1.4 示例结果:
输入:
查询id为admin的用户
第一次查询时:
第二次查询:
其余redis的操作api等以后学到再补充。