log4net的使用

來源:互聯網
上載者:User

標籤:color   換行   寫入   收集   prot   out   java se   記錄   --   

程式中只需要引用log4net.dll檔案即可

配置的引用
log4net.Config.XmlConfigurator.Configure();

  首先添加以上代碼。

CS程式:在Main方法中添加;

BS程式:Application_Start方法中添加;

或是兩者都可以在AssemblyInfo.cs(Properties中)檔案裡添加以下的語句:

//設定獨立設定檔,log4net.config[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )] //或是預設的設定檔[assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config檔案中)
詳細配置

log4net,可以把日誌輸出到控制台程式,檔案,資料庫、郵件,下面貼出四個輸出的配置代碼,其餘如window日誌等輸出不做闡述。

<?xml version="1.0" encoding="utf-8" ?><configuration>  <!--首先加入configSections配置節點-->  <configSections>    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>  </configSections>  <log4net>
<root> <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) --> <!--限制日誌記錄層級--> <level value="all" /> <!--將日誌輸出到檔案--> <appender-ref ref="FileAppender"/> <!--將日誌輸出到應用程式控制台--> <appender-ref ref="ConsoleAppender"/> <!--將日誌寫到郵件中--> <!--<appender-ref ref="LogSmtpAppender"/>--> <!--將日誌記錄到資料庫中。可以採用SQL和預存程序兩種方式--> <appender-ref ref="AdoNetAppender"/> <!--可以同時設定多個輸出對象,沒用到可以注釋--> <!--將日誌寫到local syslog service (僅用於UNIX環境下)。--> <!--<appender-ref ref="LocalSyslogAppender"/>--> </root>
<!--發郵件--> <appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender"> <authentication value="Basic" /> <!--接受郵件的郵箱--> <to value="[email protected]" /> <!--發送郵件的郵箱--> <from value="[email protected]" /> <!--發送郵件的郵箱--> <username value="[email protected]" /> <!--發送郵件的郵箱密碼--> <password value="123456" /> <!--標題--> <subject value="XXX應用錯誤記錄檔訊息" /> <!--smtp.qq.com--> <smtpHost value="smtp.126.com" /> <bufferSize value="2048" /> <!--超長部分是否丟棄--> <lossy value="true" /> <!--記錄層級 大於 WARN 的才發郵件--> <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>
<!-- 控制台日誌 --> <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> <!--指定範圍內的等級才可以被記錄--> <!--<filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="Info" /> <param name="LevelMax" value="Fatal" /> </filter>--> </appender > <!--指定日記記錄方式,以滾動檔案的方式(檔案記錄)--> <appender name="FileAppender" type="log4net.Appender.RollingFileAppender"> <!--日誌路徑--> <param name= "File" value= "log/"/> <!--是否是向檔案中追加日誌--> <param name= "AppendToFile" value= "true"/> <!--log保留天數--> <param name= "MaxSizeRollBackups" value= "10"/> <!--每個檔案最大1M--> <param name="maximumFileSize" value="1MB" /> <!--記錄檔名是否是固定不變的--> <param name= "StaticLogFileName" value= "false"/> <!--記錄檔名格式為:2008-08-31.log--> <param name= "DatePattern" value= "yyyy-MM-dd".log""/> <!--日誌根據日期滾動--> <param name= "RollingStyle" value= "Date"/> <!--布局--> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%n記錄時間:%d{yyyy-MM-dd HH:mm:ss} 線程名:[%t] 層級:%p 類名:%c 資訊:%m%n" /> <param name="Header" value="----------------------------------------------------------- "/> </layout> </appender>
<!--資料庫日記--> <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender"> <!--設定為1方便查看結果,處於效能考慮這裡的值應該略大一點,官方預設值是100,BufferSize為緩衝區大小,只有日誌記錄超設定值才會一塊寫入到資料庫--> <bufferSize value="1" /> <!--sqlserver 引用--> <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> <!--串連資料庫字串--> <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)" /> <!--所有參數--> <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 為命名空間

布局、格式字元說明:

%p:輸出日誌資訊的優先順序,即DEBUG,INFO,WARN,ERROR,FATAL。 %d:輸出日誌時間點的日期或時間,預設格式為ISO8601,也可以在其後指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。 %r:輸出自應用程式啟動到輸出該log資訊耗費的毫秒數。 %t:輸出產生該日誌事件的線程名。 %l:輸出日誌事件的發生位置,相當於%c.%M(%F:%L)的組合,包括類全名、方法、檔案名稱以及在代碼中的行數。例如:test.TestLog4j.main(TestLog4j.java:10)。 %c:輸出日誌資訊所屬的類目,通常就是所在類的全名。 %M:輸出產生日誌資訊的方法名。 %F:輸出日誌訊息產生時所在的檔案名稱。 %L::輸出代碼中的行號。 %m::輸出代碼中指定的具體日誌資訊。 %n:輸出一個斷行符號分行符號,Windows平台為"\r\n",Unix平台為"\n"。 %x:輸出和當前線程相關聯的NDC(嵌套診斷環境),尤其用到像java servlets這樣的多客戶多線程的應用中。 %%:輸出一個"%"字元。 另外,還可以在%與格式字元之間加上修飾符來控制其最小長度、最大長度、和文本的對齊。如: 1)%20c:指定輸出category的名稱,最小的長度是20,如果category的名稱長度小於20的話,預設的情況下靠右對齊。 2)%-20c:"-"號表示靠左對齊。 3)%.30c:指定輸出category的名稱,最大的長度是30,如果category的名稱長度大於30的話,就會將左邊多出的字元截掉,但小於30的話也不會補空格。
自訂資料庫插入欄位(源自網路收集、整理)

1.先定義一個LogData類:

namespace log4_Test.Log4netExpand{    public class LogData    {        /// <summary>        /// 日誌描述資訊        /// </summary>        public string Description { get; set; }        /// <summary>        /// 日誌描述資訊        /// </summary>        public string ObjType { get; set; }    }}

2.Layout擴充類

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>        /// 通過反射擷取傳入的日誌對象的某個屬性的值        /// </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)        {                       //能看到是那個類輸出            ILog logger = log4net.LogManager.GetLogger(typeof(Program));
logger.Info(new LogData { Description="123", ObjType="123"}) logger.Info("訊息11111111111111111111111111111"); logger.Warn("警告"); logger.Error("異常"); logger.Fatal("錯誤"); } }

 

log4net的使用

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.