为啥需要缓存?
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