Log4net 列

配置 <configuration>
<configSections>
<section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
</configSections>

<log4net>
<!--定義輸出到文件中-->
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<!--定義文件存放位置-->
<file value="Log\GALog\GaLog.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="100" />
<maximumFileSize value="1M" />
<staticLogFileName value="true" />

<!--<param name="File" value="Log\\LogError\\" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="100" />
<param name="MaxFileSize" value="2M" />
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd&quot;.txt&quot;" />
<param name="RollingStyle" value="Date" />-->

<layout type="log4net.Layout.PatternLayout">

<!--每條日誌起末的文字說明-->
<header value="=================================================Begin=================================================&#13;&#10;"/>
<footer value="=================================================End===================================================&#13;&#10;"/>
<!--輸出格式-->
<!--樣例:2008-03-26 13:42:32,111 [10] INFO Log4NetDemo.MainClass [(null)] - info-->
<!--<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />-->
<conversionPattern value="記錄時間:%date 線程ID:[%thread] 日誌級別:%-5level 出錯類:%logger property:[%property{NDC}] - 錯誤描述:%message%newline" />
</layout>
</appender>
<!--定義輸出到控制檯命令行中-->
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<!--定義輸出到windows事件中-->
<appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<!--定義輸出到數據庫中,這裏舉例輸出到Access數據庫中,數據庫爲C盤的log4net.mdb-->
<appender name="AdoNetAppender_Access" type="log4net.Appender.AdoNetAppender">
<connectionString value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:log4net.mdb" />
<commandText value="INSERT INTO LogDetails ([LogDate],[Thread],[Level],[Logger],[Message]) VALUES (@logDate, @thread, @logLevel, @logger,@message)" />
<!--定義各個參數-->
<parameter>
<parameterName value="@logDate" />
<dbType value="String" />
<size value="240" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date" />
</layout>
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="240" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@logLevel" />
<dbType value="String" />
<size value="240" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="240" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="240" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
</appender>
<!--定義日誌的輸出媒介,下面定義日誌以四種方式輸出。也能夠下面的按照一種類型或其餘類型輸出。-->
<root>
<!--文件形式記錄日誌-->
<appender-ref ref="LogFileAppender" />
<!--控制檯控制顯示日誌-->
<!--<appender-ref ref="ConsoleAppender" />-->
<!--Windows事件日誌-->
<!--<appender-ref ref="EventLogAppender" />-->
<!-- 若是不啓用相應的日誌記錄,能夠經過這種方式註釋掉
<appender-ref ref="AdoNetAppender_Access" />
-->
</root>

</log4net>

</configuration> .CS代碼

using System;

using System.Collections.Generic;
using System.Linq;
using System.Text;

[assembly: log4net.Config.XmlConfigurator(Watch = true)]
namespace ga
{
public class ExceptionLog
{
private static readonly log4net.ILog log =
log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public static void WriteLog(string remark, Exception ex)
{
try
{
log.Error(remark, ex);
}
catch (Exception e)
{
Console.WriteLine(e.Message);
}
}

}
}


 

log4net裏面的filter類經常使用的爲:
一、DenyAllFilter
拒絕所用的日誌輸出
<filter type="log4net.Filter.LevelMatchFilter">
<param name="LevelToMatch" value="DEBUG" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
上面的配置是若是日誌的輸出級別不符合DEBUG要求的話,則不輸出任何日誌。
二、LevelMatchFilter
這個類裏面有兩個屬性,一個是LevelToMatch這個屬性是你要匹配輸出日誌的級別,好比:
<filter type="log4net.Filter.LevelMatchFilter">
<param name="LevelToMatch" value="DEBUG" />
</filter>
這樣的話,只有級別是DEBUG的日誌才能輸出。
另外這個類還有一個重要的屬性就是AcceptOnMatch這個屬性是設置若是這個條件匹配的話,是否接受輸出打印,好比說:
<filter type="log4net.Filter.LevelMatchFilter">
<param name="LevelToMatch" value="DEBUG" />
</filter>
<filter type="log4net.Filter.StringMatchFilter">
<param name="StringToMatch" value="debug" />
</filter>
若是日誌的級別爲DEBVG的話,也就是說符合了第一個Filter的條件,日誌就輸出,則StringMatchFilter就不執行了。若是這樣寫的話,就會繼續向下執行過濾:
<filter type="log4net.Filter.LevelMatchFilter">
<param name="LevelToMatch" value="DEBUG" />
<AcceptOnMatch value="false"></AcceptOnMatch>
</filter>
<filter type="log4net.Filter.StringMatchFilter">
<param name="StringToMatch" value="debug" />
</filter>
若是這樣寫的話,即便第一個Filter符合了條件則第二個Filter也會繼續執行。
三、LevelRangeFilter
配置文件是這樣的:
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="DEBUG" />
<param name="LevelMax" value="ERROR" />
</filter>
四、LoggerMatchFilter
配置文件是這樣的:
<filter type="log4net.Filter.LoggerMatchFilter">
<param name="LoggerToMatch" value="Client" />
</filter>
五、StringMatchFilter
配置文件是這樣的:
<filter type="log4net.Filter.StringMatchFilter">
<param name="StringToMatch" value="/blog/Client.Program" />
</filter> 數據庫

相關文章
相關標籤/搜索