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

C#使用Log4net實現(xiàn)將日志輸出到控制臺或者文本文檔

 更新時間:2024年03月13日 08:35:35   作者:全棧小5  
Log4net?是一個穩(wěn)定且功能豐富的日志庫,已經存在多年并且被廣泛使用,這篇文章主要為大家介紹了如何使用Log4net實現(xiàn)將日志輸出到控制臺或者文本文檔,感興趣的可以了解下

背景

最近在最一些并發(fā)方式的測試,發(fā)現(xiàn)自己之前封裝的一個日志插件報錯,盡管在寫日志時已經通過鎖的方式進行了優(yōu)化,但是依然無法解決并發(fā)時同一個文件同時訪問情況,會頻繁出現(xiàn)報錯提示xxx.txt文件正在被另一個進程訪問而不無法操作。

基于這個原因,暫時沒有想好很好的優(yōu)化方案,從而考慮使用第三方優(yōu)秀日志插件來解決并發(fā)情況。

插件簡介

Log4net 是一個穩(wěn)定且功能豐富的日志庫,已經存在多年并且被廣泛使用。

它支持多種輸出目標和格式,可以滿足各種日志記錄需求。

Log4net 具有靈活的配置選項,允許你根據(jù)需要定制日志記錄行為。

插件安裝

在項目中添加對 Log4net 的引用??梢允褂?NuGet 包管理器來安裝 Log4net。

選擇一個合適版本進行安裝,博主這里選擇最新版本安裝。

配置文件

日志類型

在 log4net 中,日志類型一般分為以下幾種,對應不同的日志級別:

1.DEBUG

最詳細的日志級別,通常用于打印一些調試信息,僅在開發(fā)和調試階段使用,生產環(huán)境中通常不會記錄 DEBUG 級別的日志。

2.INFO

用于記錄程序正常運行時的重要信息,比如服務啟動、關鍵流程開始或結束等。對于用戶而言,通常不需要關注 INFO 級別的日志,但這些日志對于開發(fā)人員來說非常重要。

3.WARN

表明潛在的問題,但不會影響系統(tǒng)正常運行,比如某個接口請求參數(shù)不合法,程序采取了默認值處理;或者磁盤空間不足,但系統(tǒng)仍然能夠正常運行。WARN 級別的日志用于提示開發(fā)人員和運維人員需要注意的問題。

4.ERROR

用于記錄錯誤事件,但不會導致程序終止。比如捕獲到了一個異常,程序進行了相應的處理,不會導致程序崩潰。ERROR 級別的日志通常需要開發(fā)人員及時關注并處理。

5.FATAL

表示嚴重的錯誤事件,可能導致程序終止。比如未捕獲的異常、數(shù)據(jù)庫連接失敗等致命錯誤。FATAL 級別的日志表示系統(tǒng)出現(xiàn)了嚴重的錯誤,需要立即處理。

文件詳情

此配置文件內容,按日志級別創(chuàng)建文件,按時間年月日時來創(chuàng)建文件名,同一小時內超過10M文件大小則拆分文件保存。

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!--定義日志級別-->
    <root>
        <level value="FATAL"/>
        <level value="ERROR"/>
        <level value="WARN"/>
        <level value="INFO"/>
        <level value="DEBUG"/>
        <appender-ref ref="FATALAppender" />
        <appender-ref ref="ERRORAppender" />
        <appender-ref ref="WARNAppender" />
        <appender-ref ref="INFOAppender" />
        <appender-ref ref="DebugAppender" />
    </root>

    <!--嚴重錯誤日志-->
    <appender name="FATALAppender" type="log4net.Appender.RollingFileAppender">
        <file type="log4net.Util.PatternString" value="logs\Fatal\%date{yyyyMMddHH}.log" />

        <appendToFile value="true" />
        <rollingStyle value="Size" />
        <staticLogFileName value="false"/>
        <maximumFileSize value="100KB"/>
        <maxSizeRollBackups value="-1"/>

        <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" />
        </layout>
    </appender>

    <!--調試日志-->
    <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender">
        <file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" />

        <appendToFile value="true" />
        <rollingStyle value="Size" />
        <staticLogFileName value="false"/>
        <maximumFileSize value="100KB"/>
        <maxSizeRollBackups value="-1"/>

        <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" />
        </layout>
    </appender>
</log4net>

通過使用不同級別的日志記錄,開發(fā)人員和運維人員可以更好地了解系統(tǒng)的運行情況,及時發(fā)現(xiàn)潛在問題,并采取相應的措施進行處理。

日志設置

命名空間

using log4net;
using log4net.Config;
using System.Reflection;

實例化

// 日志插件
var logRepository = LogManager.GetRepository(Assembly.GetEntryAssembly());
XmlConfigurator.Configure(logRepository, new FileInfo(Path.Combine(AppContext.BaseDirectory, "log4net.config")));

日志調用

private static readonly ILog log = LogManager.GetLogger(typeof(SqlHelper));

public void Test()
{    
    log.Fatal("Fatal message");
    log.Debug("Debug message");
    log.Info("Info message");
    log.Warn("Warn message");
    log.Error("Error message");
}

輸出控制臺

根據(jù)上面默認配置文件信息,日志信息輸出到控制臺里。

使用的類型是log4net.Appender.ConsoleAppender

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
        <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger - %message%line" />
            </layout>
        </appender>

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

輸出文本文檔

根據(jù)上面默認配置文件信息,日志信息輸出到文本文檔里。

使用的類型是log4net.Appender.Appender.RollingFileAppender

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!--定義日志級別-->
    <root>
        <level value="DEBUG"/>
        <appender-ref ref="DebugAppender" />
    </root>
 
    <!--調試日志-->
    <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender">
        <file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" />

        <appendToFile value="true" />
        <rollingStyle value="Size" />
        <staticLogFileName value="false"/>
        <maximumFileSize value="100KB"/>
        <maxSizeRollBackups value="-1"/>

        <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" />
        </layout>
    </appender>
</log4net>

到此這篇關于C#使用Log4net實現(xiàn)將日志輸出到控制臺或者文本文檔的文章就介紹到這了,更多相關C# Log4net日志輸出內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • WPF用狀態(tài)模式開發(fā)截圖功能

    WPF用狀態(tài)模式開發(fā)截圖功能

    狀態(tài)模式是設計模式中的一種行為設計模式,尤其在游戲中開發(fā)中還是比較常見的,本文將通過狀態(tài)模式開發(fā)一個截圖功能,有需要的小伙伴可以參考下
    2025-03-03
  • C#中的類繼承詳解

    C#中的類繼承詳解

    大家好,本篇文章主要講的是C#中的類繼承詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • C#實現(xiàn)操作PPT動畫窗格并插入音頻文件

    C#實現(xiàn)操作PPT動畫窗格并插入音頻文件

    這篇文章主要為大家詳細介紹了如何利用C#實現(xiàn)操作PPT動畫窗格并插入音頻文件,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-10-10
  • C#實現(xiàn)帶搜索功能的ComboBox

    C#實現(xiàn)帶搜索功能的ComboBox

    這篇文章主要為大家詳細介紹了C#如何實現(xiàn)帶搜索功能的ComboBox,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • 解析C#中如何把控件的邊框角畫為圓弧

    解析C#中如何把控件的邊框角畫為圓弧

    以下是對C#中把控件的邊框角畫為圓弧的實現(xiàn)代碼進行了介紹,需要的朋友可以參考下
    2013-07-07
  • C#實現(xiàn)線段樹的示例代碼

    C#實現(xiàn)線段樹的示例代碼

    線段樹是一種常用來維護區(qū)間信息的數(shù)據(jù)結構,本文主要介紹了C#實現(xiàn)線段樹的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • 詳解c# 中的DateTime

    詳解c# 中的DateTime

    這篇文章主要介紹了c# 中的DateTime的相關資料,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-07-07
  • 基于C#自制批量doc轉換為docx的小工具

    基于C#自制批量doc轉換為docx的小工具

    "doc"?文件是一種常見的文件格式,通常用于存儲文本文檔,"docx"?文件是?Microsoft?Word?2007?及更高版本中使用的文檔文件格式的擴展名,下面我們就來看看如何使用C#實現(xiàn)批量doc轉換為docx吧
    2024-03-03
  • C#實現(xiàn)XML序列化與反序列化

    C#實現(xiàn)XML序列化與反序列化

    這篇文章介紹了C#實現(xiàn)XML序列化與反序列化的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 聊一聊C#接口問題 新手速來圍觀

    聊一聊C#接口問題 新手速來圍觀

    聊一聊C#接口問題,新手速來圍觀,一個通俗易懂的例子幫助大家更好的理解C#接口問題,感興趣的小伙伴們可以參考一下
    2016-08-08

最新評論