詳解log4net的使用
程序中只需要引用log4net.dll文件即可
配置的引用
log4net.Config.XmlConfigurator.Configure();
首先添加以上代碼。
CS程序:在Main方法中添加;
BS程序:Application_Start方法中添加;
或是兩者都可以在AssemblyInfo.cs(Properties中)文件里添加以下的語(yǔ)句:
//設(shè)置獨(dú)立配置文件,log4net.config [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )] //或是默認(rèn)的配置文件 [assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config文件中)
詳細(xì)配置
log4net,可以把日志輸出到控制臺(tái)程序,文件,數(shù)據(jù)庫(kù)、郵件,下面貼出四個(gè)輸出的配置代碼,其余如window日志等輸出不做闡述。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <!--首先加入configSections配置節(jié)點(diǎn)--> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/> </configSections> <log4net><br> <root> <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) --> <!--限制日志記錄級(jí)別--> <level value="all" /> <!--將日志輸出到文件--> <appender-ref ref="FileAppender"/> <!--將日志輸出到應(yīng)用程序控制臺(tái)--> <appender-ref ref="ConsoleAppender"/> <!--將日志寫到郵件中--> <!--<appender-ref ref="LogSmtpAppender"/>--> <!--將日志記錄到數(shù)據(jù)庫(kù)中??梢圆捎肧QL和存儲(chǔ)過程兩種方式--> <appender-ref ref="AdoNetAppender"/> <!--可以同時(shí)設(shè)置多個(gè)輸出對(duì)象,沒用到可以注釋--> <!--將日志寫到local syslog service (僅用于UNIX環(huán)境下)。--> <!--<appender-ref ref="LocalSyslogAppender"/>--> </root><br> <!--發(fā)郵件--> <appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender"> <authentication value="Basic" /> <!--接受郵件的郵箱--> <to value="7778888@qq.com" /> <!--發(fā)送郵件的郵箱--> <from value="123456@126.com" /> <!--發(fā)送郵件的郵箱--> <username value="123456@126.com" /> <!--發(fā)送郵件的郵箱密碼--> <password value="123456" /> <!--標(biāo)題--> <subject value="XXX應(yīng)用錯(cuò)誤日志消息" /> <!--smtp.qq.com--> <smtpHost value="smtp.126.com" /> <bufferSize value="2048" /> <!--超長(zhǎng)部分是否丟棄--> <lossy value="true" /> <!--日志級(jí)別 大于 WARN 的才發(fā)郵件--> <evaluator type="log4net.Core.LevelEvaluator"> <threshold value="ERROR"/> </evaluator> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value=" %level :: %message %newlineLogger: %logger%newline Date: %date%newline" /> </layout> </appender><br> <!-- 控制臺(tái)日志 --> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%n%d{yyyy-MM-dd HH:mm:ss} %m%n" /> </layout> <!--指定范圍內(nèi)的等級(jí)才可以被記錄--> <!--<filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="Info" /> <param name="LevelMax" value="Fatal" /> </filter>--> </appender > <!--指定日記記錄方式,以滾動(dòng)文件的方式(文件記錄)--> <appender name="FileAppender" type="log4net.Appender.RollingFileAppender"> <!--日志路徑--> <param name= "File" value= "log/"/> <!--是否是向文件中追加日志--> <param name= "AppendToFile" value= "true"/> <!--log保留天數(shù)--> <param name= "MaxSizeRollBackups" value= "10"/> <!--每個(gè)文件最大1M--> <param name="maximumFileSize" value="1MB" /> <!--日志文件名是否是固定不變的--> <param name= "StaticLogFileName" value= "false"/> <!--日志文件名格式為:2008-08-31.log--> <param name= "DatePattern" value= "yyyy-MM-dd".log""/> <!--日志根據(jù)日期滾動(dòng)--> <param name= "RollingStyle" value= "Date"/> <!--布局--> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%n記錄時(shí)間:%d{yyyy-MM-dd HH:mm:ss} 線程名:[%t] 級(jí)別:%p 類名:%c 信息:%m%n" /> <param name="Header" value="----------------------------------------------------------- "/> </layout> </appender><br> <!--數(shù)據(jù)庫(kù)日記--> <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender"> <!--設(shè)置為1方便查看結(jié)果,處于性能考慮這里的值應(yīng)該略大一點(diǎn),官方默認(rèn)值是100,BufferSize為緩沖區(qū)大小,只有日志記錄超設(shè)定值才會(huì)一塊寫入到數(shù)據(jù)庫(kù)--> <bufferSize value="1" /> <!--sqlserver 引用--> <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> <!--連接數(shù)據(jù)庫(kù)字符串--> <connectionString value="data source=.;initial catalog=test;integrated security=false;persist security info=True;User ID=sa;Password=sqlserver;" /> <!--插入到表Log--> <commandText value="INSERT INTO LogTest ([Date],[Level],[Logger],[Message],[Exception],[Description],[ObjType]) VALUES (@log_date,@log_level, @logger, @message, @exception,@Description,@ObjType)" /> <!--所有參數(shù)--> <parameter> <parameterName value="@log_date" /> <dbType value="DateTime" /> <layout type="log4net.Layout.RawTimeStampLayout" /> </parameter> <parameter> <parameterName value="@log_level" /> <dbType value="String" /> <size value="50" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%level" /> </layout> </parameter> <!--類所在位置--> <parameter> <parameterName value="@logger" /> <dbType value="String" /> <size value="255" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%logger" /> </layout> </parameter> <parameter> <parameterName value="@message" /> <dbType value="String" /> <size value="4000" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%message" /> </layout> </parameter> <parameter> <parameterName value="@exception" /> <dbType value="String" /> <size value="2000" /> <layout type="log4net.Layout.ExceptionLayout" /> </parameter> <!--自定義輸入字段--> <parameter> <parameterName value = "@Description"/> <dbType value = "String"/> <size value = "50"/> <layout type = "log4_Test.Log4netExpand.ExpandLayout"> <conversionPattern value = "%property{Description}"/> </layout> </parameter> <parameter> <parameterName value = "@ObjType"/> <dbType value = "String"/> <size value = "50"/> <layout type = "log4_Test.Log4netExpand.ExpandLayout"> <conversionPattern value = "%property{ObjType}"/> </layout> </parameter> </appender> </log4net> </configuration>
<layout type = "log4_Test.Log4netExpand.ExpandLayout"> 中的log4_Test.Log4netExpand 為命名空間
布局、格式字符說(shuō)明:
%p:輸出日志信息的優(yōu)先級(jí),即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL。
%d:輸出日志時(shí)間點(diǎn)的日期或時(shí)間,默認(rèn)格式為ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:輸出自應(yīng)用程序啟動(dòng)到輸出該log信息耗費(fèi)的毫秒數(shù)。
%t:輸出產(chǎn)生該日志事件的線程名。
%l:輸出日志事件的發(fā)生位置,相當(dāng)于%c.%M(%F:%L)的組合,包括類全名、方法、文件名以及在代碼中的行數(shù)。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:輸出日志信息所屬的類目,通常就是所在類的全名。
%M:輸出產(chǎn)生日志信息的方法名。
%F:輸出日志消息產(chǎn)生時(shí)所在的文件名稱。
%L::輸出代碼中的行號(hào)。
%m::輸出代碼中指定的具體日志信息。
%n:輸出一個(gè)回車換行符,Windows平臺(tái)為"\r\n",Unix平臺(tái)為"\n"。
%x:輸出和當(dāng)前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像java servlets這樣的多客戶多線程的應(yīng)用中。
%%:輸出一個(gè)"%"字符。
另外,還可以在%與格式字符之間加上修飾符來(lái)控制其最小長(zhǎng)度、最大長(zhǎng)度、和文本的對(duì)齊方式。如:
1)%20c:指定輸出category的名稱,最小的長(zhǎng)度是20,如果category的名稱長(zhǎng)度小于20的話,默認(rèn)的情況下右對(duì)齊。
2)%-20c:"-"號(hào)表示左對(duì)齊。
3)%.30c:指定輸出category的名稱,最大的長(zhǎng)度是30,如果category的名稱長(zhǎng)度大于30的話,就會(huì)將左邊多出的字符截掉,但小于30的話也不會(huì)補(bǔ)空格。
自定義數(shù)據(jù)庫(kù)插入字段(源自網(wǎng)絡(luò)收集、整理)
1.先定義一個(gè)LogData類:
namespace log4_Test.Log4netExpand { public class LogData { /// <summary> /// 日志描述信息 /// </summary> public string Description { get; set; } /// <summary> /// 日志描述信息 /// </summary> public string ObjType { get; set; } } }
2.Layout擴(kuò)展類
namespace log4_Test.Log4netExpand { public class ExpandLayout : PatternLayout { public ExpandLayout() { this.AddConverter("property", typeof(MyMessagePatternConverter)); } } }
3.MyMessagePatternConverter 類
namespace log4_Test.Log4netExpand { public class MyMessagePatternConverter: PatternLayoutConverter { protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent) { if (Option != null) { // Write the value for the specified key WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent)); } else { // Write all the key value pairs WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties()); } } /// <summary> /// 通過反射獲取傳入的日志對(duì)象的某個(gè)屬性的值 /// </summary> /// <param name="property"></param> /// <returns></returns> private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent) { object propertyValue = string.Empty; PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property); if (propertyInfo != null) { propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null); } return propertyValue; } } }
4.使用代碼如下:
public class Program { static void Main(string[] args) { //能看到是那個(gè)類輸出 ILog logger = log4net.LogManager.GetLogger(typeof(Program)); logger.Info(new LogData { Description="123", ObjType="123"}) logger.Info("消息11111111111111111111111111111"); logger.Warn("警告"); logger.Error("異常"); logger.Fatal("錯(cuò)誤"); } }
以上所述是小編給大家介紹的log4net的使用詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
.net?core中高效的動(dòng)態(tài)內(nèi)存管理方案
這篇文章介紹了.net?core中高效的動(dòng)態(tài)內(nèi)存管理方案,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07安裝.NET Framework進(jìn)度條卡住不動(dòng)的解決方案(推薦)
VS在安裝之前需要安裝.NET Framework,我安裝的是4.0版本。但是安裝進(jìn)度條到一半左右時(shí)就卡住不動(dòng)了。前前后后重試多次,還有幾次重新開機(jī),但都沒用,怎么解決呢,下面給大家分享下解決方案2016-12-12asp.net實(shí)現(xiàn)的計(jì)算網(wǎng)頁(yè)下載速度的代碼
剛看到有人給出asp.net實(shí)現(xiàn)的計(jì)算網(wǎng)頁(yè)下載速度的方法,本方法未經(jīng)本人測(cè)試,不知道能否可靠性如何。準(zhǔn)確來(lái)說(shuō),這只是個(gè)思路吧2013-03-03Request.QueryString與一般NameValueCollection的區(qū)別
最近在做一個(gè)搜索程序的優(yōu)化改進(jìn),將搜索結(jié)果按照查詢的參數(shù)不同進(jìn)行緩存。緩存的Key很自然的就想到了用查詢字符串,而獲取查詢字符串的最簡(jiǎn)單方式是通過Request.QueryString.ToString()方法2011-12-12TreeView創(chuàng)建IHierarchicalDataSource類型的數(shù)據(jù)源實(shí)現(xiàn)
為TreeView創(chuàng)建IHierarchicalDataSource類型的數(shù)據(jù)源實(shí)現(xiàn)2009-01-01C#中的FileUpload 選擇后的預(yù)覽效果具體實(shí)現(xiàn)
選擇后的預(yù)覽效果實(shí)現(xiàn)的方法有很多,在本文為大家介紹下使用C#中的FileUpload是如何實(shí)現(xiàn)的,感興趣的朋友不要錯(cuò)過2013-12-12asp.net顯示相同數(shù)字相乘的結(jié)果,直到數(shù)值大于150為止
老師布置Insus.NET做的第二道題,題目如標(biāo)題。感興趣的網(wǎng)友也可以練習(xí)練習(xí)。現(xiàn)在Insus.NET的作答如下,但老師還沒有看,因此答案是否正確或是最好的,還不能確定,只是供參考2012-05-05