1. 程式人生 > >C# 日誌的配置流程

C# 日誌的配置流程

client attr bsp 重復 一個 erro ilog 復制代碼 ext

轉載自https://www.cnblogs.com/SuperMetalMax/p/6203188.html

1. 下載log4net.dll文件

http://download.csdn.net/detail/abc456456456456/7653857

2. 項目中引用此dll

3. appconfig中配置log4net

技術分享
<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
  </configSections>
  <log4net>
    <!-- 日誌文件配置-->
    <root>
      <level value="ALL" />
      <appender-ref ref="RollingLogFileAppender" />
    </root>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <appender name="FileAppender" type="log4net.Appender.FileAppender">
      <file value="logs/dd/%date.txt" />
      <appendToFile value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="logs\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="10" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyy-MM-dd&quot;.log&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%date [%thread] %-5level %logger MapConnectStringproperty{NDC}] - %message%newline" />
      </layout>
    </appender>
  </log4net>
</configuration>
技術分享

配置說明:

<log4net>

  <root>

    <!--控制級別,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->

    <!--比如定義級別為INFO,則INFO級別向下的級別,比如DEBUG日誌將不會被記錄-->

    <!--如果沒有定義LEVEL的值,則缺省為DEBUG-->

    <level value="ERROR"/>

    <appender-ref ref="RollingFileAppender"/>

  </root>

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

    <!--日誌文件名開頭-->

    <file value="c:\Log\TestLog4net.TXT"/>

    <!--多線程時采用最小鎖定-->

    <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>

    <!--日期的格式,每天換一個文件記錄,如不設置則永遠只記錄一天的日誌,需設置-->

    <datePattern value="(yyyyMMdd)"/>

    <!--是否追加到文件,默認為true,通常無需設置-->

    <appendToFile value="true"/>

    <!--變換的形式為日期,這種情況下每天只有一個日誌-->

    <!--此時MaxSizeRollBackups和maximumFileSize的節點設置沒有意義-->

    <!--<rollingStyle value="Date"/>-->

    <!--變換的形式為日誌大小-->

    <!--這種情況下MaxSizeRollBackups和maximumFileSize的節點設置才有意義-->

    <RollingStyle value="Size"/>

    <!--每天記錄的日誌文件個數,與maximumFileSize配合使用-->

    <MaxSizeRollBackups value="10"/>

    <!--每個日誌文件的最大大小-->

    <!--可用的單位:KB|MB|GB-->

    <!--不要使用小數,否則會一直寫入當前日誌-->

    <maximumFileSize value="2MB"/>

    <!--日誌格式-->

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

      <conversionPattern value="%date [%t]%-5p %c - %m%n"/>

    </layout>

  </appender>

</log4net>

其中layout節點的配置說明:

   %m(message):輸出的日誌消息;
%n(newline):換行;
%d(datetime):輸出當前語句運行的時刻;
%r(runtime):輸出程序從運行到執行到當前語句時消耗的毫秒數;
%t(threadid):當前語句所在的線程ID ;
%p(priority): 日誌的當前日誌級別;
%c(class):當前日誌對象的名稱;
%L:輸出語句所在的行號;
%F:輸出語句所在的文件名;
%-10:表示最小長度為10,如果不夠,則用空格填充;

4. AssemblyInfo.cs 中添加"[assembly: log4net.Config.XmlConfigurator(Watch = true)]"

[assembly: log4net.Config.XmlConfigurator(Watch = true)]   

5.Winform中調用

private static readonly log4net.ILog Logger = log4net.LogManager.GetLogger(typeof(FrmLog));
Logger.Debug("測試debug");

註意:

1.如果出現"類型初始值設定項引發異常"類似的文字,首先查看 app.config配置中 <configSections> 元素,必須是根<configuration> 元素的第一個子元素。

2.項目的目標框架為.NET Framework 3.5(或者4) Client Profile時會報出下圖錯誤,改成.NET Framework 3.5(或者4) 即可。

技術分享 3.對於大量記日誌的程序,需註意配置RollingStyle值為Composite,且設置MaxSizeRollBackups(每天記錄的日誌文件個數)和maximumFileSize(每個日誌文件的最大大小)。我以前遇過一次日誌過大的問題,有一次版本臨時發布就改了一個方法而沒有經過測試,造成每天記幾十G日誌的,幾天就把服務器磁盤弄滿了。 4.當發現不記日誌時,可從兩方面調查問題, 一是log4net有沒有初始化,也就是XmlConfigurator.Configure(); 二是看level節點的配置是不是正確; 5.當發現一些設置參數沒有起作用時,請檢查是不是同一個節點被設置過多次,當被重復設置時,log4net會選擇最後一個作為實際的設置。 例如設置記錄日誌的級別設置兩次如<level value="ERROR"/><level value="All"/>,則最終會以ALL作為記錄日誌的級別。 6.如果是網站項目,須在項目中的AssemblyInfo.cs文件的最後一行中添加:
[assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)]   

C# 日誌的配置流程