详解log4net的使用

 更新时间:2019年8月21日 22:00  点击:554

程序中只需要引用log4net.dll文件即可

配置的引用

log4net.Config.XmlConfigurator.Configure();

首先添加以上代码。

CS程序:在Main方法中添加;

BS程序:Application_Start方法中添加;

或是两者都可以在AssemblyInfo.cs(Properties中)文件里添加以下的语句:

//设置独立配置文件,log4net.config
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )]
//或是默认的配置文件
[assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config文件中)

详细配置

log4net,可以把日志输出到控制台程序,文件,数据库、邮件,下面贴出四个输出的配置代码,其余如window日志等输出不做阐述。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <!--首先加入configSections配置节点-->
 <configSections>
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
 </configSections>
 <log4net><br>
  <root>
   <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->
   <!--限制日志记录级别-->
   <level value="all" />
   <!--将日志输出到文件-->
   <appender-ref ref="FileAppender"/>
   <!--将日志输出到应用程序控制台-->
   <appender-ref ref="ConsoleAppender"/>
   <!--将日志写到邮件中-->
   <!--<appender-ref ref="LogSmtpAppender"/>-->
   <!--将日志记录到数据库中。可以采用SQL和存储过程两种方式-->
   <appender-ref ref="AdoNetAppender"/>
   <!--可以同时设置多个输出对象,没用到可以注释-->
   <!--将日志写到local syslog service (仅用于UNIX环境下)。-->
   <!--<appender-ref ref="LocalSyslogAppender"/>-->
  </root><br>
  <!--发邮件-->
  <appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender">
   <authentication value="Basic" />
   <!--接受邮件的邮箱-->
   <to value="7778888@qq.com" />
   <!--发送邮件的邮箱-->
   <from value="123456@126.com" />
   <!--发送邮件的邮箱-->
   <username value="123456@126.com" />
   <!--发送邮件的邮箱密码-->
   <password value="123456" />
   <!--标题-->
   <subject value="XXX应用错误日志消息" />
   <!--smtp.qq.com-->
   <smtpHost value="smtp.126.com" />
   <bufferSize value="2048" />
   <!--超长部分是否丢弃-->
   <lossy value="true" />
   <!--日志级别 大于 WARN 的才发邮件-->
   <evaluator type="log4net.Core.LevelEvaluator">
    <threshold value="ERROR"/>
   </evaluator>
   <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value=" %level :: %message %newlineLogger: %logger%newline Date: %date%newline" />
   </layout>
  </appender><br>
  <!-- 控制台日志 -->
  <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
   <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%n%d{yyyy-MM-dd HH:mm:ss} %m%n" />
   </layout>
   <!--指定范围内的等级才可以被记录-->
   <!--<filter type="log4net.Filter.LevelRangeFilter">
    <param name="LevelMin" value="Info" />
    <param name="LevelMax" value="Fatal" />
   </filter>-->
  </appender >
  
  <!--指定日记记录方式,以滚动文件的方式(文件记录)-->
  <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
   <!--日志路径-->
   <param name= "File" value= "log/"/>
   <!--是否是向文件中追加日志-->
   <param name= "AppendToFile" value= "true"/>
   <!--log保留天数-->
   <param name= "MaxSizeRollBackups" value= "10"/>
   <!--每个文件最大1M-->
   <param name="maximumFileSize" value="1MB" />
   <!--日志文件名是否是固定不变的-->
   <param name= "StaticLogFileName" value= "false"/>
   <!--日志文件名格式为:2008-08-31.log-->
   <param name= "DatePattern" value= "yyyy-MM-dd".log""/>
   <!--日志根据日期滚动-->
   <param name= "RollingStyle" value= "Date"/>
   <!--布局-->
   <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%n记录时间:%d{yyyy-MM-dd HH:mm:ss} 线程名:[%t] 级别:%p 类名:%c 信息:%m%n" />
    <param name="Header" value="----------------------------------------------------------- "/>
   </layout>
  </appender><br>
  <!--数据库日记-->
  <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
   <!--设置为1方便查看结果,处于性能考虑这里的值应该略大一点,官方默认值是100,BufferSize为缓冲区大小,只有日志记录超设定值才会一块写入到数据库-->
   <bufferSize value="1" />
   <!--sqlserver 引用-->
   <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
   <!--连接数据库字符串-->
   <connectionString value="data source=.;initial catalog=test;integrated security=false;persist security info=True;User ID=sa;Password=sqlserver;" />
   <!--插入到表Log-->
   <commandText value="INSERT INTO LogTest ([Date],[Level],[Logger],[Message],[Exception],[Description],[ObjType]) VALUES (@log_date,@log_level, @logger, @message, @exception,@Description,@ObjType)" />
   <!--所有参数-->
   <parameter>
    <parameterName value="@log_date" />
    <dbType value="DateTime" />
    <layout type="log4net.Layout.RawTimeStampLayout" />
   </parameter>
   <parameter>
    <parameterName value="@log_level" />
    <dbType value="String" />
    <size value="50" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%level" />
    </layout>
   </parameter>
   <!--类所在位置-->
   <parameter>
    <parameterName value="@logger" />
    <dbType value="String" />
    <size value="255" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%logger" />
    </layout>
   </parameter>
   <parameter>
    <parameterName value="@message" />
    <dbType value="String" />
    <size value="4000" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%message" />
    </layout>
   </parameter>
   <parameter>
    <parameterName value="@exception" />
    <dbType value="String" />
    <size value="2000" />
    <layout type="log4net.Layout.ExceptionLayout" />
   </parameter>
   <!--自定义输入字段-->
   <parameter>
    <parameterName value = "@Description"/>
    <dbType value = "String"/>
    <size value = "50"/>
    <layout type = "log4_Test.Log4netExpand.ExpandLayout">
    <conversionPattern value = "%property{Description}"/>
    </layout>
   </parameter>
   <parameter>
    <parameterName value = "@ObjType"/>
    <dbType value = "String"/>
    <size value = "50"/>
    <layout type = "log4_Test.Log4netExpand.ExpandLayout">
     <conversionPattern value = "%property{ObjType}"/>
    </layout>
   </parameter>
  </appender>
  
 </log4net>
</configuration>

 <layout type = "log4_Test.Log4netExpand.ExpandLayout"> 中的log4_Test.Log4netExpand 为命名空间

布局、格式字符说明:

%p:输出日志信息的优先级,即DEBUG,INFO,WARN,ERROR,FATAL。
%d:输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:输出产生该日志事件的线程名。
%l:输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名以及在代码中的行数。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:输出日志信息所属的类目,通常就是所在类的全名。
%M:输出产生日志信息的方法名。
%F:输出日志消息产生时所在的文件名称。
%L::输出代码中的行号。
%m::输出代码中指定的具体日志信息。
%n:输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"。
%x:输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
%%:输出一个"%"字符。
另外,还可以在%与格式字符之间加上修饰符来控制其最小长度、最大长度、和文本的对齐方式。如:
1)%20c:指定输出category的名称,最小的长度是20,如果category的名称长度小于20的话,默认的情况下右对齐。
2)%-20c:"-"号表示左对齐。
3)%.30c:指定输出category的名称,最大的长度是30,如果category的名称长度大于30的话,就会将左边多出的字符截掉,但小于30的话也不会补空格。

 自定义数据库插入字段(源自网络收集、整理)

1.先定义一个LogData类:

namespace log4_Test.Log4netExpand
{
  public class LogData
  {
    /// <summary>
    /// 日志描述信息
    /// </summary>
    public string Description { get; set; }
    /// <summary>
    /// 日志描述信息
    /// </summary>
    public string ObjType { get; set; }
  }
}

2.Layout扩展类

namespace log4_Test.Log4netExpand
{
  public class ExpandLayout : PatternLayout
  {
    public ExpandLayout()
    {
       this.AddConverter("property", typeof(MyMessagePatternConverter));
    }
  }
}

3.MyMessagePatternConverter 类

namespace log4_Test.Log4netExpand
{
  public class MyMessagePatternConverter: PatternLayoutConverter
  {
    protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent)
    {
 
      if (Option != null)
      {
 
        // Write the value for the specified key
 
        WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));
 
      }
      else
      {
 
        // Write all the key value pairs
 
        WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());
 
      }
    }
    /// <summary>
    /// 通过反射获取传入的日志对象的某个属性的值
    /// </summary>
    /// <param name="property"></param>
    /// <returns></returns>
    private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
    {
      object propertyValue = string.Empty;
      PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
      if (propertyInfo != null)
      {
        propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
      }
      return propertyValue;
 
    }
  }
}

4.使用代码如下:

public class Program
  {
    static void Main(string[] args)
    {
       
      //能看到是那个类输出
      ILog logger = log4net.LogManager.GetLogger(typeof(Program));
 
      logger.Info(new LogData { Description="123", ObjType="123"})
      
      logger.Info("消息11111111111111111111111111111");
      logger.Warn("警告");
      logger.Error("异常");
      logger.Fatal("错误");
      
    }
  }

以上所述是小编给大家介绍的log4net的使用详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对猪先飞网站的支持!

[!--infotagslink--]

相关文章

  • Laravel 调试工具 laravel-debugbar 打印日志消息

    laravel-debugbar 调试工具的教程小编整理了几篇不错的教程,今天我们来看一篇Laravel 调试工具 laravel-debugbar 打印日志消息例子,希望文章对各位有帮助。 其实不...2016-11-25
  • 对MySQL日志操作的一些基本命令总结

    MySQL日志主要包含:错误日志、查询日志、慢查询日志、事务日志、二进制日志;日志是mysql数据库的重要组成部分。日志文件中记录着mysql数据库运行期间发生的变化;也就是说用来记录mysql数据库的客户端连接状况、SQL语句...2015-11-24
  • Powershell 查询 Windows 日志的方法

    这篇文章主要介绍了Powershell 查询 Windows 日志的方法,需要的朋友可以参考下...2020-06-30
  • C#实现线程安全的简易日志记录方法

    这篇文章主要介绍了C#实现线程安全的简易日志记录方法,比较实用的功能,需要的朋友可以参考下...2020-06-25
  • c# 用Dictionary实现日志数据批量插入

    这篇文章主要介绍了c# 用Dictionary实现日志数据批量插入的步骤,帮助大家更好的理解和使用c#中的Dictionary类,感兴趣的朋友可以了解下...2021-02-01
  • C#3.0使用EventLog类写Windows事件日志的方法

    这篇文章主要介绍了C#3.0使用EventLog类写Windows事件日志的方法,以简单实例形式分析了C#写windows事件日志的技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • Java SSM框架如何添加写日志功能

    这篇文章主要介绍了Java SSM框架如何添加写日志功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-25
  • c#快速写本地日志方法

    下面小编就为大家分享一篇c#快速写本地日志方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-06-25
  • Nginx访问日志及错误日志参数说明

    这篇文章主要介绍了Nginx访问日志及错误日志参数说明,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-11-14
  • sql server日志处理不当造成的隐患详解

    这篇文章主要给大家介绍了关于sql server日志处理不当造成的隐患的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用sql server具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-11
  • springboot启动时没有日志的原因分析

    这篇文章主要介绍了springboot启动时没有日志的原因分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-27
  • C#写日志类实例

    这篇文章主要介绍了C#写日志类,实现将日志信息写入文本文件的功能,非常具有实用价值,需要的朋友可以参考下...2020-06-25
  • Nginx自定义访问日志的配置方式

    Nginx日志主要分为两种:访问日志和错误日志。访问日志主要记录客户端访问Nginx的每一个请求,格式可以自定义。下面这篇文章主要给大家介绍了Nginx自定义访问日志的配置方式,需要的朋友可以参考学习,下面来一起看看吧。...2017-07-06
  • php性能分析之php-fpm慢执行日志slow log用法浅析

    这篇文章主要介绍了php性能分析之php-fpm慢执行日志slow log用法,结合实例形式分析了php慢执行日志的功能与相关使用技巧,需要的朋友可以参考下...2016-10-20
  • MySQL中开启和使用通用查询日志的实例教程

    这篇文章主要介绍了MySQL中开启和使用通用查询日志的实例教程,包括其备份和关闭等基础操作的例子讲解,需要的朋友可以参考下...2015-12-25
  • SpringBoot集成slf4j日志配置的方法

    本文主要介绍了SpringBoot集成slf4j日志配置的方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-29
  • MongoDB中4种日志的详细介绍

    这篇文章主要给大家介绍了关于MongoDB中4种日志的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-11
  • 怎么清除sql server日志

    方法1: 第一步: backup log database_name with no_log 或者 backup log database_name with truncate_only --no_log和truncate_only是在这里是同义的,随便执行哪一句...2016-11-25
  • C#实现将程序运行信息写入日志的方法

    这篇文章主要介绍了C#实现将程序运行信息写入日志的方法,可实现将程序运行信息写入日志并存储在Debug目录下的"/Log/PRG"下的功能,涉及C#针对日志的相关写入技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • SpringBoot日志框架如何使用

    这篇文章主要介绍了SpringBoot日志框架如何使用,帮助大家更好的理解和使用springboot日志框架,感兴趣的朋友可以了解下...2021-01-26