springboot缓存的使用实践
程序员文章站
2023-12-16 22:29:46
spring针对各种缓存实现,抽象出了cachemanager接口,用户使用该接口处理缓存,而无需关心底层实现。并且也可以方便的更改缓存的具体实现,而不用修改业务代码。下面...
spring针对各种缓存实现,抽象出了cachemanager接口,用户使用该接口处理缓存,而无需关心底层实现。并且也可以方便的更改缓存的具体实现,而不用修改业务代码。下面对于在springboot中使用缓存做一简单介绍:
1、添加依赖
<dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-cache</artifactid> </dependency>
2、在配置类里开启缓存,如下图所示:
3、在需要使用缓存的方法上加上注解,如下:
@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; }
@override //@cacheevict 该注解会删除people缓存中key为id 的数据 @cacheevict(value = "people", key = "#id") public void remove(long id) { system.out.println("删除了id、key为"+id+"的数据缓存"); //这里不做实际删除操作 }
@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、添加依赖
<dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-redis</artifactid> </dependency>
5、在配置文件里添加redis配置
redis.hostname=localhost redis.port=6379
6、在spring容器中配置redis
@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,完成了,其他什么都不用改,是不是很方便?
另外,要缓存的类必须序列化。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。