Spring Cache基本使用
前言
首先要明白什么是Spring Cache
1、Spring Cache是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能Spring Cache提供了一层抽象,底层可以切换不同的cache实现。具体就是通过CacheManager接口来统一不同的缓存技术。
2、其中CacheManager是Spring提供的各种缓存技术抽象接口。
3、针对不同的缓存技术需要实现不同的CacheManager:
CacheManager | 描述 |
---|---|
EhCacheCacheManager | 使用EhCache作为缓存技术 |
GuavaCacheManager | 使用Google的GuavaCache作为缓存技术 |
RedisCacheManager | 使用Redis作为缓存技术 |
提示:以下是本篇文章正文内容,下面案例可供参考
一、Spring Cache常用注解
注解 | 说明 |
---|---|
@EnableCaching | 开启缓存注解功能 |
@Cacheable | 在方法执行前spring先查看缓存中是否有数据,如果有数据,则直接返回缓存数据若没有数据,调用方法并将方法返回值放到缓存中,一般使用在查询方法中 |
@CachePut | 将方法的返回值放到缓存中,一般使用在添加方法中 |
@CacheEvict | 将一条或多条数据从缓存中删除,一般使用在删除和更新方法中 |
@Cacheable部分参数:(
value:缓存的名称,每个缓存名称下面可以有多个key
key:缓存的key
condition:条件,满足该条件是才缓存数据
unless:满足条件则不缓存)
@CachePut部分参数:(
value:缓存的名称,每个缓存名称下面可以有多个key
key:缓存的key)
@CacheEvict部分参数:(
value:缓存的名称,每个缓存名称下面可以有多个key
key:缓存的key)
在spring boot项目中,使用缓存技术只需在项目中导入相关缓存技术的依赖包,并在启动类上使用@EnableCaching开启缓存支持即可
例如:使用Redis作为缓存技术,只需要在pom文件中导入Spring data Redis的maven坐标即可
二、使用步骤
1.引入库
代码如下(pom.xml中):
<!--redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!--spring cache-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
2.配置yml文件
代码如下(在application.yml中):
spring:
# redis相关配置,目前用的是虚拟机中的redis
redis:
host: 输入redis服务器的ip
port: 6379
database: 0 # 表示在redis中默认使用的数据库号
password: 输入自己的密码
cache:
redis:
time-to-live: 1800000 #设置缓存过期时间
3、在需要加入缓存的方法上加入对应注解
首先在需要的类中注入CacheManager,如图:
最后在方法上加入对应的注解:如图例:
三、总结
以上就是今天要讲的内容,本文仅仅简单介绍了Spring Cache的基本使用,而Spring Cache提供了大量处理数据的方法。