溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用C#中net日志庫

發(fā)布時間:2021-10-11 21:08:04 來源:億速云 閱讀:134 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“如何使用C#中net日志庫”,在日常操作中,相信很多人在如何使用C#中net日志庫問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何使用C#中net日志庫”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

目錄
  • 一、簡述

  • 二、下載log4net

  • 三、添加log4net.dll引用

  • 四、添加日志配置log.config

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

  • 六、測試?yán)?/p>

    • 6.1 測試代碼

    • 6.2 效果

  • 七、附

    • 7.1 更多日志配置

    • 7.2 日志格式

    • 7.3 日志配置

一、簡述

記--log4net日志開源庫的簡單使用:控制日志文件大小,日志文件個數(shù),滾動式覆蓋,自由控制日志打印等級

二、下載log4net

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

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

如何使用C#中net日志庫

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

如何使用C#中net日志庫

三、添加log4net.dll引用

如何使用C#中net日志庫

四、添加日志配置log.config

如何使用C#中net日志庫

編輯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)行滾動記錄,也可以按日期-->
      <maxSizeRollBackups value="2" />  <!--最多兩個日志備份,app.log.1 app.log.2-->
      <maximumFileSize value="8KB" /> <!--日志文件達(dá)到8KB就重新記一個文件-->
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <!--每一行日志輸出格式-->
        <conversionPattern value="%date [%thread] (%file:%line) %-5level %logger - %message%newline" />
      </layout>
    </appender>
 
    <logger name="Mylog1">  <!--代碼通過Mylog1獲取對應(yīng)的logger句柄-->
        <level value="WARN" /> <!--比WARN等級低的不會輸出 日志等級由高到低:OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
        <appender-ref ref="MyAppender1" /> <!--啟用MyAppender1-->
    </logger>
  </log4net>
</configuration>

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

如何使用C#中net日志庫

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

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

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

如何使用C#中net日志庫

六、測試?yán)?/h3>

6.1 測試代碼

namespace Log4netTest
{
    public partial class Form1 : Form
    {
        //Mylog1對應(yīng)log.config種的一個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對應(yīng)log.config中的一個logger名稱

6.2 效果

控制日志文件大小,日志文件個數(shù),滾動式覆蓋,控制日志打印等級為WARN。

如何使用C#中net日志庫

如何使用C#中net日志庫

七、附

7.1 更多日志配置

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

如何使用C#中net日志庫

7.2 日志格式

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

7.3 日志配置

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

如何使用C#中net日志庫

到此,關(guān)于“如何使用C#中net日志庫”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

net
AI