亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot使用@Cacheable注解實(shí)現(xiàn)緩存功能流程詳解

 更新時(shí)間:2023年01月12日 11:07:36   作者:哪 吒  
最近一直再學(xué)Spring Boot,在學(xué)習(xí)的過程中也有過很多疑問。為了解答自己的疑惑,也在網(wǎng)上查了一些資料,以下是對(duì)@Cacheable注解的一些理解

一、Spring從3.1開始支持Cache

Spring 從 3.1 開始就引入了對(duì) Cache 的支持。定義了 org.springframework.cache.Cacheorg.springframework.cache.CacheManager接口來統(tǒng)一不同的緩存技術(shù)。并支持使用 JCache(JSR-107)注解簡化我們的開發(fā)。

其使用方法和原理都類似于 Spring 對(duì)事務(wù)管理的支持,Spring Cache 是作用在方法上的,其核心思想是,當(dāng)我們?cè)谡{(diào)用一個(gè)緩存方法時(shí)會(huì)把該方法參數(shù)和返回結(jié)果作為一個(gè)鍵值對(duì)存在緩存中。

SpringBoot中提供的緩存注解@Cacheable,@Cacheable會(huì)將方法的返回值作為緩存的value,默認(rèn)將方法的參數(shù)值作為緩存的key。@Cacheable可以標(biāo)記在某個(gè)具體的方法上,也可以標(biāo)記帶一個(gè)類上,表示該類的所有方法都支持緩存。

每次調(diào)用需要緩存功能的方法時(shí),Spring 會(huì)檢查指定參數(shù)的指定目標(biāo)方法是否已經(jīng)被調(diào)用過,如果有就直接從緩存中獲取方法調(diào)用后的結(jié)果,如果沒有就調(diào)用方法并緩存結(jié)果后返回給用戶,下次調(diào)用直接從緩存中獲取。

二、@Cacheable常用屬性

  • @Cacheable添加緩存,相同條件的查詢不再查詢數(shù)據(jù)庫,而是從緩存中查詢;
  • @CachePut每次都會(huì)訪問數(shù)據(jù)庫,并更新緩存;
  • @CacheEvict清除緩存;

1、value/cacheNames

如上圖所示,這兩個(gè)屬性代表的意義相同,這兩個(gè)屬性都是用來指定緩存組件的名稱,即將方法的返回結(jié)果放在哪個(gè)緩存中,屬性定義為數(shù)組,可以指定多個(gè)緩存;

2、key

可以通過 key 屬性來指定緩存數(shù)據(jù)所使用的的 key,默認(rèn)使用的是方法調(diào)用傳過來的參數(shù)作為 key。最終緩存中存儲(chǔ)的內(nèi)容格式為:Entry<key,value> 形式。

3、condition

觸發(fā)條件。這個(gè)參數(shù)是規(guī)定這個(gè)緩存觸發(fā)的條件拼接,例如 condition="#area.id != 1",就是在id不為1的時(shí)候觸發(fā)緩存。

4、unless

排除條件。這個(gè)參數(shù)是規(guī)定這個(gè)緩存在何時(shí)不觸發(fā),例如 unless="#result == null",不對(duì)查詢結(jié)果為NULL的結(jié)果進(jìn)行緩存。

5、keyGenerator

自定義的Key策略,比如緩存的Key值就是方法名。

@Configuration
public class CacheConfig{
	@Bean
	public KeyGenerator myKeyGenerator(){
		return (target,method,params)->method.getName();
	} 
}

KeyGenerator 是Spring提供的一個(gè)函數(shù)式接口。

package org.springframework.cache.interceptor;
import java.lang.reflect.Method;
/**
 * Cache key generator. Used for creating a key based on the given method
 * (used as context) and its parameters.
 *
 * @author Costin Leau
 * @author Chris Beams
 * @author Phillip Webb
 * @since 3.1
 */
@FunctionalInterface
public interface KeyGenerator {
	/**
	 * Generate a key for the given method and its parameters.
	 * @param target the target instance
	 * @param method the method being called
	 * @param params the method parameters (with any var-args expanded)
	 * @return a generated key
	 */
	Object generate(Object target, Method method, Object... params);
}

通過@Cacheable(keyGenerator=“myKeyGenerator”)指定Key自定義的生成策略。

6、sync

是否使用異步模式,默認(rèn)是方法執(zhí)行完,以同步的方式將方法返回的結(jié)果存在緩存中。

7、cacheManager

可以用來指定緩存管理器,從哪個(gè)緩存管理器里面獲取緩存。

三、整合步驟

1、加入pom

<dependency>
   <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

2、啟動(dòng)類加@EnableCaching注解

3、controller或service加@Cacheable注解即可 四、代碼實(shí)例

package com.nezha.controller;
import com.nezha.entity.Area;
import com.nezha.service.area.AreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/area")
public class AreaController {
    @Autowired
    private AreaService areaService;
	// @Cacheable添加緩存,相同條件的查詢不再查詢數(shù)據(jù)庫,而是從緩存中查詢
    @Cacheable(cacheNames="area",key = "#id")
    @GetMapping("getAreaById")
    public Area getAreaById(Integer id) {
        return areaService.getAreaById(id);
    }
	// @CachePut每次都會(huì)訪問數(shù)據(jù)庫,并更新緩存
    @CachePut(cacheNames="area",key = "#id")
    @PostMapping("updateAreaById")
    public void updateAreaById(Integer id) {
        areaService.updateAreaById(id);
    }
	// @CacheEvict清除緩存
    @CacheEvict(cacheNames="area",key = "#id")
    @PostMapping("deleteAreaById")
    public void deleteAreaById(Integer id) {
        areaService.deleteAreaById(id);
    }
}

通過postman訪問127.0.0.1:8080/NettyProject/area/getAreaById?id=1,第一次時(shí)控制臺(tái)輸出sql日志,第二次請(qǐng)求時(shí),控制臺(tái)無日志輸出,證明未進(jìn)行sql查詢,查詢的是@Cacheable(cacheNames="area",key = "#id")緩存的數(shù)據(jù)。

到此這篇關(guān)于SpringBoot使用@Cacheable注解實(shí)現(xiàn)緩存功能流程詳解的文章就介紹到這了,更多相關(guān)SpringBoot @Cacheable內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot使用knife4j進(jìn)行在線接口調(diào)試

    SpringBoot使用knife4j進(jìn)行在線接口調(diào)試

    這篇文章主要介紹了SpringBoot使用knife4j進(jìn)行在線接口調(diào)試,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • spring依賴注入成功但在調(diào)用接口的時(shí)候拿到的依賴卻是null問題

    spring依賴注入成功但在調(diào)用接口的時(shí)候拿到的依賴卻是null問題

    這篇文章主要介紹了spring依賴注入成功但在調(diào)用接口的時(shí)候拿到的依賴卻是null問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • SpringDataJpa如何使用union多表分頁條件查詢

    SpringDataJpa如何使用union多表分頁條件查詢

    這篇文章主要介紹了SpringDataJpa如何使用union多表分頁條件查詢,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringBoot集成Druid實(shí)現(xiàn)監(jiān)控功能的示例代碼

    SpringBoot集成Druid實(shí)現(xiàn)監(jiān)控功能的示例代碼

    這篇文章主要介紹了SpringBoot集成Druid實(shí)現(xiàn)監(jiān)控功能,Druid是阿里巴巴開發(fā)的號(hào)稱為監(jiān)控而生的數(shù)據(jù)庫連接池,可以很好的監(jiān)控DB池連接和SQL的執(zhí)行情況,天生就是針對(duì)監(jiān)控而生的DB連接池,文中通過代碼示例講解非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • 使用eclipse創(chuàng)建java項(xiàng)目的方法

    使用eclipse創(chuàng)建java項(xiàng)目的方法

    這篇文章主要為大家詳細(xì)介紹了使用eclipse創(chuàng)建java項(xiàng)目的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Spring Boot2讀取配置常用方法代碼實(shí)例

    Spring Boot2讀取配置常用方法代碼實(shí)例

    這篇文章主要介紹了Spring Boot2讀取配置常用方法代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • java基于Apache FTP點(diǎn)斷續(xù)傳的文件上傳和下載

    java基于Apache FTP點(diǎn)斷續(xù)傳的文件上傳和下載

    本篇文章主要介紹了java基于Apache FTP點(diǎn)斷續(xù)傳的文件上傳和下載,利用FTP實(shí)現(xiàn)文件的上傳和下載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2016-11-11
  • Spring?Batch批處理框架操作指南

    Spring?Batch批處理框架操作指南

    Spring?Batch?是?Spring?提供的一個(gè)數(shù)據(jù)處理框架。企業(yè)域中的許多應(yīng)用程序需要批量處理才能在關(guān)鍵任務(wù)環(huán)境中執(zhí)行業(yè)務(wù)操作,這篇文章主要介紹了Spring?Batch批處理框架操作指南,需要的朋友可以參考下
    2022-07-07
  • springboot連接kafka集群的使用示例

    springboot連接kafka集群的使用示例

    在項(xiàng)目中使用kafka的場景有很多,尤其是實(shí)時(shí)產(chǎn)生的數(shù)據(jù)流,本文主要介紹了springboot連接kafka集群的使用示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • HTTP基本認(rèn)證(Basic Authentication)的JAVA實(shí)例代碼

    HTTP基本認(rèn)證(Basic Authentication)的JAVA實(shí)例代碼

    下面小編就為大家?guī)硪黄狧TTP基本認(rèn)證(Basic Authentication)的JAVA實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11

最新評(píng)論