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

Log4Net 日志配置[附帶源碼下載]

 更新時間:2015年05月21日 23:40:37   投稿:mdxy-dxy  
這篇文章主要介紹了Log4Net 日志配置[附帶源碼下載],需要的朋友可以參考下

前述

  園子里有許多人對log4net這款開源的日志記錄控件有很多介紹。在這里個人再做一次總結,希望對以后有所幫助,需要的時候可以直接使用,減少查閱資料的時間。利用log4net可以方便地將日志信息記錄到文件、控制臺、Windows事件日志和數(shù)據(jù)庫,并且我們還可以記載控制要記載的日志級別,可以記載的日志類別包括:FATAL(致命錯誤)、ERROR(一般錯誤)、WARN(警告)、INFO(一般信息)、DEBUG(調試信息)。log4net 有四種主要的組件,分別是Logger(記錄器), Repository(庫), Appender(附著器)以及 Layout(布局).

準備工作:

1.下載log4net.dll 下載地址[http://logging.apache.org/log4net/download_log4net.cgi]

下載文件:log4net-1.2.13-bin-newkey.zip。 解壓選擇對應的net版本找到log4net.dll。

2.在項目中引用log4net.dll。

實例代碼

準備工作完成后我們來看下實例代碼 ,首先在項目中創(chuàng)建一個文件夾LogConfig。把有關log4net的一些配置文件和類都放在這個文件夾里面。

WEB網(wǎng)站為例,在項目LogConfig文件夾中創(chuàng)建Log4Net.config配置文件。

<?xml version="1.0" encoding="utf-8"?>
<configuration>
 <configSections>
  <!--添加自定義節(jié)點:log4net type:解析類名,程序集名(log4net.dll)-->
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
 </configSections>

 <log4net>
  <!--定義輸出到文件中-->
  <appender name="Log4Net_INFO" type="log4net.Appender.RollingFileAppender">
   <!--定義文件存放位置-->
   <file value="C:/log4net/"/>
   <!--是否追加到文件,默認為true,通常無需設置-->
   <appendToFile value="true"/>
   <RollingStyle value="Date"/>
   <!--日期的格式,每天換一個文件記錄,如不設置則永遠只記錄一天的日志,需設置-->
   <DatePattern value="INFO_yyyyMMdd&quot;.log&quot;" />
   <!--日志文件名是否為靜態(tài)-->
   <StaticLogFileName value="false"/>
   <!--多線程時采用最小鎖定-->
   <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
   <!--布局(向用戶顯示最后經(jīng)過格式化的輸出信息)-->
   <layout type="log4net.Layout.PatternLayout">
    <!--
      %m(message):輸出的日志消息,如ILog.Debug(…)輸出的一條消息 
      %n(new line):換行 
      %d(datetime):輸出當前語句運行的時刻 
      %r(run time):輸出程序從運行到執(zhí)行到當前語句時消耗的毫秒數(shù) 
      %t(thread id):當前語句所在的線程ID 
      %p(priority): 日志的當前優(yōu)先級別,即DEBUG、INFO、WARN…等 
      %c(class):當前日志對象的名稱,例如:
      %L:輸出語句所在的行號 
      %F:輸出語句所在的文件名 
      %-數(shù)字:表示該項的最小長度,如果不夠,則用空格填充
     -->
    <Header value="[Header]&#13;&#10;"/>
    <Footer value="[Footer]&#13;&#10;"/>
    <!--正文-->
    <ConversionPattern value="記錄時間:%date 線程ID:[%thread] 日志級別:%-5level 出錯類:%logger property:[%property{NDC}] - 錯誤描述:%message%newline" />
   </layout>
  </appender>

  <appender name="Log4Net_ERROR" type="log4net.Appender.RollingFileAppender">
   <file value="C:/log4net/"/>
   <appendToFile value="true"/>
   <RollingStyle value="Date"/>
   <DatePattern value="ERROR_yyyyMMdd&quot;.log&quot;" />
   <StaticLogFileName value="false"/>
   <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
   <layout type="log4net.Layout.PatternLayout">
    <Header value="[Header]&#13;&#10;"/>
    <Footer value="[Footer]&#13;&#10;"/>
    <!--正文-->
    <ConversionPattern value="記錄時間:%date 線程ID:[%thread] 日志級別:%-5level 出錯類:%logger property:[%property{NDC}] - 錯誤描述:%message%newline" />
   </layout>
  </appender>

  <root>
   <level value="DEBUG"/>
   <appender-ref ref="Log4Net_ERROR" />

   <level value="INFO"/>
   <appender-ref ref="Log4Net_INFO" />
  </root>

 </log4net>

</configuration>

配置文件寫完后我們在來寫一個Helper類。同樣在項目中創(chuàng)建一個名為LogHelper.cs的類文件。

using log4net;
using System;
using System.Collections.Concurrent;
using System.Collections.Generic;

//指定log4net使用的config文件來讀取配置信息
[assembly: log4net.Config.XmlConfigurator(ConfigFile = @"LogConfig\Log4Net.config", Watch = true)]
namespace Project.Log4.Net.LogConfig
{
  /// <summary>
  /// 日志幫助類
  /// </summary>
  public class LogHelper
  {
    private static readonly ConcurrentDictionary<Type, ILog> _loggers = new ConcurrentDictionary<Type, ILog>();

    /// <summary>
    /// 獲取記錄器
    /// </summary>
    /// <param name="source"></param>
    /// <returns></returns>
    private static ILog GetLogger(Type source)
    {
      if (_loggers.ContainsKey(source))
      {
        return _loggers[source];
      }
      else
      {
        ILog logger = LogManager.GetLogger(source);
        _loggers.TryAdd(source, logger);
        return logger;
      }
    }

    /* Log a message object */

    /// <summary>
    /// 調試信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Debug(object source, string message)
    {
      Debug(source.GetType(), message);
    }

    /// <summary>
    /// 調試信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="ps"></param>
    public static void Debug(object source, string message, params object[] ps)
    {
      Debug(source.GetType(), string.Format(message, ps));
    }

    /// <summary>
    /// 調試信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Debug(Type source, string message)
    {
      ILog logger = GetLogger(source);
      if (logger.IsDebugEnabled)
        logger.Debug(message);
    }

    /// <summary>
    /// 關鍵信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Info(object source, object message)
    {
      Info(source.GetType(), message);
    }

    /// <summary>
    /// 關鍵信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Info(Type source, object message)
    {
      ILog logger = GetLogger(source);
      if (logger.IsInfoEnabled)
        logger.Info(message);
    }

    /// <summary>
    /// 警告信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Warn(object source, object message)
    {
      Warn(source.GetType(), message);
    }

    /// <summary>
    /// 警告信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Warn(Type source, object message)
    {
      ILog logger = GetLogger(source);
      if (logger.IsWarnEnabled)
        logger.Warn(message);
    }

    /// <summary>
    /// 錯誤信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Error(object source, object message)
    {
      Error(source.GetType(), message);
    }

    /// <summary>
    /// 錯誤信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Error(Type source, object message)
    {
      ILog logger = GetLogger(source);
      if (logger.IsErrorEnabled)
        logger.Error(message);
    }

    /// <summary>
    /// 失敗信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Fatal(object source, object message)
    {
      Fatal(source.GetType(), message);
    }

    /// <summary>
    /// 失敗信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    public static void Fatal(Type source, object message)
    {
      ILog logger = GetLogger(source);
      if (logger.IsFatalEnabled)
        logger.Fatal(message);
    }

    /* Log a message object and exception */

    /// <summary>
    /// 調試信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Debug(object source, object message, Exception exception)
    {
      Debug(source.GetType(), message, exception);
    }

    /// <summary>
    /// 調試信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Debug(Type source, object message, Exception exception)
    {
      GetLogger(source).Debug(message, exception);
    }

    /// <summary>
    /// 關鍵信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Info(object source, object message, Exception exception)
    {
      Info(source.GetType(), message, exception);
    }

    /// <summary>
    /// 關鍵信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Info(Type source, object message, Exception exception)
    {
      GetLogger(source).Info(message, exception);
    }

    /// <summary>
    /// 警告信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Warn(object source, object message, Exception exception)
    {
      Warn(source.GetType(), message, exception);
    }

    /// <summary>
    /// 警告信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Warn(Type source, object message, Exception exception)
    {
      GetLogger(source).Warn(message, exception);
    }

    /// <summary>
    /// 錯誤信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Error(object source, object message, Exception exception)
    {
      Error(source.GetType(), message, exception);
    }

    /// <summary>
    /// 錯誤信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Error(Type source, object message, Exception exception)
    {
      GetLogger(source).Error(message, exception);
    }

    /// <summary>
    /// 失敗信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Fatal(object source, object message, Exception exception)
    {
      Fatal(source.GetType(), message, exception);
    }

    /// <summary>
    /// 失敗信息
    /// </summary>
    /// <param name="source"></param>
    /// <param name="message"></param>
    /// <param name="exception"></param>
    public static void Fatal(Type source, object message, Exception exception)
    {
      GetLogger(source).Fatal(message, exception);
    }
  }

}

配置和Helper類都有了..現(xiàn)在來看看調用方法。在項目中創(chuàng)建一個index.aspx頁面

LogHelper.Debug(this, "Debug");
LogHelper.Error(this, "Error");
LogHelper.Fatal(this, "Fatal");
LogHelper.Info(this, "Info");
LogHelper.Warn(this, "Warn");

日志生成格式[每天一個文件]:


參數(shù)說明

Log4Net.config是配置日志輸出參數(shù)文件。在這個文件中可以到看很多配置節(jié)點,大體可以分為二個大類<configSections>...</configSections> 和 <log4net>...</log4net>。我們來看看這些節(jié)點都是啥意思。

1:<configSections>..</configSections>:申明自定義節(jié)點log4net解析的類名和程序集名(log4net.dll)。
2:<log4net>..</log4net>:使用log4net的配置信息都在這里設置。來重點看看都有那些設置信息,這個大節(jié)點整體也可以分為二類。

2.1:定義輸出信息設置節(jié)點<appender></appender>。
2.2:定義日志的輸出媒介<root></root>。

配置的總體結構就是這樣,下面來看一些詳細內容。

appender:決定日志輸出的方式(可設置多個節(jié)點,如對INFO,ERROR等設置不同的輸出方式)。

主要包括已下幾種:

1 AnsiColorTerminalAppender:在ANSI 窗口終端寫下高亮度的日志事件。
2 AspNetTraceAppender:能用asp.net中Trace的方式查看記錄的日志。
3 BufferingForwardingAppender:在輸出到子Appenders之前先緩存日志事件。
4 ConsoleAppender:將日志輸出到控制臺。
5 EventLogAppender:將日志寫到Windows Event Log.
6 FileAppender:將日志寫到文件中。
7 LocalSyslogAppender:將日志寫到local syslog service (僅用于UNIX環(huán)境下).
8 MemoryAppender:將日志存到內存緩沖區(qū)。
9 NetSendAppender:將日志輸出到Windows Messenger service.這些日志信息將在用戶終端的對話框中顯示。
10 RemoteSyslogAppender:通過UDP網(wǎng)絡協(xié)議將日志寫到Remote syslog service。
11 RemotingAppender:通過.NET Remoting將日志寫到遠程接收端。
12 RollingFileAppender:將日志以回滾文件的形式寫到文件中。(實例代碼中使用的是此類型)
13 SmtpAppender:將日志寫到郵件中。
14 TraceAppender:將日志寫到.NET trace 系統(tǒng)。
15 UdpAppender:將日志connectionless UDP datagrams的形式送到遠程宿主或以UdpClient的形式廣播。

從上面提供的方式中可以看出能輸出文件、控制臺、Windows事件日志和數(shù)據(jù)庫。這個可根據(jù)實際情況選擇。

復制代碼 代碼如下:

<appender name="Log4Net_INFO" type="log4net.Appender.RollingFileAppender">
...
</appender>

這里配置的name(“Log4Net_INFO”)會在定義日志的輸出媒介中使用到。name可任意設置。

在appender 節(jié)點中還會配置一些文件存放的地址,日志個數(shù)等信息。這些在實例代碼中都在體現(xiàn),這里不做說明。我們在來看看日志最后輸出呈現(xiàn)的布局設置信息。

<layout type="log4net.Layout.PatternLayout">
    <!--頭-->
    <Header value="[Header]"/>
    <!--腳注-->
    <Footer value="[Footer]"/>
    <!--正文-->
    <ConversionPattern value="%d [%t] %-5p %c [%x] - %m%n" />
</layout>

這里配置的信息最終是日志打印出來的樣式。我們可以看到這里可以設置內容頭Header和尾Footer。正文ConversionPattern。在正文中有出現(xiàn)有 %d [%t]這些都是啥意思了表示什么。這里有一個對照表可提供參考:

%m(message):輸出的日志消息,如ILog.Debug(…)輸出的一條消息
%n(new line):換行
%d(datetime):輸出當前語句運行的時刻
%r(run time):輸出程序從運行到執(zhí)行到當前語句時消耗的毫秒數(shù)
%t(thread id):當前語句所在的線程ID
%p(priority): 日志的當前優(yōu)先級別,即DEBUG、INFO、WARN…等
%c(class):當前日志對象的名稱,例如:
%L:輸出語句所在的行號
%F:輸出語句所在的文件名
%-數(shù)字:表示該項的最小長度,如果不夠,則用空格填充

配置的基本也就這些。下就是root的配置說明 。

root:

對設置輸出的方式進行指定。

<root>
   <!--批定DEBUG輸出的文件形式記錄日志-->
   <level value="DEBUG"/>
   <appender-ref ref="Log4Net_ERROR" />
 
  <!--批定INFO輸出的文件形式記錄日志-->
   <level value="INFO"/>
   <appender-ref ref="Log4Net_INFO" />
</root>

控制級別,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF
比如定義級別為INFO,則INFO級別向下的級別,比如DEBUG日志將不會被記錄
如果沒有定義LEVEL的值,則缺省為DEBUG

附帶源碼:代碼

相關文章

  • C# 對象持久化詳解

    C# 對象持久化詳解

    本文介紹的是除數(shù)據(jù)庫之外的幾種對象持久化方式。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • C#中值類型和引用類型的區(qū)別

    C#中值類型和引用類型的區(qū)別

    這篇文章介紹了C#中值類型和引用類型的區(qū)別,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-03-03
  • C#實現(xiàn)的幾種委托方式介紹

    C#實現(xiàn)的幾種委托方式介紹

    這篇文章主要是介紹C#實現(xiàn)的幾種委托方式,需要的朋友可以參考下
    2013-03-03
  • C#使用System.Threading.Timer實現(xiàn)計時器的示例詳解

    C#使用System.Threading.Timer實現(xiàn)計時器的示例詳解

    以往一般都是用 System.Timers.Timer 來做計時器,其實 System.Threading.Timer 也可以實現(xiàn)計時器功能,下面就跟隨小編一起來學習一下如何使用System.Threading.Timer實現(xiàn)計時器功能吧
    2024-01-01
  • C# 多線程更新界面的錯誤的解決方法

    C# 多線程更新界面的錯誤的解決方法

    這篇文章主要介紹了C# 多線程更新界面的錯誤方法,由于一個線程的程序,如果調用一個功能是阻塞的,那么就會影響到界面的更新,導致使用人員操作不便。所以往往會引入雙線程的工作的方式,主線程負責更新界面和調度,而次線程負責做一些阻塞的工作,便有了下面春雨里方法
    2021-10-10
  • C# List中FindAll用法的一些簡單示例

    C# List中FindAll用法的一些簡單示例

    本篇文章只要是對C# List中FindAll用法的一些簡單示例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • Unity中3DText顯示模糊不清的解決方案

    Unity中3DText顯示模糊不清的解決方案

    這篇文章主要介紹了Unity中3DText顯示模糊不清的解決方案,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • C#日期時間類的使用方法(DateTime類、TimeSpan類與DateTimeOffset類)

    C#日期時間類的使用方法(DateTime類、TimeSpan類與DateTimeOffset類)

    在C#中我們常使用到關于時間的相關操作,這篇文章主要給大家介紹了關于C#日期時間類的使用方法,文中介紹的方法分別包括DateTime類、TimeSpan類與DateTimeOffset類的相關資料,需要的朋友可以參考下
    2023-11-11
  • 如何在Unity中檢測死循環(huán)和卡死

    如何在Unity中檢測死循環(huán)和卡死

    這篇文章主要介紹了在Unity中檢測死循環(huán)和卡死的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • c# delegate和event的使用說明

    c# delegate和event的使用說明

    這篇文章主要介紹了c# delegate和event的使用說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04

最新評論