SpringBoot日志註解與緩存優化詳解

日志註解:

關於SpringBoot中的日志處理,在之前的文章中頁寫過:

點擊進入

這次通過註解+Aop的方式來實現日志的輸出;

首先需要定義一個註解類:

 @Target(ElementType.METHOD)
 @Retention(RetentionPolicy.RUNTIME)
 @Documented
 public @interface LogAnnotation {
     String module() default "";  //模塊名
     String operation() default ""; //操作名
 }

然後定義切點:

 //定義切點
 @Pointcut("@annotation(com.xbhog.springbootvueblog.common.aop.LogAnnotation)")
 public void logPointCut() {
 }

白話文就是,註解所到之處都是切點;比較專業的解釋的話可以自行百度或者Google;

有瞭切點,那麼我們需要實現通知事件,這裡采用瞭環繞通知,也就是前後都會增強。

 //環繞  處理流之前 和之後
 @Around("logPointCut()")
 public Object around(ProceedingJoinPoint point) throws Throwable {
     long beginTime = System.currentTimeMillis();
     //執行方法
     Object result = point.proceed();
     //執行時長(毫秒)
     long time = System.currentTimeMillis() - beginTime;
     //保存日志
     recordLog(point, time);
     return result;
 }

point.proceed()就是註解下所需要執行的方法;類似於下面代碼段:

 @LogAnnotation(module = "listArticle", operation = "顯示主頁展示數據")
 public Result listArticle(@RequestBody PageParams pageParams) {
     return articleService.listArticle(pageParams);
 }

然後我們需要設置日志輸出的信息(recordLog),這裡我們通過反射來獲得相應的類名和方法名以及其他信息等。

 private void recordLog(ProceedingJoinPoint joinPoint, long time) {
     MethodSignature signature = (MethodSignature) joinPoint.getSignature();
     Method method = signature.getMethod();
     LogAnnotation logAnnotation = method.getAnnotation(LogAnnotation.class);
     log.info("=====================log start================================");
     log.info("module:{}",logAnnotation.module());
     log.info("operation:{}",logAnnotation.operation());
 ​
     //請求的方法名
     String className = joinPoint.getTarget().getClass().getName();
     String methodName = signature.getName();
     log.info("request method:{}",className + "." + methodName + "()");
 ​
     //請求的參數
     Object[] args = joinPoint.getArgs();
     String params = JSON.toJSONString(args[0]);
     log.info("params:{}",params);
 ​
     //獲取request 設置IP地址
     HttpServletRequest request = HttpContextUtils.getHttpServletRequest();
     log.info("ip:{}", IpUtils.getIpAddr(request));
 ​
 ​
     log.info("excute time : {} ms",time);
     log.info("=====================log end================================");
 }

這樣切點和切面已經完成瞭,使用的時候隻需要在方法的上面直接加註解就可以獲得對應的方法的日志信息,這樣在上線的時候遇到報錯直接就可以定位到瞭。

緩存的優化:

這個是在具體的項目中實現的,流程大體跟上面的實現類似,使用的也是註解實現的。

為什麼需要使用緩存來提高網頁內容的訪問效率,因為內存的讀取比硬盤讀取的速度快的多的多,這樣對用戶的體驗比較好,但是不是所有的數據都得放到緩存中,因為內存比磁盤貴的多,所以對哪些數據進行緩存能使得用戶和服務器均衡也需要一定的經驗。

Cache註解:

 @Target({ElementType.METHOD})
 @Retention(RetentionPolicy.RUNTIME)
 @Documented
 public @interface Cache {
     long expire() default 1 * 60 * 1000;  //存活時間
     String name() default "";  //緩存的名字
 }

這裡設置瞭數據的存活時間和名字,使得數據在一定的時間裡可以在內存中讀取數據。

接下來看下緩存的AOP實現:

直接來看下環繞通知的處理流程:

根據圖示,首先獲取類名和調用的方法名,然後設置兩個數組,一個保存參數類型一個保存參數。

遍歷參數,將其轉換成字符串,然後判斷字符串參數(params)為不為空,不為空的話,加密當前字符串參數,將當前的加密的密碼保存到Redis中,每次進入該切面的時候,需要判斷RedisValue是否為空,如果為空的話,那麼需要執行註解

下面的方法,如果不為空的話,直接從Redis中直接讀取數據顯示到前臺上。

通過日志Aop與緩存Aop的功能操作,實現效果如下:

總結

到此這篇關於SpringBoot日志註解與緩存優化的文章就介紹到這瞭,更多相關SpringBoot日志註解與緩存優化內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: