1、引言
在上位機(jī)開發(fā)中,日志記錄是必不可少的,我們可以通過日志記錄做日志分析及錯誤追蹤。初學(xué)者會采用txt文本寫入來實(shí)現(xiàn)日志保存,但是文本寫入不是線程安全,當(dāng)存在多個線程同時寫入日志時,就會出現(xiàn)一些問題。Log4net庫是.Net下一個非常優(yōu)秀的開源日志記錄組件,是一個幫助開發(fā)者將日志信息輸出到各種目標(biāo)(控制臺、文件、數(shù)據(jù)庫等)的工具。本節(jié)主要采用開源組件Log4Net來實(shí)現(xiàn)錯誤ERROR信息文本存儲,并結(jié)合SQLite數(shù)據(jù)庫,將日志INFO信息存儲到數(shù)據(jù)庫中,便于后續(xù)的查詢。
2、開發(fā)準(zhǔn)備
首先新建一個Windows窗體應(yīng)用,取名為thinger.cn.Log4NetSQLitePro,UI界面設(shè)計(jì)如下所示:
通過Nuget添加Log4Net開源組件,如下所示:
通過Nuget添加SQLite組件,如下所示:
3、文本存儲
一般情況下,我們可以將一些錯誤及異常信息存儲在文本中,便于隨時打開文件進(jìn)行查詢,文本存儲將自動以天為單位,每天對應(yīng)一個文件,步驟如下:
添加一個應(yīng)用程序配置文件
項(xiàng)目右擊添加新建項(xiàng),項(xiàng)目類型選擇應(yīng)用程序配置文件,名稱為log4net.config,如下所示:
配置文件編寫
日志配置文件增加相關(guān)節(jié)點(diǎn),如下所示:
配置文件規(guī)定了日志信息的相關(guān)屬性、存儲方式、日志內(nèi)容格式等,配置信息如下所示:
其中,較為重要的是日志信息的格式,對應(yīng)上面文件中的ConversionPattern,值為"[%d]%n%m%n%n",每個占位符有對應(yīng)的含義,如下所示:
配置文件屬性中的復(fù)制到輸出目錄,設(shè)置為始終復(fù)制或如果較新則復(fù)制,如下圖所示:
項(xiàng)目的AssemblyInfo.cs類中添加一行代碼,如下所示:
添加一個LogHelper類,編寫2個Error的方法,如下所示:
在ini文本存儲按鈕事件下,調(diào)用錯誤日志寫入,如下所示:
執(zhí)行完成后,在項(xiàng)目目錄,LogError目錄下,產(chǎn)生一條當(dāng)天日志命名的文件,打開如下所示:
4、SQLite存儲
日志信息存儲到數(shù)據(jù)庫的好處在于便于用戶通過界面進(jìn)行查詢,這里采用開源免費(fèi)數(shù)據(jù)庫SQLite,其他關(guān)系型數(shù)據(jù)庫,如SQLServer、mysql,原理都是一樣的,具體步驟如下所示:
創(chuàng)建數(shù)據(jù)庫及數(shù)據(jù)表
通過SQLiteStudio軟件創(chuàng)建一個數(shù)據(jù)庫,取名為Log4NetSQLite,執(zhí)行以下腳本創(chuàng)建一個Log數(shù)據(jù)表:
將數(shù)據(jù)庫文件復(fù)制到項(xiàng)目根目錄下的DataBase文件夾中
修改log4net.config文件,增加數(shù)據(jù)庫存儲相關(guān)配置,如下所示:
bufferSize:日志緩存寫入條數(shù) 設(shè)置為0時只要有一條就立刻寫到數(shù)據(jù)庫
connectionString:SQLite指向的是數(shù)據(jù)庫文件的絕對路徑
LogHelper類中增加一個Info方法,如下所示:
在SQLite存儲按鈕事件下,調(diào)用Info日志寫入,如下所示:
執(zhí)行完成后,打開數(shù)據(jù)庫,查看是否有相關(guān)記錄:
5、實(shí)際應(yīng)用
通過上面一系列的描述,相信大家對Log4Net的應(yīng)用有了一些了解,Log4Net構(gòu)建的日志系統(tǒng)是很多項(xiàng)目必備的一個功能,對項(xiàng)目開發(fā)、調(diào)試及后續(xù)維護(hù)都有著至關(guān)重要的作用。實(shí)際使用時,我們還可以將Log4Ne作為一個簡單的數(shù)據(jù)存儲工具,甚至可以使用Log4Net做多表多庫存儲等等,大家在工作中,會經(jīng)常用到。
-
數(shù)據(jù)庫
+關(guān)注
關(guān)注
7文章
3852瀏覽量
64724 -
日志系統(tǒng)
+關(guān)注
關(guān)注
0文章
8瀏覽量
7024 -
上位機(jī)
+關(guān)注
關(guān)注
27文章
945瀏覽量
55034
發(fā)布評論請先 登錄
相關(guān)推薦
Nginx日志分割方案
![Nginx<b class='flag-5'>日志</b>分割方案](https://file1.elecfans.com/web2/M00/8A/12/wKgZomSP_3aAPX5RAABNGx6ombc713.png)
logcat如何查看Andriod log系統(tǒng)日志?
MySQL中的redo log是什么
詳解MySQL三大日志的作用
log4j日志框架分析
![<b class='flag-5'>log4</b>j<b class='flag-5'>日志</b>框架分析](https://file.elecfans.com/web2/M00/94/E9/pYYBAGP9n36ARCiXAAGH2W3m17o808.png)
針對大量log日志快速定位錯誤地方
C#上位機(jī)開發(fā)(十三)之使用Log4net添加日志記錄功能
![C#上位機(jī)開發(fā)(十三)之使用<b class='flag-5'>Log4net</b>添加<b class='flag-5'>日志</b>記錄功能](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
Spring Boot的日志框架使用
![Spring Boot的<b class='flag-5'>日志</b>框架使用](https://file1.elecfans.com/web2/M00/89/1C/wKgaomR5WwmAXhoOAAJ-EercJrA306.jpg)
基于Rust的Log日志庫介紹
保護(hù)Log4j日志中的敏感數(shù)據(jù),兩步搞定!
Log4cpp優(yōu)勢及優(yōu)點(diǎn)
![<b class='flag-5'>Log4</b>cpp優(yōu)勢及優(yōu)點(diǎn)](https://file1.elecfans.com/web2/M00/AF/06/wKgZomVMe4OAfI4oAAJ9PjTiDQ0235.jpg)
評論