最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

【新閣教育】基于Log4Net實(shí)現(xiàn)日志信息雙向存儲(chǔ)(含源碼)

2020-09-11 14:46 作者:新閣教育  | 我要投稿


1、引言

在上位機(jī)開(kāi)發(fā)中,日志記錄是必不可少的,我們可以通過(guò)日志記錄做日志分析及錯(cuò)誤追蹤。初學(xué)者會(huì)采用txt文本寫(xiě)入來(lái)實(shí)現(xiàn)日志保存,但是文本寫(xiě)入不是線程安全,當(dāng)存在多個(gè)線程同時(shí)寫(xiě)入日志時(shí),就會(huì)出現(xiàn)一些問(wèn)題。Log4net庫(kù)是.Net下一個(gè)非常優(yōu)秀的開(kāi)源日志記錄組件,是一個(gè)幫助開(kāi)發(fā)者將日志信息輸出到各種目標(biāo)(控制臺(tái)、文件、數(shù)據(jù)庫(kù)等)的工具。本節(jié)主要采用開(kāi)源組件Log4Net來(lái)實(shí)現(xiàn)錯(cuò)誤ERROR信息文本存儲(chǔ),并結(jié)合SQLite數(shù)據(jù)庫(kù),將日志INFO信息存儲(chǔ)到數(shù)據(jù)庫(kù)中,便于后續(xù)的查詢。+vx:xiketang777領(lǐng)取源碼

2、開(kāi)發(fā)準(zhǔn)備

  • 首先新建一個(gè)Windows窗體應(yīng)用,取名為thinger.cn.Log4NetSQLitePro,UI界面設(shè)計(jì)如下所示:


  • 通過(guò)Nuget添加Log4Net開(kāi)源組件,如下所示:


  • 通過(guò)Nuget添加SQLite組件,如下所示:


3、文本存儲(chǔ)

一般情況下,我們可以將一些錯(cuò)誤及異常信息存儲(chǔ)在文本中,便于隨時(shí)打開(kāi)文件進(jìn)行查詢,文本存儲(chǔ)將自動(dòng)以天為單位,每天對(duì)應(yīng)一個(gè)文件,步驟如下:

  • 添加一個(gè)應(yīng)用程序配置文件項(xiàng)目右擊添加新建項(xiàng),項(xiàng)目類(lèi)型選擇應(yīng)用程序配置文件,名稱(chēng)為log4net.config,如下所示:


  • 配置文件編寫(xiě)日志配置文件增加相關(guān)節(jié)點(diǎn),如下所示:


配置文件規(guī)定了日志信息的相關(guān)屬性、存儲(chǔ)方式、日志內(nèi)容格式等,配置信息如下所示:


其中,較為重要的是日志信息的格式,對(duì)應(yīng)上面文件中的ConversionPattern,值為"[%d]%n%m%n%n",每個(gè)占位符有對(duì)應(yīng)的含義,如下所示:+vx:xiketang777領(lǐng)取源碼

字符格式
說(shuō)明%m(message)輸出的日志消息%n(newline)換行%d(datetime)輸出當(dāng)前語(yǔ)句運(yùn)行的時(shí)刻%r(runtime)輸出程序執(zhí)行到當(dāng)前消耗的毫秒數(shù)%t(threadid)當(dāng)前語(yǔ)句所在的線程ID%p(priority)日志的當(dāng)前日志級(jí)別%c(class)當(dāng)前日志對(duì)象的名稱(chēng)%L輸出語(yǔ)句所在的行號(hào)%F輸出語(yǔ)句所在的文件名%-10最小長(zhǎng)度為10,不夠空格填充

  • 配置文件屬性中的復(fù)制到輸出目錄,設(shè)置為始終復(fù)制或如果較新則復(fù)制,如下圖所示:


  • 項(xiàng)目的AssemblyInfo.cs類(lèi)中添加一行代碼,如下所示:


  • 添加一個(gè)LogHelper類(lèi),編寫(xiě)2個(gè)Error的方法,如下所示:


  • 在ini文本存儲(chǔ)按鈕事件下,調(diào)用錯(cuò)誤日志寫(xiě)入,如下所示:


  • 執(zhí)行完成后,在項(xiàng)目目錄,Log\Error目錄下,產(chǎn)生一條當(dāng)天日志命名的文件,打開(kāi)如下所示:



4、SQLite存儲(chǔ)

日志信息存儲(chǔ)到數(shù)據(jù)庫(kù)的好處在于便于用戶通過(guò)界面進(jìn)行查詢,這里采用開(kāi)源免費(fèi)數(shù)據(jù)庫(kù)SQLite,其他關(guān)系型數(shù)據(jù)庫(kù),如SQLServer、mysql,原理都是一樣的,具體步驟如下所示:

  • 創(chuàng)建數(shù)據(jù)庫(kù)及數(shù)據(jù)表通過(guò)SQLiteStudio軟件創(chuàng)建一個(gè)數(shù)據(jù)庫(kù),取名為L(zhǎng)og4NetSQLite,執(zhí)行以下腳本創(chuàng)建一個(gè)Log數(shù)據(jù)表:


  • 將數(shù)據(jù)庫(kù)文件復(fù)制到項(xiàng)目根目錄下的DataBase文件夾中

  • 修改log4net.config文件,增加數(shù)據(jù)庫(kù)存儲(chǔ)相關(guān)配置,如下所示:



bufferSize:日志緩存寫(xiě)入條數(shù) 設(shè)置為0時(shí)只要有一條就立刻寫(xiě)到數(shù)據(jù)庫(kù)

connectionString:SQLite指向的是數(shù)據(jù)庫(kù)文件的絕對(duì)路徑

  • LogHelper類(lèi)中增加一個(gè)Info方法,如下所示:


  • 在SQLite存儲(chǔ)按鈕事件下,調(diào)用Info日志寫(xiě)入,如下所示:


  • 執(zhí)行完成后,打開(kāi)數(shù)據(jù)庫(kù),查看是否有相關(guān)記錄:



5、實(shí)際應(yīng)用

通過(guò)上面一系列的描述,相信大家對(duì)Log4Net的應(yīng)用有了一些了解,Log4Net構(gòu)建的日志系統(tǒng)是很多項(xiàng)目必備的一個(gè)功能,對(duì)項(xiàng)目開(kāi)發(fā)、調(diào)試及后續(xù)維護(hù)都有著至關(guān)重要的作用。實(shí)際使用時(shí),我們還可以將Log4Ne作為一個(gè)簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)工具,甚至可以使用Log4Net做多表多庫(kù)存儲(chǔ),這些內(nèi)容后續(xù)再給大家進(jìn)行介紹。

6、寫(xiě)在最后【需要源碼必看】

最近發(fā)現(xiàn)越來(lái)越多的小伙伴投入到C#上位機(jī)學(xué)習(xí)中,初學(xué)者學(xué)習(xí)最大的困擾就是無(wú)人交流,可以+vx:xiketang777 拉你進(jìn)入工控上位機(jī)學(xué)習(xí)交流群,歡迎各位小伙伴加入,僅限前200名,本文源碼也可通過(guò)加群獲取


【新閣教育】基于Log4Net實(shí)現(xiàn)日志信息雙向存儲(chǔ)(含源碼)的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
寻乌县| 永靖县| 固阳县| 西林县| 休宁县| 乐陵市| 栾川县| 册亨县| 师宗县| 安仁县| 广元市| 郧西县| 沙坪坝区| 屯留县| 平利县| 峨山| 南召县| 芜湖市| 神木县| 汉寿县| 读书| 筠连县| 荔浦县| 腾冲县| 城口县| 太康县| 漠河县| 连江县| 汕尾市| 平遥县| 睢宁县| 宜昌市| 鹤壁市| 曲周县| 全州县| 疏勒县| 安丘市| 舒兰市| 广饶县| 金川县| 枣庄市|