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

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

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

背景

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

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

插件簡(jiǎn)介

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

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

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

插件安裝

在項(xiàng)目中添加對(duì) Log4net 的引用。可以使用 NuGet 包管理器來(lái)安裝 Log4net。

選擇一個(gè)合適版本進(jìn)行安裝,博主這里選擇最新版本安裝。

配置文件

日志類型

在 log4net 中,日志類型一般分為以下幾種,對(duì)應(yīng)不同的日志級(jí)別:

1.DEBUG

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

2.INFO

用于記錄程序正常運(yùn)行時(shí)的重要信息,比如服務(wù)啟動(dòng)、關(guān)鍵流程開始或結(jié)束等。對(duì)于用戶而言,通常不需要關(guān)注 INFO 級(jí)別的日志,但這些日志對(duì)于開發(fā)人員來(lái)說(shuō)非常重要。

3.WARN

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

4.ERROR

用于記錄錯(cuò)誤事件,但不會(huì)導(dǎo)致程序終止。比如捕獲到了一個(gè)異常,程序進(jìn)行了相應(yīng)的處理,不會(huì)導(dǎo)致程序崩潰。ERROR 級(jí)別的日志通常需要開發(fā)人員及時(shí)關(guān)注并處理。

5.FATAL

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

文件詳情

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

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!--定義日志級(jí)別-->
    <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>

    <!--嚴(yán)重錯(cuò)誤日志-->
    <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>

    <!--調(diào)試日志-->
    <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>

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

日志設(shè)置

命名空間

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

實(shí)例化

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

日志調(diào)用

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");
}

輸出控制臺(tái)

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

使用的類型是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ù)上面默認(rèn)配置文件信息,日志信息輸出到文本文檔里。

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

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!--定義日志級(jí)別-->
    <root>
        <level value="DEBUG"/>
        <appender-ref ref="DebugAppender" />
    </root>
 
    <!--調(diào)試日志-->
    <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>

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

相關(guān)文章

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

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

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

    C#中的類繼承詳解

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

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

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

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

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

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

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

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

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

    詳解c# 中的DateTime

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

    基于C#自制批量doc轉(zhuǎn)換為docx的小工具

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

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

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

    聊一聊C#接口問(wèn)題 新手速來(lái)圍觀

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

最新評(píng)論