欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# log4net日志库的用法小结

程序员文章站 2022-06-15 19:09:23
目录一、简述二、下载log4net三、添加log4net.dll引用四、添加日志配置log.config五、在assemblyinfo.cs文件中添加log4net.dll相关参数六、测试例子6.1...

一、简述

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

例子打包:

http://xiazai.jb51.net/202110/yuanma/log4nettest_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日志库的用法小结

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

相关标签: C# log4net