服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C# log4net日志库的用法小结

C# log4net日志库的用法小结

2022-12-06 11:38Genven_Liang C#

log4net日志开源库是用来控制日志文件大小,日志文件个数,滚动式覆盖,自由控制日志打印等级,今天通过本文给大家介绍C# log4net日志库的用法小结,感兴趣的朋友一起看看吧

一、简述

记--log4net日志开源库的简单使用:控制日志文件大小,日志文件个数,滚动式覆盖,自由控制日志打印等级

二、下载log4net

直接使用log4net源码或直接使用log4net源码编译对应的dll或直接使用log4net.dll

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

C# log4net日志库的用法小结

例子直接使用其中4.5的dll。(请根据当前环境的.net framework框架版本进行选择,请看右键项目--》属性--》应用程序--》目标框架)

C# log4net日志库的用法小结

 

三、添加log4net.dll引用

C# log4net日志库的用法小结

 

四、添加日志配置log.config

C# log4net日志库的用法小结

编辑log.config内容如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<log4net>
  <appender name="MyAppender1" type="log4net.Appender.RollingFileAppender">
    <file value="app.log" />  <!--日志文件名-->
    <appendToFile value="true" /> <!--日志文件以追加方式进行-->
    <rollingStyle value="Size" />   <!--按文件大小进行滚动记录,也可以按日期-->
    <maxSizeRollBackups value="2" />  <!--最多两个日志备份,app.log.1 app.log.2-->
    <maximumFileSize value="8KB" /> <!--日志文件达到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获取对应的logger句柄-->
      <level value="WARN" /> <!--比WARN等级低的不会输出 日志等级由高到低:OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
      <appender-ref ref="MyAppender1" /> <!--启用MyAppender1-->
  </logger>
</log4net>
</configuration>

将配置同步更新到exe输出路径

C# log4net日志库的用法小结

 

五、在AssemblyInfo.cs文件中添加log4net.dll相关参数

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

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

C# log4net日志库的用法小结

 

六、测试例子

6.1 测试代码

namespace Log4netTest
{
  public partial class Form1 : Form
  {
      //Mylog1对应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对应log.config中的一个logger名称

6.2 效果

控制日志文件大小,日志文件个数,滚动式覆盖,控制日志打印等级为WARN。

C# log4net日志库的用法小结

C# log4net日志库的用法小结

 

七、附

7.1 更多日志配置

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

C# log4net日志库的用法小结

7.2 日志格式

%m(message):输出的日志消息,如ILog.Debug(…)输出的一条消息
%n(new line):换行
%d(datetime):输出当前语句运行的时刻
%r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数
%t(thread id):当前语句所在的线程ID
%p(priority): 日志的当前优先级别,即DEBUG、INFO、WARN…等
%c(class):当前日志对象的名称,例如:
%f(file):输出语句所在的文件名。
%l(line):输出语句所在的行号。
%数字:表示该项的最小长度,如果不够,则用空格填充,如“%-5level”表示level的最小宽度是5个字符,如果实际长度不够5个字符则以空格填充

7.3 日志配置

appender、logger标签可多个,不是一一对应关系的

C# log4net日志库的用法小结

到此这篇关于C# log4net日志库的简单使用的文章就介绍到这了,更多相关C# log4net使用内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/nanfeibuyi/article/details/120689401

延伸 · 阅读

精彩推荐
  • C#C# Winform 子窗体访问父级窗体的控件和属性

    C# Winform 子窗体访问父级窗体的控件和属性

    本文主要介绍两种子窗体访问父窗体控件和属性的方法,大家可以参考一下,本人比较偏向第二种,把父窗体作为属性传递,一劳永逸,想访问父窗体的什...

    xch_yang10112021-11-19
  • C#Unity Shader实现模糊效果

    Unity Shader实现模糊效果

    这篇文章主要为大家详细介绍了Unity Shader实现模糊效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    小盖子10762022-11-29
  • C#一个可携带附加消息的增强消息框MessageBoxEx

    一个可携带附加消息的增强消息框MessageBoxEx

    一个可携带附加消息的增强消息框MessageBoxEx分享给大家,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    AhDung9002021-12-30
  • C#C#实现图片切割的方法

    C#实现图片切割的方法

    这篇文章主要介绍了C#实现图片切割的方法,涉及C#使用Graphics实现图片属性的相关设置、保存等操作技巧,需要的朋友可以参考下...

    JoeBlackzqq8892022-01-07
  • C#C#编写Windows服务程序详细步骤详解(图文)

    C#编写Windows服务程序详细步骤详解(图文)

    本文介绍了如何用C#创建、安装、启动、监控、卸载简单的Windows Service 的内容步骤和注意事项,需要的朋友可以参考下...

    C#教程网6022022-01-22
  • C#C# FileStream文件读写详解

    C# FileStream文件读写详解

    本文主要介绍C#使用 FileStream 读取数据,写入数据等操作,希望能帮到大家。...

    Fskjb7592021-11-19
  • C#C# WCF简单入门图文教程(VS2010版)

    C# WCF简单入门图文教程(VS2010版)

    这篇文章主要介绍了WCF简单入门图文教程,版本是VS2010版,帮助大家轻松学习了解DataContract、ServiceContract等特性,感兴趣的小伙伴们可以参考一下...

    丶一二丶7372021-11-16
  • C#C#微信公众平台开发之access_token的获取存储与更新

    C#微信公众平台开发之access_token的获取存储与更新

    这篇文章主要介绍了C#微信公众平台开发之access_token的获取存储与更新的相关资料,需要的朋友可以参考下...

    秋荷雨翔10732021-11-16