C# log4net 的配置文件配置项详细介绍(配置示例)

 更新时间:2025年05月09日 10:40:08   作者:搬砖工程师Cola  
log4net 是一个功能强大的日志记录工具,通过配置文件可以灵活地控制日志的输出方式、格式、级别等,下面给大家分享C# log4net 的配置文件配置项详细介绍,感兴趣的朋友一起看看吧

log4net 是一个功能强大的日志记录工具,通过配置文件可以灵活地控制日志的输出方式、格式、级别等。以下是对 log4net 配置文件常见配置项的详细介绍:

根元素 <log4net>

这是 log4net 配置文件的根元素,所有配置项都要包含在该元素内。

<log4net>
    <!-- 其他配置项 -->
</log4net>

附加器(Appenders) <appender>

附加器用于指定日志的输出目标,比如文件、控制台、数据库等。log4net 提供了多种内置的附加器,你也可以自定义附加器。每个附加器都有一个唯一的名称,可通过 name 属性来指定。

1. 控制台附加器(ConsoleAppender)

将日志输出到控制台。

<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
    <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
</appender>
  • type:指定附加器的类型,这里是 log4net.Appender.ConsoleAppender
  • <layout>:定义日志的输出格式,使用 PatternLayout 可以自定义格式,conversionPattern 指定具体的格式字符串。
  • 在 log4net.Layout.PatternLayout 里,借助转换模式字符串能够自定义日志输出的格式,此字符串由一系列标记构成。下面为你详细介绍常用的标记及其用途:

基本信息标记

  • %date:输出日志记录的日期和时间,默认格式是 yyyy-MM-dd HH:mm:ss,fff,可通过 %date{format} 来指定格式,像 %date{HH:mm:ss}%level:输出日志的级别(例如 DEBUGINFOWARNERRORFATAL)。
  • %logger:输出记录日志的记录器名称。%message:输出日志的具体消息内容。
  • %newline:输出一个换行符。

线程与上下文标记

  • %thread:输出产生日志记录的线程名称。
  • %property{name}:输出线程上下文属性中指定名称的值。比如,你可以在代码里设置 log4net.ThreadContext.Properties["UserName"] = "John";,接着使用 %property{UserName} 输出。

类与方法标记

  • %class:输出记录日志的类的全限定名。
  • %method:输出记录日志的方法名。

位置信息标记

  • %file:输出记录日志的源文件名称。
  • %line:输出记录日志的代码所在的行号。

栈跟踪标记

  • %exception:输出异常的堆栈跟踪信息,通常用于 ERROR 或 FATAL 级别的日志。

2. 文件附加器(FileAppender 和 RollingFileAppender)

将日志输出到文件。RollingFileAppender 支持文件滚动,当文件达到一定大小或日期变化时,会创建新的日志文件。

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
    <file value="logs\log.txt" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="10" />
    <maximumFileSize value="10MB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
</appender>
  • <file>:指定日志文件的路径和名称。
  • <appendToFile>:设置是否将日志追加到现有文件中。
  • <rollingStyle>:指定文件滚动的方式,可选值有 Size(按文件大小滚动)、Date(按日期滚动)等。
  • <maxSizeRollBackups>:指定保留的旧日志文件的最大数量。
  • <maximumFileSize>:指定每个日志文件的最大大小。
  • <staticLogFileName>:设置是否使用静态的日志文件名。

3. 数据库附加器(AdoNetAppender)

将日志存储到数据库中。

<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
    <bufferSize value="1" />
    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
    <connectionString value="Data Source=SERVER_NAME;Initial Catalog=DATABASE_NAME;User ID=USERNAME;Password=PASSWORD" />
    <commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
    <parameter>
        <parameterName value="@log_date" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
    </parameter>
    <parameter>
        <parameterName value="@thread" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%thread" />
        </layout>
    </parameter>
    <!-- 其他参数 -->
</appender>
  • <bufferSize>:指定日志记录的缓冲区大小。
  • <connectionType>:指定数据库连接类型。
  • <connectionString>:指定数据库连接字符串。
  • <commandText>:指定插入日志记录的 SQL 语句。
  • <parameter>:定义 SQL 语句中的参数,包括参数名、数据类型和布局。

记录器(Loggers) <logger> 和 <root>

记录器用于控制不同命名空间或类的日志输出级别和使用的附加器。

1. 根记录器(Root Logger) <root>

根记录器是所有记录器的父记录器,为整个应用程序设置默认的日志级别和附加器。

<root>
    <level value="ALL" />
    <appender-ref ref="ConsoleAppender" />
    <appender-ref ref="RollingFileAppender" />
</root>
  • <level>:指定日志的输出级别,可选值有 ALLDEBUGINFOWARNERRORFATALOFF
  • <appender-ref>:引用要使用的附加器,通过 ref 属性指定附加器的名称。

2. 自定义记录器(Custom Logger) <logger>

为特定的命名空间或类设置日志级别和附加器,会覆盖根记录器的设置。

<logger name="YourNamespace.YourClass">
    <level value="DEBUG" />
    <appender-ref ref="ConsoleAppender" />
</logger>
  • name:指定记录器的名称,通常是命名空间或类的全限定名。
  • <level> 和 <appender-ref> 的作用与根记录器中的相同。

过滤器(Filters) <filter>

过滤器用于根据特定条件过滤日志记录,只允许符合条件的日志记录通过。常见的过滤器有 LevelMatchFilterLevelRangeFilter 等。

<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
    <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="INFO" />
        <levelMax value="ERROR" />
    </filter>
    <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
    </layout>
</appender>
  • <filter>:指定过滤器的类型。
  • <levelMin> 和 <levelMax>:指定日志级别的范围,只有在该范围内的日志记录才会被输出。

配置示例

以下是一个完整的 log4net 配置文件示例:

<log4net>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
        </layout>
    </appender>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
        <file value="logs\log.txt" />
        <appendToFile value="true" />
        <rollingStyle value="Size" />
        <maxSizeRollBackups value="10" />
        <maximumFileSize value="10MB" />
        <staticLogFileName value="true" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
        </layout>
    </appender>
    <root>
        <level value="ALL" />
        <appender-ref ref="ConsoleAppender" />
        <appender-ref ref="RollingFileAppender" />
    </root>
</log4net>

这个配置文件将日志同时输出到控制台和文件,日志级别为 ALL,即输出所有级别的日志。

通过合理配置 log4net 的配置文件,可以满足不同场景下的日志记录需求。

到此这篇关于C# log4net 的配置文件配置项详细介绍(配置示例)的文章就介绍到这了,更多相关C# log4net 配置文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#实现绘制鼠标的示例代码

    C#实现绘制鼠标的示例代码

    这篇文章主要为大家详细介绍了如何利用C#实现绘制鼠标的效果,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2022-12-12
  • C# Request.Form用法案例详解

    C# Request.Form用法案例详解

    这篇文章主要介绍了C# Request.Form用法案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Unity中的PostProcessBuild实用案例深入解析

    Unity中的PostProcessBuild实用案例深入解析

    这篇文章主要为大家介绍了Unity中的PostProcessBuild实用案例深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 详解c# 多态

    详解c# 多态

    这篇文章主要介绍了c# 多态的相关资料,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • .NET中实现彩色光标、动画光标及自定义光标的方法

    .NET中实现彩色光标、动画光标及自定义光标的方法

    这篇文章主要介绍了.NET中实现彩色光标、动画光标及自定义光标的方法,非常实用的功能,需要的朋友可以参考下
    2014-08-08
  • Unity UGUI的LayoutElement布局元素组件介绍使用示例

    Unity UGUI的LayoutElement布局元素组件介绍使用示例

    这篇文章主要为大家介绍了Unity UGUI的LayoutElement布局元素组件介绍使用示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • 互斥量mutex的简单使用(实例讲解)

    互斥量mutex的简单使用(实例讲解)

    本篇文章主要是对互斥量mutex的简单使用进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • 浅谈C#中的委托、事件与异步

    浅谈C#中的委托、事件与异步

    本文主要介绍了C#中的委托、事件与异步的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • C#反射之基础应用实例总结

    C#反射之基础应用实例总结

    这篇文章主要介绍了C#反射之基础应用实例总结,包括了反射的基本原理与用法实例,需要的朋友可以参考下
    2014-10-10
  • C#实现电脑麦克风录音

    C#实现电脑麦克风录音

    这篇文章主要为大家详细介绍了C#实现电脑麦克风录音,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07

最新评论