工作中面臨日誌問題以及自己現有日誌的備份

来源:http://www.cnblogs.com/mlliud/archive/2016/03/14/5275654.html
-Advertisement-
Play Games

    問題的產生,必有其理由。說白點也就是客戶需要,沒辦法的事。不過也到給我們添了不少麻煩。本人也希望大牛們能給在下提提更多的思路,在下在此謝過。     具體是這樣:   1.要記錄操作人員,操作時間,操作相應模塊          2.要記錄操作的原始數據(ps:列級別)和變更後數據    


    問題的產生,必有其理由。說白點也就是客戶需要,沒辦法的事。不過也到給我們添了不少麻煩。本人也希望大牛們能給在下提提更多的思路,在下在此謝過。

    具體是這樣:

     1.要記錄操作人員,操作時間,操作相應模塊

         2.要記錄操作的原始數據(ps:列級別)和變更後數據

    面臨問題:

         1.各個方法相對獨立,沒有公共介面

         2.形參順序不一,類型不一以及方法名稱不一

 針對以上,要是解決其實也很簡單,主要不怕麻煩。寫個介面,每個模塊去調用,這種簡單而且有效的方法。不過模塊太多而且繁瑣這要累死個人。

   目前就我自己發現以及朋友提醒再加上資料等信息,大致將其分為2類,共四種方法:

   第一類(每個相關業務中需要手工添加執行功能部分):

        1.寫日誌操作類,在相關模塊中添加此介面調用。這種方法比較簡單,如果一開始就有這部分代碼,那就更好解決了。此種方法自不必多說,跟正常介面一樣。

        2.利用消息中間件,2和1實現類似,也需要每次都調用jms,不過論性能2比1好點

        3.利用log4j日誌記錄,相關請看:http://blog.csdn.net/ziruobing/article/details/3919501,logback也有相關

    第二類(使用Aop,攔截器等):

   1.Aop,該實現思路@BussAnnotation註解可以標示相關業務信息(ps:新增,刪除,修改等操作,以及所屬模塊等信息,aop中形參ProceedingJoinPoint可以獲取參數對象

      @Component("userManager")

 

   public class UserManagerApplogicImpl implements UserManagerApplogic {
    @BussAnnotation(moduleName="人員管理",option="添加用戶")
    public void addUser(String name) {
      System.out.println("add a User!Name is "+name);
    }
   }

 

  @Aspect
  @Component
  public class LogInterceptor {
    @Pointcut("execution(public * com.mlliud..*.addUser(..))")
    public void aApplogic() {}
    @Around(value = "aApplogic() && @annotation(annotation) &&args(object,..) ", argNames = "annotation,object")
    public Object interceptorApplogic(ProceedingJoinPoint pj,BussAnnotation annotation, Object object) throws Throwable {
      System.out.println("moduleName:"+annotation.moduleName());
      System.out.println("option:"+annotation.option());
      pj.proceed();
      return object;
    }
  } 

      2.攔截器,這個簡單日誌還好,其他目測算了吧。個人愚笨只有想到根據訪問鏈接記錄一些日誌。

      看來以上問題,針對我們項目做分析。得出一下結論:

           1.第一類在項目初期考慮或者有相關需求還好,涉及每個模塊相關代碼都要改,可以手工加入。要是項目結構複雜或者代碼量較多,我覺得很坑.....

           2.第二類aop中@BussAnnotation註解雖然可以標示些關鍵信息,但是我們畢竟要把整個vo的相關變更信息記錄。由於當時參數沒有特殊規範,以及類型沒有規劃,造成ProceedingJoinPoint獲取參數沒有規律可尋,例如:addUser(User u,int a),updateUser(User u,String x) 這種我獲取第一個參數,往資料庫中存就可以。其他你懂的....

           3.攔截器....

     寫此篇文章希望各位大神能給咱提下想法,尋找更好方法....

        也希望在此宣傳下群:189770377  希望各位大神能夠入住,多多提出好的想法。也希望學弟學妹們,能夠在此得到好的方向.

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • php獲取POST數據的三種方法php 圖片加水印源代碼php+ajax+json的一個最簡單實例php 漢字轉拼音源碼php遍歷目錄,生成目錄下每個文件的md5值並寫入到結果文件中php實現linux命令tail -fphp json_encode與json_decode使用實例php curl
  • Tcp通信過程一般為如下步驟: 伺服器綁定埠,等待客戶端連接。 客戶端通過伺服器的ip和伺服器綁定的埠連接伺服器。 伺服器和客戶端通過網路建立一條數據通路,通過這條數據通路進行數據交互。 常用API: 1. ACE_INET_Addr類。 ACE"地址"類ACE_Addr的子類,表示TCP/IP
  • 面向對象編程的基本原則:  1、設置類的屬性 用以上方法設置屬性值會有很多問題: 第一:PHP允許動態設置屬性,如果拼錯或忘記屬性名時並不會得到警告。例如錯誤地把 寫作 ,當我們輸出作者名字的時候,會有意想不到的結果。 第二:類太過鬆散,我們沒有強制設置標題、價格或者產品名稱,客戶端代碼可以確定的是
  •   電源如同人類的迴圈系統,是能源輸入輸出的地方,若是電源設計不合理,或者能量輸出不足,帶給整個電子系統都是致命的。   對於線性電源來說,有些概念必須要註意,最大功耗 PD = | Vin - Vout | x Iout;熱阻是指熱量從器件的晶片上向外傳導時受到的阻力,其單位是℃/W。那麼熱阻和最
  • Spring的另一個重要思想是AOP,面向切麵的編程,它提供了一種機制,可以在執行業務前後執行另外的代碼,Servlet中的Filter就是一種AOP思想的體現,下麵通過一個例子來感受一下. 假設我們現在需要在針對資料庫進行CRUD操作時添加一組日誌,即在執行CRUD方法前後分別加上一句話,實現簡單
  •  
  • 一個基於redis的處理session的方法,如下。 補充: php.ini文件中的session.gc_probability與session.gc_divisor兩個配置選項共同決定gc函數調用的時機。預設值分為為1和1000,表示每個請求只有1/1000的機會調用gc函數。
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...