欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

C#中l(wèi)og4net有什么用

這篇文章給大家分享的是有關(guān)C#中l(wèi)og4net有什么用的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

企業(yè)建站必須是能夠以充分展現(xiàn)企業(yè)形象為主要目的,是企業(yè)文化與產(chǎn)品對外擴(kuò)展宣傳的重要窗口,一個合格的網(wǎng)站不僅僅能為公司帶來巨大的互聯(lián)網(wǎng)上的收集和信息發(fā)布平臺,創(chuàng)新互聯(lián)面向各種領(lǐng)域:成都輕質(zhì)隔墻板成都網(wǎng)站設(shè)計營銷型網(wǎng)站解決方案、網(wǎng)站設(shè)計等建站排名服務(wù)。


Log4net是一個第三方開源組件,它設(shè)計的主要目的是組合,生成日志信息,同時將配置保存到各種存儲介質(zhì)或者展現(xiàn)平臺中,在實(shí)際項(xiàng)目中,Log4net可以保存系統(tǒng)運(yùn)行情況,可以在系統(tǒng)出現(xiàn)異常時,根據(jù)保存的日志信息,查看當(dāng)時系統(tǒng)的狀態(tài)。

1.Log4net的優(yōu)點(diǎn):

幾乎所有的大型應(yīng)用都會有自己的用于跟蹤調(diào)試的API。因?yàn)橐坏┏绦虮徊渴鹨院?,就不太可能再利用專門的調(diào)試工具了。然而一個管理員可能需要有一套強(qiáng)大的日志系統(tǒng)來診斷和修復(fù)配置上的問題。

經(jīng)驗(yàn)表明,日志記錄往往是軟件開發(fā)周期中的重要組成部分。它具有以下幾個優(yōu)點(diǎn):它可以提供應(yīng)用程序運(yùn)行時的精確環(huán)境,可供開發(fā)人員盡快找到應(yīng)用程序中的Bug;一旦在程序中加入了Log 輸出代碼,程序運(yùn)行過程中就能生成并輸出日志信息而無需人工干預(yù)。另外,日志信息可以輸出到不同的地方(控制臺,文件等)以備以后研究之用。

Log4net就是為這樣一個目的設(shè)計的,用于.NET開發(fā)環(huán)境的日志記錄包。

2 Log4net的安裝:

用戶可以從http://logging.apache.org/log4net/下載log4net的源代碼。解壓軟件包后,在解壓的src目錄下將log4net.sln載入Visual Studio .NET,編譯后可以得到log4net.dll。用戶要在自己的程序里加入日志功能,只需將log4net.dll引入工程即可。

3 Log4net的結(jié)構(gòu)

log4net 有四種主要的組件,分別是Logger(記錄器), Repository(庫), Appender(附著器)以及 Layout(布局).

(1) Logger接口

Logger是應(yīng)用程序需要交互的主要組件,它用來產(chǎn)生日志消息。產(chǎn)生的日志消息并不直接顯示,還要預(yù)先經(jīng)過Layout的格式化處理后才會輸出。

Logger提供了多種方式來記錄一個日志消息,你可以在你的應(yīng)用程序里創(chuàng)建多個Logger,每個實(shí)例化的Logger對象都被log4net框架作為命名實(shí)體(named entity)來維護(hù)。這意味著為了重用Logger對象,你不必將它在不同的類或?qū)ο箝g傳遞,只需要用它的名字為參數(shù)調(diào)用就可以了。log4net框架使用繼承體系,繼承體系類似于.NET中的名字空間。也就是說,如果有兩個logger,分別被定義為a.b.c和a.b,那么我們說a.b是a.b.c的祖先。每一個logger都繼承了祖先的屬性

Log4net框架定義了一個ILog接口,所有的logger類都必須實(shí)現(xiàn)這個接口。如果你想實(shí)現(xiàn)一個自定義的logger,你必須首先實(shí)現(xiàn)這個接口。你可以參考在/extension目錄下的幾個例子。

ILog接口的定義如下:

public interface ILog  {  void Debug(object message);  void Info(object message);  void Warn(object message);  void Error(object message);  void Fatal(object message);  //以上的每一個方法都有一個重載的方法,用來支持異常處理。  //每一個重載方法都如下所示,有一個異常類型的附加參數(shù)。  void Debug(object message, Exception ex);  // ...  //Boolean 屬性用來檢查Logger的日志級別  //(我們馬上會在后面看到日志級別)  bool isDebugEnabled;  bool isInfoEnabled;  //… 其他方法對應(yīng)的Boolean屬性  }

Log4net框架定義了一個叫做LogManager的類,用來管理所有的logger對象。它有一個GetLogger()靜態(tài)方法,用我們提供的名字參數(shù)來檢索已經(jīng)存在的Logger對象。如果框架里不存在該Logger對象,它也會為我們創(chuàng)建一個Logger對象。代碼如下所示:

log4net.ILog log = log4net.LogManager.GetLogger("logger-name");

通常來說,我們會以類(class)的類型(type)為參數(shù)來調(diào)用GetLogger(),以便跟蹤我們正在進(jìn)行日志記錄的類。傳遞的類(class)的類型(type)可以用typeof(Classname)方法來獲得,或者可以用如下的反射方法來獲得:

System.Reflection.MethodBase.GetCurrentMethod().DeclaringType

盡管符號長了一些,但是后者可以用于一些場合,比如獲取調(diào)用方法的類(class)的類型(type)。

(2)日志的級別

正如你在ILog的接口中看到的一樣,有五種不同的方法可以跟蹤一個應(yīng)用程序。事實(shí)上,這五種方法是運(yùn)作在Logger對象設(shè)置的不同日志優(yōu)先級別上。這幾種不同的級別是作為常量定義在log4net.spi.Level類中。你可以在程序中使用任何一種方法。但是在***的發(fā)布中你也許不想讓所有的代碼來浪費(fèi)你的CPU周期,因此,框架提供了7種級別和相應(yīng)的Boolean屬性來控制日志記錄的類型。

Level有以下幾種取值:

C#中l(wèi)og4net有什么用
表1 Logger的日志級別

在log4net框架里,通過設(shè)置配置文件,每個日志對象都被分配了一個日志優(yōu)先級別。如果沒有給一個日志對象顯式地分配一個級別,那么該對象會試圖從他的祖先繼承一個級別值。

ILog接口的每個方法都有一個預(yù)先定義好了的級別值。正如你在表1看到的,ILog的Inof()方法具有INFO級別。同樣的,以此類推,Error()方法具有ERROR級別。當(dāng)我們使用以上的任何一種方法時,log4net框架會檢查日志對象logger的級別和方法的級別。只有當(dāng)方法的級別高于日志級別時,日志請求才會被接受并執(zhí)行。

舉例說明,當(dāng)你創(chuàng)建了一個日志對象,并且把他的級別設(shè)置為INFO。于是框架會設(shè)置日志的每個Boolean屬性。當(dāng)你調(diào)用相應(yīng)的日志方法時,框架會檢查相應(yīng)的Boolean屬性,以決定該方法能不能執(zhí)行。如下的代碼:

Logger.Info("message");  Logger.Debug("message");  Logger.Warn("message");

對于***種方法,Info()的級別等與日志的級別(INFO),因此日志請求會被傳遞,我們可以得到輸出結(jié)果”message”。

對于第二種方法,Debug()的級別低于日志對象logger的日志級別(INFO),因此,日志請求被拒絕了,我們得不到任何輸出。同樣的,針對第三行語句,我們可以很容易得出結(jié)論。

在表1中有兩個特殊的級別:ALL和OFF。ALL表示允許所有的日志請求。OFF是拒絕所有的請求。

你也可以顯式地檢查Logger對象的Boolean屬性,如下所示:

if (logger.IsDebugEnabled)   {  Logger.Debug("message");  }

Repository

Repository主要用于負(fù)責(zé)日志對象組織結(jié)構(gòu)的維護(hù)。在log4net的以前版本中,框架僅支持分等級的組織結(jié)構(gòu)(hierarchical organization)。這種等級結(jié)構(gòu)本質(zhì)上是庫的一個實(shí)現(xiàn),并且定義在log4net.Repository.Hierarchy 名字空間中。要實(shí)現(xiàn)一個Repository,需要實(shí)現(xiàn)log4net.Repository.ILoggerRepository 接口。但是通常并不是直接實(shí)現(xiàn)該接口,而是以log4net.Repository.LoggerRepositorySkeleton為基類繼承。體系庫(hierarchical repository )則由log4net.Repository.Hierarchy.Hierarchy類實(shí)現(xiàn)。

如果你是個log4net框架的使用者,而非擴(kuò)展者,那么你幾乎不會在你的代碼里用到Repository的類。相反的,你需要用到LogManager類來自動管理庫和日志對象。

Appender

一個好的日志框架應(yīng)該能夠產(chǎn)生多目的地的輸出。比如說輸出到控制臺或保存到一個日志文件。log4net 能夠很好的滿足這些要求。它使用一個叫做Appender的組件來定義輸出介質(zhì)。正如名字所示,這些組件把它們附加到Logger日志組件上并將輸出傳遞到輸出流中。你可以把多個Appender組件附加到一個日志對象上。Log4net框架提供了幾個Appender組件。關(guān)于log4net提供的Appender組件的完整列表可以在log4net框架的幫助手冊中找到。有了這些現(xiàn)成的Appender組件,一般來說你沒有必要再自己編寫了。但是如果你愿意,可以從log4net.Appender.AppenderSkeleton類繼承

Appender Filters

一個Appender 對象缺省地將所有的日志事件傳遞到輸出流。Appender的過濾器(Appender Filters) 可以按照不同的標(biāo)準(zhǔn)過濾日志事件。在log4net.Filter的名字空間下已經(jīng)有幾個預(yù)定義的過濾器。使用這些過濾器,你可以按照日志級別范圍過濾日志事件,或者按照某個特殊的字符串進(jìn)行過濾。

感謝各位的閱讀!關(guān)于“C#中l(wèi)og4net有什么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

新聞名稱:C#中l(wèi)og4net有什么用
網(wǎng)站路徑:http://aaarwkj.com/article10/psojgo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、品牌網(wǎng)站設(shè)計App設(shè)計、關(guān)鍵詞優(yōu)化、標(biāo)簽優(yōu)化網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
免费激情在线视频网址| 四虎永久精品在线视频| 欧美亚洲精品一区二区三区| 欧美一区二区亚洲天堂| 日韩中文字幕一二一二区| 精品国产成人一区二区| 中文字幕精品一区二区介绍 | 午夜在线成人免费观看| 爱高潮www亚洲精品| 全国精品免费视频久久久| 日本经典三级在线视频| 啄木乌法国一区二区三区| 给我免费在线观看视频| 一级片欧美女人性生活片| 91欧美精品在线视频| 国产区av中文字幕在线观看| 欧美精品激情在线不卡| 亚洲精品一区二区三区pp| 97视频网站在线观看| 日韩精品毛片在线看| 好狼色欧美激情国产区| 精品一级人片内射视频| 国产成人99亚洲综合精品| 欧美日韩一区二区高清在线| 日韩黄色一级片免费看| 91亚洲精品一区二区三区| 婷婷五激情五月激情片| 国偷蜜桃av一区二区三区| 国产三级黄在线观看| 国产成人亚洲精品午夜国产馆| 日韩久久精品国产亚洲av成人| 99久久精品国产国产毛片| 久久精品国产亚洲av超一| 九九热最新视频免费看| 欧美日韩亚洲人人夜夜澡| 亚洲伊人久久一区二区| 日韩在线不卡视频一区| 91精品国产高清91久久久久久| 国语对白刺激真实精品| 国产一区二区三区在线观看俏佳人| 岛国大片日韩在线观看|