使用redis作为缓存
1. 在pom.xml文件中导入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2. 在启动类中添加使用缓存的注解
@EnableCaching
3. 在application.yml中配置redis的信息
spring:
redis:
host: localhost
port: 6379
4. 在service层配置缓存注解
- 注意:配置在dao层会抛出找不到key的错误
- 解决方式1:配置在service层
- 解决方式2:自定义一种key的生成策略
/**
* 使用@CacheConfig是一个类级别的注解,允许共享缓存的名称、KeyGenerator、CacheManager 和CacheResolver。
*
* @author: 594781919@qq.com
* @date: 2018/5/17
*/
@Service
@CacheConfig(cacheNames = "user")
public class UserService {
@Autowired
private UserMapper userMapperr;
/**
* 使用@CachePut:在新增对象时就放入缓存中,一般不建议这么做,因为会造成缓存过多,也没有必要每条新增数据都放入缓存
*
* @param user
*/
public void save(User user) {
userMapperr.save(user);
}
/**
* 通过ID查询数据
* unless:true表示不保存到缓存,与condition相反
*
* @param id
* @return
*/
@Cacheable(key = "#id", unless = "#result == null")
public User getById(Integer id) {
return userMapperr.getById(id);
}
/**
* 使用@CacheEvict消除缓存,在每次对数据进行删除时,就清除缓存。
*
* @param id
*/
@CacheEvict(key = "#id")
public void delete(Integer id) {
userMapperr.delete(id);
}
/**
* 修改时建议清除缓存,而不是重新放入缓存,这样可以避免多个线程修改相同数据时,
* 最后有效的修改不是放入缓存的数据,造成数据不是最新数据。
*
* @param user
*/
@CacheEvict(key = "#user.id")
public void update(User user) {
userMapperr.update(user);
}
}