缓存实现方式

为啥需要缓存?

mysql关系型数据库,查询时需要磁盘IO,会消耗系统性能并且耗时,当数据变化量较小,并且响应要快的话,可以考虑使用缓存

服务端缓存方式有哪些?

服务端缓存方式:
①可以使用静态变量(jdk8及以后,静态变量是存在JVM堆上的)
②使用redis跨服务缓存,分布式应用使用redis缓存(键值对)
③使用ehcache缓存框架

代码实现(kotlin代码演示)

方式一:使用静态变量:由于是存在JVM堆上的,所以是全局共享变量,生命周期随着类的加载而加载,类的结束而结束

步骤①:定义一个全局变量
在这里插入图片描述
步骤②:跑定时任务,定时查询,查到的数据赋值给定时任务
在这里插入图片描述

方式二:使用redis跨服务缓存,分布式应用使用redis缓存(键值对)【java】

步骤①:引入redis依赖
在这里插入图片描述
步骤②:在application.properties文件下进行配置
spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password=123456
步骤③:编写redis配置类
在这里插入图片描述
步骤④:调用写入读取操作
在这里插入图片描述
在这里插入图片描述

方式三:使用ehcache缓存框架 【kotlin】,在Service层缓存,有了缓存就不走接口查询,直接将缓存的值返回,ehcache支持堆内存储和堆外磁盘存储

步骤①:引入ehcache依赖
在这里插入图片描述
步骤②:yml文件配置
在这里插入图片描述
步骤③:写ehcache管理工具类
在这里插入图片描述
在这里插入图片描述
步骤④:设置key的生成策略

在这里插入图片描述
步骤⑤:在Service类加上@CacheConfig>在这里插入图片描述
在方法上加上@Cacheable(cacheNames = [“item1”], sync = true) 改方法的内容需要缓存
在这里插入图片描述
@CacheEvict(value = [“item1”, “item2”, “item3”, “item4”, “item5”, “item6”, “item7”, “item8”, “item9”],allEntries = true) 清空全部缓存
在这里插入图片描述

参考链接:

SpringBoot整合Redis
SpringBoot整合Ehcache

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值