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

C# log4net日志庫(kù)的用法小結(jié)

 更新時(shí)間:2021年10月11日 16:11:20   作者:Genven_Liang  
log4net日志開源庫(kù)是用來(lái)控制日志文件大小,日志文件個(gè)數(shù),滾動(dòng)式覆蓋,自由控制日志打印等級(jí),今天通過(guò)本文給大家介紹C# log4net日志庫(kù)的用法小結(jié),感興趣的朋友一起看看吧

一、簡(jiǎn)述

記--log4net日志開源庫(kù)的簡(jiǎn)單使用:控制日志文件大小,日志文件個(gè)數(shù),滾動(dòng)式覆蓋,自由控制日志打印等級(jí)

例子打包:

http://xiazai.jb51.net/202110/yuanma/Log4netTest_jb51.rar

http://xiazai.jb51.net/202110/yuanma/apache-log4net-source_jb51.rar

http://xiazai.jb51.net/202110/yuanma/apache-log4net-binaries_jb51.rar

二、下載log4net

直接使用log4net源碼或直接使用log4net源碼編譯對(duì)應(yīng)的dll或直接使用log4net.dll

下載地址:http://logging.apache.org/log4net/download_log4net.html

例子直接使用其中4.5的dll。(請(qǐng)根據(jù)當(dāng)前環(huán)境的.net framework框架版本進(jìn)行選擇,請(qǐng)看右鍵項(xiàng)目--》屬性--》應(yīng)用程序--》目標(biāo)框架)

三、添加log4net.dll引用

四、添加日志配置log.config

編輯log.config內(nèi)容如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <appender name="MyAppender1" type="log4net.Appender.RollingFileAppender">
      <file value="app.log" />  <!--日志文件名-->
      <appendToFile value="true" /> <!--日志文件以追加方式進(jìn)行-->
      <rollingStyle value="Size" />   <!--按文件大小進(jìn)行滾動(dòng)記錄,也可以按日期-->
      <maxSizeRollBackups value="2" />  <!--最多兩個(gè)日志備份,app.log.1 app.log.2-->
      <maximumFileSize value="8KB" /> <!--日志文件達(dá)到8KB就重新記一個(gè)文件-->
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <!--每一行日志輸出格式-->
        <conversionPattern value="%date [%thread] (%file:%line) %-5level %logger - %message%newline" />
      </layout>
    </appender>
 
    <logger name="Mylog1">  <!--代碼通過(guò)Mylog1獲取對(duì)應(yīng)的logger句柄-->
        <level value="WARN" /> <!--比WARN等級(jí)低的不會(huì)輸出 日志等級(jí)由高到低:OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
        <appender-ref ref="MyAppender1" /> <!--啟用MyAppender1-->
    </logger>
  </log4net>
</configuration>

將配置同步更新到exe輸出路徑

五、在AssemblyInfo.cs文件中添加log4net.dll相關(guān)參數(shù)

在AssemblyInfo.cs文件末尾添加一行(其中的log.config就是步驟四添加的配置文件)

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log.config", Watch = true)]

六、測(cè)試?yán)?/h2>

6.1 測(cè)試代碼

namespace Log4netTest
{
    public partial class Form1 : Form
    {
        //Mylog1對(duì)應(yīng)log.config種的一個(gè)logger名稱
        public static readonly log4net.ILog mLogger = log4net.LogManager.GetLogger("Mylog1");
 
        public Form1()
        {
            InitializeComponent();
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
            mLogger.Error("APP Start");
            mLogger.Debug("logDebug");
            mLogger.Info("logInfo");
            mLogger.Warn("logWarn");
            mLogger.Error("logError");
            mLogger.Error(this);
        }
    }

注:代碼種的Mylog1對(duì)應(yīng)log.config中的一個(gè)logger名稱

6.2 效果

控制日志文件大小,日志文件個(gè)數(shù),滾動(dòng)式覆蓋,控制日志打印等級(jí)為WARN。

七、附

7.1 更多日志配置

http://logging.apache.org/log4net/release/manual/configuration.html

7.2 日志格式

%m(message):輸出的日志消息,如ILog.Debug(…)輸出的一條消息
%n(new line):換行
%d(datetime):輸出當(dāng)前語(yǔ)句運(yùn)行的時(shí)刻
%r(run time):輸出程序從運(yùn)行到執(zhí)行到當(dāng)前語(yǔ)句時(shí)消耗的毫秒數(shù)
%t(thread id):當(dāng)前語(yǔ)句所在的線程ID
%p(priority): 日志的當(dāng)前優(yōu)先級(jí)別,即DEBUG、INFO、WARN…等
%c(class):當(dāng)前日志對(duì)象的名稱,例如:
%f(file):輸出語(yǔ)句所在的文件名。
%l(line):輸出語(yǔ)句所在的行號(hào)。
%數(shù)字:表示該項(xiàng)的最小長(zhǎng)度,如果不夠,則用空格填充,如“%-5level”表示level的最小寬度是5個(gè)字符,如果實(shí)際長(zhǎng)度不夠5個(gè)字符則以空格填充

7.3 日志配置

appender、logger標(biāo)簽可多個(gè),不是一一對(duì)應(yīng)關(guān)系的

到此這篇關(guān)于C# log4net日志庫(kù)的簡(jiǎn)單使用的文章就介紹到這了,更多相關(guān)C# log4net使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#?線程切換后上下文都去了哪里(.NET高級(jí)調(diào)試分析)

    C#?線程切換后上下文都去了哪里(.NET高級(jí)調(diào)試分析)

    總會(huì)有一些朋友問(wèn)一個(gè)問(wèn)題,在 Windows 中線程做了上下文切換,請(qǐng)問(wèn)被切的線程他的寄存器上下文都去了哪里?這個(gè)問(wèn)題其實(shí)比較底層,如果對(duì)操作系統(tǒng)沒(méi)有個(gè)體系層面的理解以及做過(guò)源碼分析,其實(shí)很難說(shuō)明白,這篇我們就從.NET高級(jí)調(diào)試的角度分析,需要的朋友可以參考下
    2023-12-12
  • c# WinForm 窗體之間傳值的幾種方式(小結(jié))

    c# WinForm 窗體之間傳值的幾種方式(小結(jié))

    這篇文章主要介紹了WinForm 窗體之間傳值的幾種方式(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 基于C#實(shí)現(xiàn)Ping工具類

    基于C#實(shí)現(xiàn)Ping工具類

    Ping是一種常用的測(cè)試網(wǎng)絡(luò)連接的工具,可以測(cè)試網(wǎng)絡(luò)延遲和連接狀況,以及判斷網(wǎng)絡(luò)是否可用,本文將通過(guò)框架類庫(kù)中的Ping類來(lái)實(shí)現(xiàn)Ping功能,感興趣的小伙伴可以了解下
    2023-11-11
  • C#利用VS中插件打包并發(fā)布winfrom程序

    C#利用VS中插件打包并發(fā)布winfrom程序

    這篇文章主要為大家詳細(xì)介紹了C#利用VS中插件打包并發(fā)布winfrom程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • C#繪制時(shí)鐘的方法

    C#繪制時(shí)鐘的方法

    這篇文章主要為大家詳細(xì)介紹了C#繪制時(shí)鐘的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C#圖像線性變換的方法

    C#圖像線性變換的方法

    這篇文章主要介紹了C#圖像線性變換的方法,涉及C#操作圖像線性變換的相關(guān)技巧,需要的朋友可以參考下
    2015-04-04
  • C#通過(guò)WIN32 API實(shí)現(xiàn)嵌入程序窗體

    C#通過(guò)WIN32 API實(shí)現(xiàn)嵌入程序窗體

    這篇文章主要介紹了C#通過(guò)WIN32 API實(shí)現(xiàn)嵌入程序窗體的方法,涉及WIN32 API的調(diào)用及窗體的設(shè)計(jì),具有很好的借鑒價(jià)值,需要的朋友可以參考下
    2014-09-09
  • WPF使用WrapPanel實(shí)現(xiàn)虛擬化效果

    WPF使用WrapPanel實(shí)現(xiàn)虛擬化效果

    這篇文章主要為大家詳細(xì)介紹了如何利用WPF WrapPanel實(shí)現(xiàn)虛擬化效果,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)或工作有一定幫助,感興趣的小伙伴可以了解一下
    2022-09-09
  • C#9.0主要特性的一些想法

    C#9.0主要特性的一些想法

    這篇文章主要給大家介紹了關(guān)于C#9.0主要特性的一些想法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • C# 位運(yùn)算符整理

    C# 位運(yùn)算符整理

    在C#中可以對(duì)整型運(yùn)算對(duì)象按位進(jìn)行邏輯運(yùn)算。按位進(jìn)行邏輯運(yùn)算的意義是:依次取被運(yùn)算對(duì)象的每個(gè)位,進(jìn)行邏輯運(yùn)算,每個(gè)位的邏輯運(yùn)算結(jié)果是結(jié)果值的每個(gè)位。
    2008-10-10

最新評(píng)論