基于Log4Net實現日志信息存儲至數據庫_第1頁
基于Log4Net實現日志信息存儲至數據庫_第2頁
基于Log4Net實現日志信息存儲至數據庫_第3頁
基于Log4Net實現日志信息存儲至數據庫_第4頁
基于Log4Net實現日志信息存儲至數據庫_第5頁
已閱讀5頁,還剩8頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、引言

在上位機開發(fā)中,日志記錄是必不可少的,我們可以通過日志記錄做日志分析及錯誤追蹤。初學者會采用txt文本寫入來實現日志保存,但是文本寫入不是線程安全,當存在多個線程同時寫入日志時,就會出現一些問題。Log4net庫是.Net下一個非常優(yōu)秀的開源日志記錄組件,是一個幫助開發(fā)者將日志信息輸出到各種目標(控制臺、文件、數據庫等)的工具。本節(jié)主要采用開源組件Log4Net來實現錯誤ERROR信息文本存儲,并結合SQLite數據庫,將日志INFO信息存儲到數據庫中,便于后續(xù)的查詢。2、開發(fā)準備首先新建一個Windows窗體應用,取名為.Log4NetSQLitePro,UI界面設計如下所示:通過Nuget添加Log4Net開源組件,如下所示:通過Nuget添加SQLite組件,如下所示:3、文本存儲一般情況下,我們可以將一些錯誤及異常信息存儲在文本中,便于隨時打開文件進行查詢,文本存儲將自動以天為單位,每天對應一個文件,步驟如下:添加一個應用程序配置文件項目右擊添加新建項,項目類型選擇應用程序配置文件,名稱為log4net.config,如下所示:配置文件編寫日志配置文件增加相關節(jié)點,如下所示:配置文件規(guī)定了日志信息的相關屬性、存儲方式、日志內容格式等,配置信息如下所示:其中,較為重要的是日志信息的格式,對應上面文件中的ConversionPattern,值為"[%d]%n%m%n%n",每個占位符有對應的含義,如下所示:字符格式說明%m(message)輸出的日志消息%n(newline)換行%d(datetime)輸出當前語句運行的時刻%r(runtime)輸出程序執(zhí)行到當前消耗的毫秒數%t(threadid)當前語句所在的線程ID%p(priority)日志的當前日志級別%c(class)當前日志對象的名稱%L輸出語句所在的行號%F輸出語句所在的文件名%-10最小長度為10,不夠空格填充配置文件屬性中的復制到輸出目錄,設置為始終復制或如果較新則復制,如下圖所示:項目的AssemblyInfo.cs類中添加一行代碼,如下所示:添加一個LogHelper類,編寫2個Error的方法,如下所示:在ini文本存儲按鈕事件下,調用錯誤日志寫入,如下所示:執(zhí)行完成后,在項目目錄,Log\Error目錄下,產生一條當天日志命名的文件,打開如下所示:4、SQLite存儲日志信息存儲到數據庫的好處在于便于用戶通過界面進行查詢,這里采用開源免費數據庫SQLite,其他關系型數據庫,如SQLServer、mysql,原理都是一樣的,具體步驟如下所示:創(chuàng)建數據庫及數據表通過SQLiteStudio軟件創(chuàng)建一個數據庫,取名為Log4NetSQLite,執(zhí)行以下腳本創(chuàng)建一個Log數據表:將數據庫文件復制到項目根目錄下的DataBase文件夾中修改log4net.config文件,增加數據庫存儲相關配置,如下所示:bufferSize:日志緩存寫入條數設置為0時只要有一條就立刻寫到數據庫connectionString:SQLite指向的是數據庫文件的絕對路徑LogHelper類中增加一個Info方法,如下所示:在SQLite存儲按鈕事件下,調用Info日志寫入,如下所示:執(zhí)行完成后,打開數據庫,查看是否有相關記錄:

5、實際應用

通過上面一系列的描述,相信大家對Log4Net的應用有了一些了解,Log4Net構建的日志系統(tǒng)是很多項目必備的一個功能,對項目開發(fā)、調試及后續(xù)維護都有

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論