SpringBoot統(tǒng)計一個Bean中方法的調(diào)用次數(shù)的實現(xiàn)步驟
實現(xiàn)思路
通過AOP即可實現(xiàn),通過AOP對Bean進行代理,在每次執(zhí)行方法前或者后進行幾次計數(shù)統(tǒng)計。這個主要就是考慮好如何避免并發(fā)情況下不準,以及如何使用AOP實現(xiàn)代理。
前置條件
首先搭建一個spring boot工程,我這里用的是3x版本
搭建步驟:
新版idea創(chuàng)建springboot項目
新版idea創(chuàng)建spring boot項目的詳細教程_java_腳本之家 (jb51.net)
導入依賴:

pom.xml:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>實現(xiàn)步驟
首先我們先自定義一個注解
有了這個注解之后,我們可以在想要統(tǒng)計的方法上加上這個注解
名稱隨便起但要見名知意


代碼如下:
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 {
}接下來定義一個切面
通過該切面來對這個注解進行增強處理

代碼如下:
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)計方法上使用該注解
有了以上注解和切面后,只需要在我們想要統(tǒng)計的方法上使用該注解就行了

測試
啟動項目調(diào)用一下接口


但是需要注意的是,這個統(tǒng)計結(jié)果只在內(nèi)存中有效,如果應用發(fā)生重啟,就會歸零了。如果想要持久化保存,就需要考慮持久化存儲了,如存在mysql或者redis中。
另外,如果并發(fā)特別高,對統(tǒng)計結(jié)果要求沒那么精確,可以用LongAdder替代AtomicInteger
以上就是SpringBoot統(tǒng)計一個Bean中方法的調(diào)用次數(shù)的實現(xiàn)步驟的詳細內(nèi)容,更多關(guān)于SpringBoot統(tǒng)計Bean調(diào)用次數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringBoot使用Caffeine實現(xiàn)緩存的示例代碼
本文主要介紹了SpringBoot使用Caffeine實現(xiàn)緩存的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07
MongoDB中ObjectId的誤區(qū)及引起的一系列問題
這篇文章主要介紹了MongoDB中ObjectId的誤區(qū)及引起的一系列問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-12-12
使用SpringMVC訪問Controller接口返回400BadRequest
這篇文章主要介紹了使用SpringMVC訪問Controller接口返回400BadRequest,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
JDK動態(tài)代理接口和接口實現(xiàn)類深入詳解
這篇文章主要介紹了JDK動態(tài)代理接口和接口實現(xiàn)類,JDK動態(tài)代理是代理模式的一種實現(xiàn)方式,因為它是基于接口來做代理的,所以也常被稱為接口代理,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-06-06

