SpringCache
每次都那样写缓存太麻烦了,spring从3.1开始定义了Cache、CacheManager接口来统一不同的缓存技术。并支持使用JCache(JSR-107)注解简化我们的开发Cache接口的实现包括RedisCache、EhCacheCache、ConcurrentMapCache等每次调用需要缓存功能的方法时,spring会检查检查指定参数的指定的目标方法是否已经被调用过;
如果有就直接从缓存中获取方法调用后的结果,如果没有就调用方法并缓存结果后返回给用户。下次调用直接从缓存中获取。
- 使用Spring缓存抽象时我们需要关注以下两点:
1、确定方法需要缓存以及他们的缓存策略
2、从缓存中读取之前缓存存储的数据
一、配置
- 依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<!--使用redis作为缓存-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>
- 指定缓存类型并在主配置类上加上注解
@EnableCaching
@EnableCaching//开启缓存注解
public class AchangmallProductApplication {
public static void main(String[] args) {
SpringApplication.run(AchangmallProductApplication.class, args);
}
}
spring:
cache:
#指定缓存类型为redis
type: redis
redis:
# 指定redis中的过期时间为1h
time-to-live: 3600000
key-prefix:

本文详细介绍了Spring Cache的使用,包括配置Redis作为缓存、自定义缓存管理器以及注解@Cacheable和@CacheEvict的运用。通过示例展示了如何配置Redis缓存,并讨论了缓存的读写模式,如缓存穿透、缓存击穿和缓存雪崩的解决方案。最后,文章探讨了Spring Cache的原理及其局限性。
最低0.47元/天 解锁文章
690

被折叠的 条评论
为什么被折叠?



