c# log组件 log4net使用介绍

在软件开发和测试过程中,打印log信息是必不可少的调试方法。尤其在定位偶发性出现的问题的时候,用log的方式,就能体现出优势了。
log4net是一个开源的log代码,只需要应用他的dll,并且在config中进行相关配置,就能在程序中轻松使用了。
log4net 下载地址: http://logging.apache.org/log4net/download_log4net.cgi

下载后 就有log4net.dll。

配置方法如下:

1:  引用 log4net.dll

2:   在app.config 中插入如下代码
注意: configSections 必须放在<configSection> 后的第一个位置
<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, 
            log4net-net-1.0"/>
  </configSections>

  <!--站点日志配置部分-->
  <log4net>
    <root>
      <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
      <!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录-->
      <!--如果没有定义LEVEL的值,则缺省为DEBUG-->
      <level value="ALL"/>
      <appender-ref ref="RollingFileAppender"/>
    </root>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <!--日志文件名开头-->
      <file value="Log\\TestLog4net.txt"/>
      <!--多线程时采用最小锁定-->
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置-->
      <datePattern value="(yyyyMMdd)"/>
      <!--是否追加到文件,默认为true,通常无需设置-->
      <appendToFile value="true"/>
      <!--变换的形式为日期,这种情况下每天只有一个日志-->
      <!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义-->
      <!--<rollingStyle value="Date"/>-->
      <!--变换的形式为日志大小-->
      <!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义-->
      <RollingStyle value="Size"/>
      <!--每天记录的日志文件个数,与maximumFileSize配合使用-->
      <MaxSizeRollBackups value="10"/>
      <!--每个日志文件的最大大小-->
      <!--可用的单位:KB|MB|GB-->
      <!--不要使用小数,否则会一直写入当前日志-->
      <maximumFileSize value="100MB"/>
      <!--日志格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%t]%p: %m%n"/>
      </layout>
    </appender>
  </log4net>
3:在 assemblyinfo.cs中增加
[assembly: log4net.Config.DOMConfigurator(ConfigFileExtension = "config", Watch = true)]


c#代码如下
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using log4net;
using log4net.Config;  

namespace InvokeCpp
{
    class LogTest
    { 
        public void print()
        {
            ILog m_log = LogManager.GetLogger("log");
            m_log.Debug("这是一个Debug日志"+2);
            m_log.Info("这是一个Info日志");
            m_log.Warn("这是一个Warn日志");
            m_log.Error("这是一个Error日志");
            m_log.Fatal("这是一个Fatal日志");  
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            LogTest log = new LogTest();
            log.print();
        } 
    }
}

在Testlog4net.txt中就有

2016-04-05 10:01:08,085 [8]DEBUG 这是一个Debug日志 %d2
2016-04-05 10:01:08,096 [8]INFO 这是一个Info日志
2016-04-05 10:01:08,099 [8]WARN 这是一个Warn日志
2016-04-05 10:01:08,102 [8]ERROR 这是一个Error日志
2016-04-05 10:01:08,104 [8]FATAL 这是一个Fatal日志

其中layout节点的配置说明:
%m(message):输出的日志消息;
%n(newline):换行;
%d(datetime):输出当前语句运行的时刻;
%r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
%t(threadid):当前语句所在的线程ID ;
%p(priority): 日志的当前日志级别;
%c(class):当前日志对象的名称;
%L:输出语句所在的行号;
%F:输出语句所在的文件名;
%-10:表示最小长度为10,如果不够,则用空格填充;

其他注意事项: 来自 http://blog.csdn.net/pfe_nova/article/details/12225349

1.项目的目标框架为.NET Framework 3.5(或者4) Client Profile时会报出下图错误,改成.NET Framework 3.5(或者4) 即可;

     2.当configSections节点没有放在configuration节点下的第一个节点时,编译时不会报警告,但运行时不会记日志。这是因为自定义的节点configSections这个必须放在第一个,这是app.config文件的语法规定;

    3.对于大量记日志的程序,需注意配置RollingStyle值为Composite,且设置MaxSizeRollBackups(每天记录的日志文件个数)和maximumFileSize(每个日志文件的最大大小)。我以前遇过一次日志过大的问题,有一次版本临时发布就改了一个方法而没有经过测试,造成每天记几十G日志的,几天就把服务器磁盘弄满了。

    4.当发现不记日志时,可从两方面调查问题,一是log4net有没有初始化,也就是XmlConfigurator.Configure();二是看level节点的配置是不是正确;

    5.当发现一些设置参数没有起作用时,请检查是不是同一个节点被设置过多次,当被重复设置时,log4net会选择最后一个作为实际的设置。例如设置记录日志的级别设置两次如<level value="ERROR"/><level value="All"/>,则最终会以ALL作为记录日志的级别。

    6.如果是网站项目,须在项目中的AssemblyInfo.cs文件的最后一行中添加:
        [assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)] 
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: log4net是一个强大的日志记录库,用于在.NET应用程序中实现灵活的、高效的日志功能。它提供了一套简单易用的API,可以帮助开发人员记录应用程序的各种运行时信息。 使用log4net可以方便地记录各种级别的日志,例如DEBUG、INFO、WARN、ERROR等。开发人员可以根据需要选择合适的级别,以便在不同环境下记录适当的日志信息。 log4net可以将日志输出到不同的目标,包括控制台、文件、数据库等。它提供了多个日志输出器,可以根据需求选择合适的输出方式。 除了基本的日志输出功能,log4net还支持日志的格式化和过滤。开发人员可以定义自己的日志格式,以及根据需要过滤不希望记录的日志信息。 log4net还支持日志的异步写入,可以提高应用程序的性能。通过将日志的写入操作放入后台线程中,可以避免主线程被阻塞。 log4net是开源软件,可以免费使用。它的源代码可以从官方网站上获取,并且有一个活跃的开发社区提供支持和更新。 总而言之,log4net是一款功能丰富、易于使用的日志记录库,可以帮助开发人员快速添加日志功能到他们的应用程序中,从而方便地进行调试和错误排查。 ### 回答2: log4net 是一个用于记录日志的开源组件,它是Apache Software Foundation的一个子项目,基于Apache许可证发行。 log4net 提供了一种灵活且可扩展的方法来记录程序运行时生成的日志信息。它可以将日志信息输出到不同的目标,例如控制台、文件、数据库等。用户可以通过配置文件或代码来定义日志的格式、输出位置、日志级别等。 log4net 支持不同的日志级别,包括DEBUG、INFO、WARN、ERROR、FATAL。通过设置日志级别,用户可以根据需要过滤日志信息,只记录关键的错误信息或异常情况。 log4net 还提供了丰富的功能和组件,用于对日志信息进行增强和处理。例如,用户可以自定义日志记录器、过滤器、格式器等,以满足特定的需求。 使用log4net 可以帮助开发者更好地理解和跟踪程序的执行过程,方便排查问题和调试。同时,日志的记录和分析也对于系统监控和性能分析非常有帮助。 总的来说,log4net 是一个强大而灵活的日志记录工具,使得开发者可以方便地记录和管理程序运行时的日志信息,提高代码质量和可维护性。 ### 回答3: log4net 是一个用于 .NET 平台的功能强大的日志记录工具。它提供了非常灵活和可配置的日志记录功能,可以帮助我们在应用程序中实现高效的日志记录和调试。 log4net 的主要功能包括: 1. 配置灵活:log4net 允许我们通过配置文件或者编程方式来定义日志的格式、输出目的地以及日志级别等。这使得我们可以方便地根据应用程序的需求来调整日志记录的方式。 2. 多目的地输出:log4net 支持将日志记录发送到多个不同的输出目的地,例如控制台、文件、数据库等。这样,我们可以同时将日志发送到多个目的地,以满足不同的需求,比如输出到文件用于归档,同时在控制台显示用于实时监控。 3. 日志级别控制:log4net 支持不同的日志级别,包括 DEBUG、INFO、WARN、ERROR 和 FATAL 等级别。我们可以根据应用程序的需求来设置不同的日志级别,以便在不同的场景下记录不同级别的日志。这可以帮助我们更好地分析和排查问题。 4. 可扩展性:log4net 允许我们通过自定义 Appender 和 Layout 来扩展其功能。我们可以根据需要创建自定义的输出目的地或者日志格式,以满足特定的需求。 总之,log4net 是一个功能强大且灵活的日志记录工具,可以帮助我们更好地追踪和调试应用程序中的问题。它的配置灵活性和多目的地输出特性使得我们可以根据应用程序的需求来定制日志的格式和输出方式。同时,它的日志级别控制和扩展性使得我们可以更加精细地控制日志记录的内容和行为。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值