欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.net core整合log4net的解決方案

 更新時(shí)間:2018年07月02日 10:14:07   作者:KING_GUOKUN  
這篇文章主要給大家介紹了關(guān)于.net core整合log4net的解決方案,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用.net core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

概述

log4net是.Net下一個(gè)非常優(yōu)秀的開(kāi)源日志記錄組件。log4net記錄日志的功能非常強(qiáng)大。它可以將日志分不同的等級(jí),以不同的格式,輸出到不同的媒介。

背景

前兩天,曾經(jīng)的一個(gè)同事咨詢(xún)我,怎樣將log4net以中間件的形式整合到core里邊去。我不假思索的回答,這種問(wèn)題應(yīng)該有人做過(guò)吧,他說(shuō)沒(méi)有。于是,我去博客園搜了下,發(fā)現(xiàn)還真沒(méi)有,全部都是傳統(tǒng).NET那一套,直接LogManager.GetLogger,于是趁著周末有時(shí)間,決定調(diào)研下這個(gè)問(wèn)題。去巨硬官網(wǎng)快速瀏覽了下,擴(kuò)展第三方日志的核心就在于兩個(gè)接口:ILogger和ILoggerProvider。于是建好解決方案,刷刷刷實(shí)現(xiàn)這兩個(gè)接口,實(shí)現(xiàn)差不多了查相關(guān)資料時(shí),猛然發(fā)現(xiàn),臥槽,已經(jīng)有國(guó)外同仁實(shí)現(xiàn)過(guò)了,我尼瑪?shù)男量鄬?xiě)半天,這下徹底垮了。。。

切換四路

本著偷懶、鄙視瞎造輪子/裝逼的心態(tài), 直接把解決方案切換到開(kāi)源實(shí)現(xiàn)。實(shí)際上順便看了下第三方實(shí)現(xiàn)源碼,四路也是一致的,實(shí)現(xiàn)那兩個(gè)接口。

解決方案如下:

包引用如下:

最上邊的不多說(shuō),第二個(gè)別問(wèn)我,第三個(gè)就是core整合log4net的主角。關(guān)于這個(gè),得特別說(shuō)明下,最新版本是2.2.1,但我并沒(méi)有引用最新的,而是2.1.0,因?yàn)槟壳坝行┑谌桨钚掳姹疽玫脑影亲钚碌?,而上邊第二個(gè)鬼東東Microsoft.AspNetCore.App這個(gè)框架包底層的原子包卻并不是,所以如果引用最新的第三方包,很可能會(huì)報(bào)某個(gè)原子包依賴(lài)版本不對(duì)的錯(cuò)誤。解決方案有二:1、哪個(gè)包報(bào)錯(cuò),你單獨(dú)安裝哪個(gè)原子包的最新版本;2、切換第三方包的版本到較次,找到能夠兼容當(dāng)前Microsoft.AspNetCore.App的實(shí)現(xiàn)。解決方案1的問(wèn)題是,你更新了這個(gè)原子包,它的依賴(lài)包又出錯(cuò),你更新了它的依賴(lài)的依賴(lài),它的依賴(lài)的依賴(lài)的依賴(lài)又出錯(cuò)。。。所以,方便起見(jiàn),我直接用了Microsoft.Extensions.Logging.Log4Net.AspNetCore的較低版本。

log4net.config不再截圖或上代碼,跟以前的德行沒(méi)啥兩樣。

接下來(lái),注冊(cè)log4net:

圖中,前兩行的作用是過(guò)濾掉System和Microsoft開(kāi)頭的命名空間下的組件產(chǎn)生的警告級(jí)別一下的日志,實(shí)際上主要就是一些框架性日志。第三行便是注冊(cè)log4net中間件。

接下來(lái)新建控制器,注入日志實(shí)踐下效果:

上圖兩個(gè)紅框,上邊一個(gè)是構(gòu)造器注入日志接口,下邊是調(diào)用日志組件記錄日志。

好,接下來(lái)我們?nèi)タ纯聪到y(tǒng)產(chǎn)生的日志,先調(diào)用:

控制臺(tái)窗口:

OK,日志已經(jīng)輸出成功,接下來(lái),我們看關(guān)鍵性的輸出到文件:

看到?jīng)]有,日志已經(jīng)成功經(jīng)由log4net輸出到文件。

總結(jié)

感覺(jué)沒(méi)什么好總結(jié)的,.net core提供的擴(kuò)展已經(jīng)很開(kāi)放了,雖然log4net目前比較操蛋,但這對(duì)咱大部分.NET開(kāi)發(fā)者來(lái)說(shuō)應(yīng)該都不是事兒。

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

最新評(píng)論