SpringBoot集成cache缓存的实现

网友投稿 242 2022-10-20


SpringBoot集成cache缓存的实现

前言

日常开发中,缓存是解决数据库压力的一种方案,通常用于频繁查询的数据,例如新闻中的热点新闻,本文记录springboot中使用cache缓存。

官方文档介绍:https://docs.spring.io/spring-boot/docs/2.1.0.RELEASE/reference/htmlsingle/#boot-features-caching-provider-generic

工程结构

代码编写

pom引入依赖,引入cache缓存,数据库使用mysql,ORM框架用jpa

org.springframework.boot

spring-boot-starter-cache

net.sf.ehcache

ehcache

org.springframework.boot

spring-boot-starter-data-jpa

mysql

mysql-connector-java

配置文件

server.port=10010

spring.application.name=springboot-cache

spring.cache.type=ehcache

spring.cache.ehcache.config=classpath:/ehcache.xml

ehcache.xml

maxElementsInMemory="1000"

eternal="false"

timeToIdleSeconds="600"

timeToLiveSeconds="0"

overflowToDisk="false">

maxElementsInMemory="1000"

eternal="false"

timeToIdleSeconds="600"

timeToLiveSeconds="0"

overflowToDisk="false">

maxElementsInMemory="1000"

eternal="false"

timeToIdleSeconds="120"

timeToLiveSeconds="0"

overflowToDisk="false">

maxElementsInMemory="1000"

eternal="false"

timeToIdleSeconds="120"

timeToLiveSeconds="0"

overflowToDisk="false">

先写一个套tb_user表的CRUD代码

@RestController

@RequestMapping("/tbUser/")

public class TbUserController {

@Autowired

private TbUserService tbUserService;

//方便测试暂时改成Gehttp://tMapping

@GetMapping("list")

// @PostMapping("list")

public List list(TbUser entityVo) {

return tbUserService.list(entityVo);

}

@GetMapping("get/{id}")

public TbUser get(@PathVariable("id")Integer id) {

return tbUserService.get(id);

}

//方便测试暂时改成GetMapping

@GetMapping("save")

// @PostMapping("save")

public TbUser save(TbUser entityVo) {

return tbUserService.save(entityVo);

}

@GetMapping("delete/{id}")

public Integer delete( @PathVariable("id") Integer id) {

return tbUserService.delete(id);

}

}

opjo实体类要实现序列化

@Entity

@Table(name = "tb_user")

@Data

public class TbUser implements Serializable {

@Id

@GeneratedValue(strategy= GenerationType.IDENTITY)

private Integer id;//表id

private String username;//用户名

private String password;//密码

private Date created;//创建时间

private Integer descriptionId;//关联详情id

}

serviceImpl中,使用注解来开启缓存

@Service

@Transactional

@CacheConfig(cacheNames = {"myCache"})

public class TbUserServiceImpl implements TbUserService{

@PersistenceContext

private EntityManager em;

@Autowired

private TbUserRepository tbUserRepository;

//@Cacheable缓存数据:key为userList,value为返回值List

@Cacheable(key = "'userList'")

@Override

public List list(TbUser entityVo) {

System.out.println("获取list用户列表缓存数据,"+new Date());

return tbUserRepository.findAll(Example.of(entityVo));

}

//@Cacheable缓存数据:key为参数id,value为返回值TbUser

@Cacheable(key = "#id")

@Override

public TbUser get(Integer id) {

System.out.println("获取数据缓存,key:"+id);

Optional optionalE = tbUserRepository.findById(id);

if (!optionalE.isPresent()) {

throw new RuntimeException("ID不存在!");

}

return optionalE.get();

}

//@CachePut缓存新增的或更新的数据到缓存,其中缓存的名称为people,数据的key是person的id

@CachePut(key = "#entityVo.id")

// @CacheEvict从缓存中删除key为参数userList的数据

@CacheEvict(key = "'userList'")

@Override

public TbUser save(TbUser entityVo) {

System.out.println("新增/更新缓存,key:"+entityVo.getId());

//entityVo传啥存啥,会全部更新

return tbUserRepository.save(entityVo);

}

//清空所有缓存

@CacheEvict(allEntries=true)

@Override

public Integer delete(Integer id) {

System.out.println("清空所有缓存");

tbUserRepository.deleteById(id);

return id;

}

}

效果演示

http://localhost:10010/tbUser/save?id=2&username=李四

调用save方法,key为2,value为当前tbUser对象的数据被缓存下来

http://localhost:10010/tbUser/get/2

当我们调用get方法时,直接获取缓存数据,控制台啥也不打印,连serviceImpl的get方法都不进去(可以打断点调试)

http://localhost:10010/tbUser/save?id=2&username=王五

当我们再次调用save方法更新username时,缓存数据也被更新

http://localhost:10010/tbUser/get/2

再次调用get接口,直接返回缓存数据,后台也是方法都不进去,啥也不打印

http://localhost:10010/tbUser/delete/2

调用delete接口,删除数据,同时删除缓存

再次调用get接口,发现缓存数据被清除,查询数据库

http://localhhttp://ost:10010/tbUser/list

首次调用list接口,key为userList的,value为用户集合数据被缓存下来,再次调用直接返回缓存数据

当调用save接口,数据更新,删除key为userList的缓存,再次调用list时,重新查库并设置缓存

我们配置了缓存发呆时间,当120秒内未使用该缓存,立即过期,一直用就会一直存在

我们先同时访问两个接口list、get,list接口2分钟后再次访问,get接口不能超过2分钟是不是访问一下,结果如预期

PS:原先使用了这个jar包,有报错

org.ehcache

ehcache

3.8.1

后面改成用上面“代码编写”里pom中引的jnet.sf.ehcache下面的ar

后记

缓存除了能缓解数据库压力,还能做用户登录状态控制,例如:用户登录成功后cookie中保存颁发的token令牌设置永不过期,缓存存活时间也设置永不过期,发呆时间设置1天,这样只有用户在1天内有访问缓存接口,那他就可以一直保留登录状态,直至有其他业务将token或者缓存清掉。

springboot使用cache缓存暂时先记录到这,后续有空再进行补充。

代码开源

代码已经开源、托管到我的github、码云:

GitHub:https://github.com/huanzi-qch/springBoot

码云http://:https://gitee.com/huanzi-qch/springBoot


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:09年将有4~6亿人民币的数据中心布线市场
下一篇:51CTO独家采访:Cisco数据中心3.0改变了什么?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~