spring针对各种缓存实现,抽象出了cachemanager接口,用户使用该接口处理缓存,而无需关心底层实现。并且也可以方便的更改缓存的具体实现,而不用修改业务代码。下面对于在springboot中使用缓存做一简单介绍:
1、添加依赖
1
2
3
4
|
<dependency>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-starter-cache</artifactid>
</dependency>
|
2、在配置类里开启缓存,如下图所示:
3、在需要使用缓存的方法上加上注解,如下:
1
2
3
4
5
6
7
8
|
@override
//@cacheput 该注解会将方法的返回值缓存起来,其中缓存名字是 people,数据的key是person的id
@cacheput (value = "people" , key = "#person.id" )
public person save(person person) {
person p = personrepository.save(person);
system.out.println( "为id、key为:" +p.getid()+ "数据做了缓存" );
return p;
}
|
1
2
3
4
5
6
7
|
@override
//@cacheevict 该注解会删除people缓存中key为id 的数据
@cacheevict (value = "people" , key = "#id" )
public void remove( long id) {
system.out.println( "删除了id、key为" +id+ "的数据缓存" );
//这里不做实际删除操作
}
|
1
2
3
4
5
6
7
8
9
|
@override
//@cacheable 该注解会在方法执行时,判断缓存people中key为#person.id
的缓存是否存在,如果存在,则直接返回缓存中的数据。如果不存在,则会查数据库,然后将返回结果缓存起来。
@cacheable (value = "people" , key = "#person.id" )
public person findone(person person) {
person p = personrepository.findone(person.getid());
system.out.println( "为id、key为:" +p.getid()+ "数据做了缓存" );
return p;
}
|
以上几部就完成了缓存,但是现在的缓存是默认的基于内存的,没有实现持久化。下面以redis作为缓存的具体实现,如下:
4、添加依赖
1
2
3
4
|
<dependency>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-starter-redis</artifactid>
</dependency>
|
5、在配置文件里添加redis配置
1
2
|
redis.hostname=localhost
redis.port= 6379
|
6、在spring容器中配置redis
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
@configuration
public class redisconfig extends cachingconfigurersupport{
private static final logger logger = loggerfactory.getlogger(redisconfig. class );
@autowired
private environment env;
@bean
public jedisconnectionfactory redisconnectionfactory() {
jedisconnectionfactory redisconnectionfactory = new jedisconnectionfactory();
redisconnectionfactory.sethostname(env.getproperty( "redis.hostname" ));
redisconnectionfactory.setport(integer.parseint(env.getproperty( "redis.port" )));
return redisconnectionfactory;
}
@bean
public redistemplate<string, string> redistemplate(redisconnectionfactory cf) {
redistemplate<string, string> redistemplate = new redistemplate<>();
redistemplate.setconnectionfactory(cf);
return redistemplate;
}
@bean
public cachemanager cachemanager(redistemplate<?, ?> redistemplate) {
rediscachemanager cachemanager = new rediscachemanager(redistemplate);
cachemanager.setdefaultexpiration( 600 );
return cachemanager;
}
}
|
ok,完成了,其他什么都不用改,是不是很方便?
另外,要缓存的类必须序列化。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/luckyxl029/article/details/79420334