SpringBoot成神之路--18.缓存机制及缓存抽象及缓存底层源码分析和使用(一)

目录

 

一、springboot缓存机制

1、JSR107

结构图

 二、spring缓存抽象

缓存的核心概念

创建springboot项目

基础环境的搭建

 缓存的使用

三、缓存底层源码分析

跟踪程序

使用默认key

 自定义key

 自定义key生成器

 动态判断索引的值

 异步操作


一、springboot缓存机制

1、JSR107

java caching定义了5个核心接口,分别是CachingProvider,ChacheManager,Chache,Entry和Expiry

CachingProvider定义了创建、配置、获取、管理和控制多个ChacheManager,一个应用可以在运行期访问多个CachingProvider。

CacheManager定义了创建、配置、获取、管理和控制多个唯一命名的Cache,这些Cache存在于CacheManger的上下文。一个CacheManager仅被一个CachingProvider所拥有。

Cache是一个类似Map的数据结构并临时存储在key为索引的值。一个Cache仅被一个CacheManager所拥有。

Entry是一个存储在Cache中的key-value对。

Expiry每一个存储在Cache中的条目有一个定义的有效期。一旦超过这个时间,条目为过期的状态。一旦过期,条目将不可访问、更新和删除。缓存有效期可以通过ExpiryPolicy设置。

结构图

 

 导入相关jar包

 二、spring缓存抽象

spring从3.1开始定义了org.springframework.cache.Cache和org.springframework.cache.CacheManager接口来统一不同的缓存技术;并支持使用JCache(JSR-107)注解简化我们开发;

Cache接口为缓存的组件规范定义,包含缓存的各种操作集合;

Cache接口下Spring提供了各种xxxCache的实现;如redisCache、EhCacheCache,ConcurrentMapCache等;

 

每次调用需要缓存功能的方法时,spring会检查指定参数的指定的目标方法是否已经被调用过;如果有就直接从缓存中获取方法调用后的结构,如果没有就调用方法

使用spring缓存抽象时我们需要关注一下两点:

1、确定方法需要被缓存以及他们的缓存策略

2、从缓存中获取之前缓存存储的数据

缓存的核心概念

 

创建springboot项目

基础环境的搭建

引入相关依赖

 

导入数据库文件

创建javabean

 

 properties中数据库配置

配置扫描mapper路径 

 创建javabean(@mapper可以去掉,因为在main方法上已经标注了mapper的扫描路径)

 查询数据库

 创建service

 创建controller

 开启驼峰命名识别

 缓存的使用

开启缓存

设置debug打印日志

 运行查询的时候mapper下面的SQL语句的时候就可以打印出语句

 给查询方法添加缓存注解

 查看Cacheable

cacheNames/value:指定缓存组件的名字;在CacheManager中管理多个Cache组件,对缓存的真正CRUD操作在Cache组件中,每一个缓存组件有自己唯一一个名字;

key:缓存数据使用的key;可以用它来指定。默认是使用方法参数的值;

keygenerator:key的生成器;可以自己指定key的生成器的组件id

      key/keygenerator任选其一

cachemanager:指定缓存管理器;或者cacheresolver指定获取解析器

condition:指定符号条件的情况下缓存;

unless:指定不符合符号条件的情况下才缓存;

sync:是否使用异步模式

 缓存实现的逻辑图

具体使用

当我们查询了第一次之后,后面在查询只会到缓存中查找

三、缓存底层源码分析

首先查看缓存自动配置类CacheAutoConfiguration

 

 通过debug可以看到它导入的是缓存的所有配置类

这上面那几个配置 只有SimpleCacheConfiguration生效了

 

 

根据缓存名字创建缓存

 查找缓存

 总结:

运行流程

1、方法运行之前,先去查询cache(缓存组件),按照cacheNames指定的名字获取;

   (cachemanager先获取相应的缓存),第一次获取缓存如果没有cache组件会自动创建。

2、去cache中查找缓存的内容,使用一个key,默认是方法的参数。key是按照某种策略生成的。默认是使用keygenerator生产的。在底层就是使用simplekeygenerator生成key;

      simplekeygenerator生成key的默认策略

如果没有参数:key=new simplekey();

如果有一个参数:key=参数的值

如果有多个参数:key=new simplekey(params)

3、没有查到缓存就调用目标方法;

4、将目标方法返回的结果,放入到缓存中。

核心:

1)、使用CacheManager(ConcurrentMapCacheManager)按照名字得到Cache(ConcurrentMapCache,底层封装cache使用的是线程安全的ConcurrentHashMap)组件

2)、key使用KeyGenerator生成的,默认是SimpleKeyGenerator

 

跟踪程序

使用默认key

设置缓存方法

运行程序,查询

 debug看到,使用的key是传入的id(2)

 

 通过key在缓存中查找

 由于缓存中没有就执行目标方法

 自定义key

缓存中可使用的一些元数据

 自定义

 运行查看key的值,可以看到是我们自定义的

 自定义key生成器

 指定自定义key生成器

重启

 

 生成key

 

 

 动态判断索引的值

 也可以写多个判断条件

 

 

 异步操作

在异步的情况下unless就不支持了

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值