欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot統(tǒng)計(jì)一個Bean中方法的調(diào)用次數(shù)的實(shí)現(xiàn)步驟

 更新時(shí)間:2024年01月28日 09:03:46   作者:蒾酒  
這篇文章主要給大家介紹了SpringBoot統(tǒng)計(jì)一個Bean中方法的調(diào)用次數(shù)的實(shí)現(xiàn)步驟,文中通過代碼示例和圖文結(jié)合的方式給大家講解的非常詳細(xì),對大家的學(xué)習(xí)具有一定的幫助,需要的朋友可以參考下

實(shí)現(xiàn)思路

通過AOP即可實(shí)現(xiàn),通過AOP對Bean進(jìn)行代理,在每次執(zhí)行方法前或者后進(jìn)行幾次計(jì)數(shù)統(tǒng)計(jì)。這個主要就是考慮好如何避免并發(fā)情況下不準(zhǔn),以及如何使用AOP實(shí)現(xiàn)代理。

前置條件

首先搭建一個spring boot工程,我這里用的是3x版本

搭建步驟:

新版idea創(chuàng)建springboot項(xiàng)目

新版idea創(chuàng)建spring boot項(xiàng)目的詳細(xì)教程_java_腳本之家 (jb51.net)

導(dǎo)入依賴:

pom.xml:

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

實(shí)現(xiàn)步驟

首先我們先自定義一個注解

有了這個注解之后,我們可以在想要統(tǒng)計(jì)的方法上加上這個注解

名稱隨便起但要見名知意

代碼如下:

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
 
/**
 * @author mijiupro
 */
 
 
@Retention(RetentionPolicy.RUNTIME)// 指定注解的保留策略為RUNTIME
@Target(ElementType.METHOD)// 指定該注解可以用于方法
public @interface MethodCallCount {
}

接下來定義一個切面

通過該切面來對這個注解進(jìn)行增強(qiáng)處理

代碼如下:

import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
 
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicInteger;
 
/**
 * @author mijiupro
 */
 
@Aspect// 聲明這是一個切面
@Component// 聲明這是一個Spring Bean(交給Spring管理)
@Slf4j
public class MethodCallCountAspect {
    // 用于存儲方法調(diào)用次數(shù)的Map,使用ConcurrentMap保證線程安全
    private final Map<String, AtomicInteger> counterMap = new ConcurrentHashMap<>();
    @Around("@annotation(com.mijiu.commom.aop.annotation.MethodCallCount)")
    public Object methodCallCountAspect(ProceedingJoinPoint joinPoint) {
 
        String methodName = joinPoint.getSignature().toShortString();
        try{
            return joinPoint.proceed();
        }catch (Throwable ignored){
        //異常處理
            return null;
        }finally {
            AtomicInteger counter = counterMap.computeIfAbsent(methodName,k -> new AtomicInteger(0));
            counter.incrementAndGet();
            log.info("方法 {} 調(diào)用次數(shù):{}", methodName, counter.get());
        }
 
    }
 
    // 提供一個方法,用于獲取方法調(diào)用次數(shù)的Map
    public Map<String, AtomicInteger> getCounterMap() {
        return new ConcurrentHashMap<>(counterMap);
    }
}

需要統(tǒng)計(jì)方法上使用該注解

有了以上注解和切面后,只需要在我們想要統(tǒng)計(jì)的方法上使用該注解就行了

測試

啟動項(xiàng)目調(diào)用一下接口

但是需要注意的是,這個統(tǒng)計(jì)結(jié)果只在內(nèi)存中有效,如果應(yīng)用發(fā)生重啟,就會歸零了。如果想要持久化保存,就需要考慮持久化存儲了,如存在mysql或者redis中。

另外,如果并發(fā)特別高,對統(tǒng)計(jì)結(jié)果要求沒那么精確,可以用LongAdder替代AtomicInteger

以上就是SpringBoot統(tǒng)計(jì)一個Bean中方法的調(diào)用次數(shù)的實(shí)現(xiàn)步驟的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot統(tǒng)計(jì)Bean調(diào)用次數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringBoot使用Caffeine實(shí)現(xiàn)緩存的示例代碼

    SpringBoot使用Caffeine實(shí)現(xiàn)緩存的示例代碼

    本文主要介紹了SpringBoot使用Caffeine實(shí)現(xiàn)緩存的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    這篇文章主要介紹了MongoDB中ObjectId的誤區(qū)及引起的一系列問題,非常不錯,具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-12-12
  • 參數(shù)校驗(yàn)Spring的@Valid注解用法解析

    參數(shù)校驗(yàn)Spring的@Valid注解用法解析

    這篇文章主要介紹了參數(shù)校驗(yàn)Spring的@Valid注解用法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • 深入理解Spring Boot的日志管理

    深入理解Spring Boot的日志管理

    這篇文章主要給大家深入的介紹了Spring Boot日志管理的相關(guān)資料,文中介紹的很詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • Java 深入探討設(shè)計(jì)模式之原型模式篇

    Java 深入探討設(shè)計(jì)模式之原型模式篇

    設(shè)計(jì)模式(Design pattern)是一套被反復(fù)使用、多數(shù)人知曉的、經(jīng)過分類編目的、代碼設(shè)計(jì)經(jīng)驗(yàn)的總結(jié)。使用設(shè)計(jì)模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性
    2021-10-10
  • 使用SpringMVC訪問Controller接口返回400BadRequest

    使用SpringMVC訪問Controller接口返回400BadRequest

    這篇文章主要介紹了使用SpringMVC訪問Controller接口返回400BadRequest,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java線程中斷interrupt的常用方法

    Java線程中斷interrupt的常用方法

    本文主要介紹了Java線程中斷interrupt的常用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • JAVA實(shí)現(xiàn)301永久重定向方法

    JAVA實(shí)現(xiàn)301永久重定向方法

    本篇文章給大家總結(jié)了JAVA中實(shí)現(xiàn)永久重定向的方法以及詳細(xì)代碼,對此有需要的朋友可以參考學(xué)習(xí)下。
    2018-04-04
  • SpringBoot中的自動裝配原理解析

    SpringBoot中的自動裝配原理解析

    這篇文章主要介紹了SpringBoot中的自動裝配原理解析,自動裝配就是指 Spring 容器在不使用<constructor-arg>和<property>標(biāo)簽的情況下,可以自動裝配(autowire)相互協(xié)作的Bean之間的關(guān)聯(lián)關(guān)系,將一個 Bean注入其他Bean的Property中,需要的朋友可以參考下
    2023-08-08
  • JDK動態(tài)代理接口和接口實(shí)現(xiàn)類深入詳解

    JDK動態(tài)代理接口和接口實(shí)現(xiàn)類深入詳解

    這篇文章主要介紹了JDK動態(tài)代理接口和接口實(shí)現(xiàn)類,JDK動態(tài)代理是代理模式的一種實(shí)現(xiàn)方式,因?yàn)樗腔诮涌趤碜龃淼?所以也常被稱為接口代理,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06

最新評論