SpringCache使用和注意事项

2023-11-01 06:30

本文主要是介绍SpringCache使用和注意事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、基本原理与使用方法论

1.1、基本介绍

1.2、SpringCache具有如下特点

1.3、Spring缓存实现

1.4、声名式缓存注解

1.5、SpringBoot的支持 

1.6、开启声名式缓存支持

1.7、缓存比较

2、使用场景

2.1、条件缓存

2.2、综合运用

3、实现成果(使用Spring 与SpringCache JCache实现)

4、可运行源码地址


1、基本原理与使用方法论

1.1、基本介绍

      一个应用主要瓶颈在于数据库的IO,大家都知道内存的速度是远远快于硬盘的速度(即使固态硬盘与内容也无法比拟)。应用之中经常会遇到返回相同的数据(数据字典,行政区划树),因为这些数据变化的可能性很小。假如我们使用传统的方式每次都通过接口与数据库打交道去请求获得;是不是每次都既消耗了内存资源、网络资源、数据库资源、CPU资源,又导致大量的时间耗费在数据库查询,及远程方法调用上;从而导致程序性能的恶化。这种场景就是需要使用缓存来解决这类问题。我们把数据缓存在内存之中,以后每次获取直接内存之中获得;使得程序获得极大的性能提升。下图是我们日常Web开发之中多种缓存场景。

    日常研发中使用的缓存有如下几类不限于此:

          EhCache:此缓存框架一直伴随着Spring,Hibernate,Mybatis等等。在SpringBoot出来之前都已经广泛的使用来做为一级缓存。

         Guava: Google出品的框架,也支持缓存。

         Redis:在我们日常开发之中经常使用的;并且被大众广泛接受的速度极快的缓存。

        memcached:是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。

  本文章将介绍的缓存SpringCache,自从Spring 3.1 引入了基于注解 annotation 的缓存 cache 技术,SpringCache本质上不是一种缓存的实现,而是一种缓存的抽象。Spring此框架的原则是让使用者方便开发,也能很好的支持第三方框架集成。如同Spring实现的SpringJdbc一样。

    SpringCache 通过在现有代码之中,仅添加少量各种预先定义好的 注解 annotation,即能达到缓存方法返回对象的效果。降低了开发者使用缓存技术的学习成本。

    SpringCache 缓存技术具备相当的灵活性,不仅能够使用 SpEL(Spring Expression Language)来定义缓存的 key 和各种 condition,而且提供开箱即用的缓存临时存储方案,也支持与主流专业缓存(EHCache、Redis ....)集成。 

1.2、SpringCache具有如下特点

  • 通过少量的配置 annotation 注释即可使得既有代码支持缓存 
  • 支持开箱即用 Out-Of-The-Box,即不用安装和部署额外第三方组件即可使用缓存 
  • 支持 Spring Express Language,能使用对象的任何属性或者方法来定义缓存的 key 和 condition 
  • 支持 AspectJ,并通过其实现任何方法的缓存支持 
  • 支持自定义 key 和自定义缓存管理者,具有相当的灵活性和扩展性
  • 支持各种缓存实现,默认基于ConcurrentMap实现的ConcurrentMapCache,同时支持其他缓存实现

从以上的注解中可以看出,虽然使用注解的确方便,但是缺少灵活的缓存策略,

缓存策略:

  • TTL(Time To Live )
    存活期,即从缓存中创建时间点开始直到它到期的一个时间段(不管在这个时间段内有没有访问都将过期)

  • TTI(Time To Idle)
    空闲期,即一个数据多久没被访问将从缓存中移除的时间

项目中可能有很多缓存的TTL不相同,这时候就需要编码式使用编写缓存。

1.3、Spring缓存实现

      Spring缓存的接口:org.springframework.cache.Cache ;org.springframework.cache.CacheManager这两个接口都在context中,一个是用来提供缓存,一个是用来提供管理缓存。

CacheManager是Spring提供的各种缓存技术抽象接口,

Cache接口包含缓存的各种操作(增加、删除、获得缓存,我们一般不会直接和此接口打交道)。

Spring支持的CacheManager实现如下图: 

1.4、声名式缓存注解

Spring提供了4个注解来声明缓存规则(又是使用注解式的AOP的一个生动例子)。
所示。

@Cacheable、@CachePut、@CacheEvit都有value属性,指定的是要使用的缓存名称;key属性指定的是 
数据在缓存中的存储的键。

1.5、SpringBoot的支持 

在springboot中,已经为cache做了自动配置,如图:

在Spring Boot环境下,使用缓存技术只需在项目中导入相关缓存技术的依赖包,并在配置类使用@EnableCaching开启缓存支持即可。

1.6、开启声名式缓存支持

开启声名式缓存支持十分简单,只需在配置类上使用@EnableCaching注解即可,例如:

@Configuration
@EnableCaching
public class QixueAiApplication {
}

1.7、缓存比较

项目中注解缓存只能配置一个,所以可以通过以下引入哪个配置文件来决定使用哪个缓存。 
当然,可以通过其他配置搭配使用两个缓存机制。比如ecache做一级缓存,redis做二级缓存。 

2、使用场景

2.1、条件缓存

根据运行流程,如下@Cacheable将在执行方法之前( #result还拿不到返回值)判断condition,如果返回true,则查缓存; 

@Cacheable(value = "user", key = "#id", condition = "#id lt 10")  
public User conditionFindById(final Long id)  

如下@CachePut将在执行完方法后(#result就能拿到返回值了)判断condition,如果返回true,则放入缓存

@CachePut(value = "user", key = "#id", condition = "#result.username ne 'zhang'")  
public User conditionSave(final User user)   

  如下@CachePut将在执行完方法后(#result就能拿到返回值了)判断unless,如果返回false,则放入缓存;(即跟condition相反)

@CachePut(value = "user", key = "#user.id", unless = "#result.username eq 'zhang'")  
public User conditionSave2(final User user)   

  如下@CacheEvict, beforeInvocation=false表示在方法执行之后调用(#result能拿到返回值了);且判断condition,如果返回true,则移除缓存;

@CacheEvict(value = "user", key = "#user.id", beforeInvocation = false, condition = "#result.username ne 'zhang'") 
public User conditionDelete(final User user)

2.2、综合运用

package com.whdcmap.example.code.service;import java.util.HashSet;
import java.util.Set;import org.springframework.cache.annotation.CacheConfig;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.CachePut;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;import com.whdcmap.example.code.entity.User;/***
*@purpose:用户 使用 SpringCache 缓存
*@author:jianxiapc
*@since:2019年3月11日
***/
@Service
@CacheConfig(cacheNames = {"user", "user2"})
public class UserService {Set<User> users = new HashSet<User>();@CachePut(key = "#user.id")public User save(User user) {users.add(user);return user;}@CachePut(key = "#user.id")public User update(User user) {users.remove(user);users.add(user);return user;}@CacheEvict(key = "#user.id")public User delete(User user) {users.remove(user);return user;}@CacheEvict(allEntries = true)public void deleteAll() {users.clear();}@Cacheable(key = "#id")public User findById(final Long id) {System.out.println("cache miss, invoke find by id, id:" + id);for (User user : users) {if (user.getId().equals(id)) {return user;}}return null;}}

3、实现成果(使用Spring 与SpringCache JCache实现)

4、可运行源码地址

https://github.com/jianxia612/SpringCache.git

参考文章:https://mp.weixin.qq.com/s/z0fBCVkN7F1zIfBDzpVTsA 图片版权归于此

这篇关于SpringCache使用和注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/321119

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念