C# log4net日志库的用法小结

作者:Genven_Liang 时间:2023-12-26 18:50:44 

一、简述

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

例子打包:

http://xiazai.jb51.net/202110/yuanma/Log4netTest_jb51.rar

http://xiazai.jb51.net/202110/yuanma/apache-log4net-source_jb51.rar

http://xiazai.jb51.net/202110/yuanma/apache-log4net-binaries_jb51.rar

二、下载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日志库的用法小结

来源:https://blog.csdn.net/nanfeibuyi/article/details/120689401

标签:C#,log4net
0
投稿

猜你喜欢

  • C语言实现顺序表的顺序查找和折半查找

    2021-10-24 13:17:19
  • C#仿QQ实现简单的截图功能

    2021-10-11 16:43:15
  • git自定义_动力节点Java学院整理

    2021-06-11 22:05:49
  • java实现在性能测试中进行业务验证实例

    2022-10-15 09:50:11
  • C#实现炫酷启动图-动态进度条效果

    2022-01-04 22:22:10
  • 解决MySQL忘记密码问题的方法

    2022-04-05 07:55:43
  • 详解Java中的ReentrantLock锁

    2023-07-18 10:00:45
  • Android绘制钟表的方法

    2023-09-01 13:18:03
  • 在当前Activity之上创建悬浮view之WindowManager悬浮窗效果

    2023-02-09 21:02:12
  • Java 7大常见排序方法实例详解

    2022-01-09 05:16:46
  • Android使用Realm数据库实现App中的收藏功能(代码详解)

    2022-11-01 02:00:45
  • 新手学习Java对Redis简单操作

    2023-09-10 05:05:41
  • Flutter图片缓存管理ImageCache原理分析

    2023-08-20 23:26:19
  • Kotlin使用协程实现高效并发程序流程详解

    2021-12-27 20:47:21
  • Android 百度地图定位实现仿钉钉签到打卡功能的完整代码

    2022-09-05 17:32:46
  • C#中事件只能在内部调用的原因分析

    2023-08-09 05:07:00
  • Android 自定义一套 Dialog通用提示框 (代码库)

    2022-10-08 06:20:31
  • C# PictureBox控件方法参数及图片删除重命名上传详解

    2023-02-04 17:59:08
  • 深入理解spring事务

    2023-10-13 14:51:36
  • Java设计模式之java备忘录模式详解

    2023-08-22 19:31:07
  • asp之家 软件编程 m.aspxhome.com