




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、引言
在上位機(jī)開發(fā)中,日志記錄是必不可少的,我們可以通過日志記錄做日志分析及錯(cuò)誤追蹤。初學(xué)者會(huì)采用txt文本寫入來實(shí)現(xiàn)日志保存,但是文本寫入不是線程安全,當(dāng)存在多個(gè)線程同時(shí)寫入日志時(shí),就會(huì)出現(xiàn)一些問題。Log4net庫是.Net下一個(gè)非常優(yōu)秀的開源日志記錄組件,是一個(gè)幫助開發(fā)者將日志信息輸出到各種目標(biāo)(控制臺(tái)、文件、數(shù)據(jù)庫等)的工具。本節(jié)主要采用開源組件Log4Net來實(shí)現(xiàn)錯(cuò)誤ERROR信息文本存儲(chǔ),并結(jié)合SQLite數(shù)據(jù)庫,將日志INFO信息存儲(chǔ)到數(shù)據(jù)庫中,便于后續(xù)的查詢。2、開發(fā)準(zhǔn)備首先新建一個(gè)Windows窗體應(yīng)用,取名為.Log4NetSQLitePro,UI界面設(shè)計(jì)如下所示:通過Nuget添加Log4Net開源組件,如下所示:通過Nuget添加SQLite組件,如下所示:3、文本存儲(chǔ)一般情況下,我們可以將一些錯(cuò)誤及異常信息存儲(chǔ)在文本中,便于隨時(shí)打開文件進(jìn)行查詢,文本存儲(chǔ)將自動(dòng)以天為單位,每天對(duì)應(yīng)一個(gè)文件,步驟如下:添加一個(gè)應(yīng)用程序配置文件項(xiàng)目右擊添加新建項(xiàng),項(xiàng)目類型選擇應(yīng)用程序配置文件,名稱為log4net.config,如下所示:配置文件編寫日志配置文件增加相關(guān)節(jié)點(diǎn),如下所示:配置文件規(guī)定了日志信息的相關(guān)屬性、存儲(chǔ)方式、日志內(nèi)容格式等,配置信息如下所示:其中,較為重要的是日志信息的格式,對(duì)應(yīng)上面文件中的ConversionPattern,值為"[%d]%n%m%n%n",每個(gè)占位符有對(duì)應(yīng)的含義,如下所示:字符格式說明%m(message)輸出的日志消息%n(newline)換行%d(datetime)輸出當(dāng)前語句運(yùn)行的時(shí)刻%r(runtime)輸出程序執(zhí)行到當(dāng)前消耗的毫秒數(shù)%t(threadid)當(dāng)前語句所在的線程ID%p(priority)日志的當(dāng)前日志級(jí)別%c(class)當(dāng)前日志對(duì)象的名稱%L輸出語句所在的行號(hào)%F輸出語句所在的文件名%-10最小長度為10,不夠空格填充配置文件屬性中的復(fù)制到輸出目錄,設(shè)置為始終復(fù)制或如果較新則復(fù)制,如下圖所示:項(xiàng)目的AssemblyInfo.cs類中添加一行代碼,如下所示:添加一個(gè)LogHelper類,編寫2個(gè)Error的方法,如下所示:在ini文本存儲(chǔ)按鈕事件下,調(diào)用錯(cuò)誤日志寫入,如下所示:執(zhí)行完成后,在項(xiàng)目目錄,Log\Error目錄下,產(chǎn)生一條當(dāng)天日志命名的文件,打開如下所示:4、SQLite存儲(chǔ)日志信息存儲(chǔ)到數(shù)據(jù)庫的好處在于便于用戶通過界面進(jìn)行查詢,這里采用開源免費(fèi)數(shù)據(jù)庫SQLite,其他關(guān)系型數(shù)據(jù)庫,如SQLServer、mysql,原理都是一樣的,具體步驟如下所示:創(chuàng)建數(shù)據(jù)庫及數(shù)據(jù)表通過SQLiteStudio軟件創(chuàng)建一個(gè)數(shù)據(jù)庫,取名為Log4NetSQLite,執(zhí)行以下腳本創(chuàng)建一個(gè)Log數(shù)據(jù)表:將數(shù)據(jù)庫文件復(fù)制到項(xiàng)目根目錄下的DataBase文件夾中修改log4net.config文件,增加數(shù)據(jù)庫存儲(chǔ)相關(guān)配置,如下所示:bufferSize:日志緩存寫入條數(shù)設(shè)置為0時(shí)只要有一條就立刻寫到數(shù)據(jù)庫connectionString:SQLite指向的是數(shù)據(jù)庫文件的絕對(duì)路徑LogHelper類中增加一個(gè)Info方法,如下所示:在SQLite存儲(chǔ)按鈕事件下,調(diào)用Info日志寫入,如下所示:執(zhí)行完成后,打開數(shù)據(jù)庫,查看是否有相關(guān)記錄:
5、實(shí)際應(yīng)用
通過上面一系列的描述,相信大家對(duì)Log4Net的應(yīng)用有了一些了解,Log4Net構(gòu)建的日志系統(tǒng)是很多項(xiàng)目必備的一個(gè)功能,對(duì)項(xiàng)目開發(fā)、調(diào)試及后續(xù)維護(hù)都有
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 企業(yè)培訓(xùn)體系構(gòu)建及在線學(xué)習(xí)平臺(tái)
- 雨后的彩虹橋?qū)懢巴捵魑?5篇
- 2025年福建省福州市閩清縣機(jī)關(guān)事務(wù)服務(wù)中心招聘1人考前自測高頻考點(diǎn)模擬試題及完整答案詳解
- 2025廣東深圳大學(xué)彭孝軍院士團(tuán)隊(duì)專職研究員招聘2名考前自測高頻考點(diǎn)模擬試題及答案詳解(名師系列)
- 2025年福建省漳州市醫(yī)院招聘若干人考前自測高頻考點(diǎn)模擬試題有答案詳解
- 企業(yè)培訓(xùn)材料標(biāo)準(zhǔn)化制作指南
- 2025年寶應(yīng)縣公安局招聘警務(wù)輔助人員30人模擬試卷附答案詳解(模擬題)
- 2025安徽安慶醫(yī)藥高等??茖W(xué)校面向校園招聘21人考前自測高頻考點(diǎn)模擬試題及答案詳解(必刷)
- 2025內(nèi)蒙古錫林郭勒盟太仆寺旗烏蘭牧騎招聘事業(yè)編制舞蹈演員2人模擬試卷有答案詳解
- 2025湖南湘西州瀘溪縣婦幼保健計(jì)劃生育服務(wù)中心招聘高校見習(xí)生5人考前自測高頻考點(diǎn)模擬試題及答案詳解(有一套)
- 2025至2030全球及中國InfiniBand行業(yè)發(fā)展趨勢(shì)分析與未來投資戰(zhàn)略咨詢研究報(bào)告
- 2025年水資源利用與水資源安全保障體系構(gòu)建與完善資源分析可行性研究報(bào)告
- 廣東省深圳市龍華區(qū)2024-2025學(xué)年一年級(jí)上冊(cè)期中測試數(shù)學(xué)試卷(含答案)
- 宅基地爭議申請(qǐng)書
- 河南省百師聯(lián)盟2025-2026學(xué)年高二上學(xué)期9月聯(lián)考化學(xué)試題(A)含答案
- 重慶通信安全員c證題庫及答案解析
- 頸椎骨折護(hù)理圍手術(shù)期管理方案
- 新型建筑材料的實(shí)驗(yàn)檢測技術(shù)與創(chuàng)新進(jìn)展
- 2025年德州中考數(shù)學(xué)試卷及答案
- 住宅小區(qū)物業(yè)管理應(yīng)急預(yù)案方案
- 【MOOC期末】《中國馬克思主義與當(dāng)代》(北京科技大學(xué))期末慕課答案
評(píng)論
0/150
提交評(píng)論