来源:Yaopengfei

链接:http://www.cnblogs.com/yaopengfei/p/9428206.html

一、Log4Net简介

Log4net是从Java中的Log4j迁移过来的一个.Net版的开源日志框架,它的功能很强大,可以将日志分为不同的等级,以不同的格式输出到不同的存储介质中,比如:数据库、txt文件、内存缓冲区、邮件、控制台、ANSI终端、远程接收端等等,我们这里主要介绍最常用的两种:txt文件和数据库。

(PS:其它的存储介质详见 http://logging.apache.org/log4net/release/config-examples.html)

Log4net将日志分为五个级别,分别是: FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息),每个级别都对应着一组重载方法进行调用。

官网地址:http://logging.apache.org/log4net/index.html

Nuget地址:https://www.nuget.org/packages/log4net/

Nuget安装:Install-Package log4net

最新版本:2.0.8 (2018-08-09)

本节主要围绕两个主要的存储介质:【txt文件】和【SQLServer数据库】展开,涵盖的知识点有:

①. 基本的使用步骤。

②. 初始化关联配置文件的几种形式。

③. 代码调用详解。

④. 配置文件详解。

⑤. 简单的封装和在MVC框架中的调用。

二、基本使用步骤

我们先以控制台程序为例,简单介绍Log4net存储日志到txt文本文档中,后面在做代码的详解。

1、新建01-SimpleDemo控制台程序,通过指令 【Install-Package log4net】安装相应程序集。

2、在默认配置文件中App.config(B/S程序则为web.config)中进行配置,主要分两块:

A. 在<configuration></configuration>节点下新增节点下新增(要在其最顶部):

<configSections>

 <section name = "log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />

</configSections>

B. 在<configuration></configuration>根节点下,配置log4net的核心配置代码, 主要节点如下:

<log4net> <appender> </appender> <root></root> </log4net>

详细代码如下:

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<!-- 1. 添加log4net的节点声明配置代码-->

<configSections>

<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />

</configSections>

<!--2. log4net的核心配置代码-->

<log4net>

<!--把日志信息输出到以日期命名的文件里-->

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">

<!--文件夹的位置-->

<file value="D:MyLog1" />

<appendToFile value="true" />

<!--动态生成文件名-->

<param name="StaticLogFileName" value="false" />

<!--以日期命名-->

<param name="DatePattern" value="yyyyMMdd&quot;.log&quot;" />

<rollingStyle value="Date" />

<!--日志在日志文件中的布局方式-->

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别:  %-5level %n出错类:%logger property: [%property{NDC}] - %n错误描述:%message%newline %n"/>

</layout>

<!--使用最小锁定模型(minimal locking model),以允许多个进程可以写入同一个文件 -->

<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

</appender>

<root>

<level value="ALL"></level>

<appender-ref ref="RollingFileAppender"></appender-ref>

</root>

</log4net>

<startup>

<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6" />

</startup>

</configuration>

3、代码调用

log4net.Config.XmlConfigurator.Configure();

ILog log = LogManager.GetLogger("test");

log.Debug("调试信息");

4、运行结果

截止此处,日志保存成功。

三、初始化配置文件

前面提到在默认配置文件中App.config(B/S程序则为web.config)中进行配置,可以通过代码  log4net.Config.XmlConfigurator.Configure(); 来初始化配置,或者还可以通过 [assembly: log4net.Config.XmlConfigurator()]  反射的形式进行初始化配置,二者可以达到同样的效果,代表了两种初始化配置文件的形式。

PS: [assembly: log4net.Config.XmlConfigurator()]  可以加在 当前使用文件的 namespace上作用于当前文件,或者加在Properties/AssemblyInfo.cs中,则该项目全局都无须再初始化了。

在实际项目中,默认的配置文件里可能包含很多框架的信息,这个时候把 log4net的配置代码再放入进去,就会显得有点杂乱,或者有些“奇葩”的人把默认配置文件改名了,这个时候使用上述默认的两种方式就不好用了,那么这种情况怎么处理呢?

这里重点介绍 通过 log4net.Config.XmlConfigurator.Configure(); 来关联配置文件。

情况一: 使用默认配置文件的情况

1、代码配置:log4net.Config.XmlConfigurator.Configure();

2、反射配置:[assembly: log4net.Config.XmlConfigurator()]

情况二:修改默认配置文件的名称为:App1.config (这里只是举例,很少有修改默认配置文件名称的)

1、代码配置: 首先将App1.config文件的属性中的“生成操作”改为“ 嵌入的资源”,然后通过以下代码进行配置。

Assembly assembly = Assembly.GetExecutingAssembly();

var xml = assembly.GetManifestResourceStream("_01_SimpleDemo.App1.config");

log4net.Config.XmlConfigurator.Configure(xml);

注:代码中的 _01_SimpleDemo 为命名空间名。

2、反射配置:[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.xml")]

注:用这种方式属性中的:复制到输出目录需要改为:始终复制,生成操作不需要配置,使用默认:无  即可

情况三:新建单独xml文件,进行log4net的配置 (推荐采用这种方式,和原配置文件区分开,单独配置方便,处理方式和情况二是一致的)

1、代码配置:首先将log4net.xml文件的属性中的“生成操作”改为“ 嵌入的资源”,然后通过以下代码进行配置。

Assembly assembly = Assembly.GetExecutingAssembly();

var xml = assembly.GetManifestResourceStream("_01_SimpleDemo.log4net.xml");

log4net.Config.XmlConfigurator.Configure(xml);

注:代码中的 _01_SimpleDemo 为命名空间名。

情况四:无论是修改默认配置文件的名称为 或者 新建单独的xml作为配置文件 → 可以通过绝对路径的方式进行处理 【不推荐这种方式】

1、直接写绝对路径 (注意这种方式【不需要】配置文件属性为 “嵌入的资源”)

log4net.Config.XmlConfigurator.Configure(new FileInfo(@"D:-我的开发之路DotNet体系-DotNet框架篇-Log4net详解Code-SimpleDemolog4net.xml"));

2 通过代码获取绝对路径 (注意这种方式【不需要】配置文件属性的“生成操作”改为 “嵌入的资源”,但需要改为“始终复制”,确保输出到bin文件下)

string assemblyFilePath = Assembly.GetExecutingAssembly().Location;

string assemblyDirPath = Path.GetDirectoryName(assemblyFilePath);

string configFilePath = assemblyDirPath + " //log4net.xml";

log4net.Config.XmlConfigurator.Configure(new FileInfo(configFilePath));

PS:B/S程序下通过  log4net.Config.XmlConfigurator.Configure(new FileInfo(Server.MapPath("~") + @"/log4net.xml")); 来配置。

四、代码调用详解

Log4net允许多个ILog对象同时存在,通过代码:ILog log = LogManager.GetLogger("xxx"); 来创建。

A: 日志级别由高到低分别为:FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息),另外还有 OFF和 ALL 。

几点说明:OFF表示所有信息都不写入,ALL表示所有信息都写入,我们也可以通过:<root><level value = "WARN" ></ level ></root>这样配置,表示WARN级别以及高于WARN以上的级别才会被写入日志。

B: 写入日志的方法有:Debug、Error、Fatal、Info、Warn五个方法,每个方法都有两个重载,如下图:

分享在使用配置文件为log4net.xml的情况下的调用代码:

Assembly assembly = Assembly.GetExecutingAssembly();

var xml = assembly.GetManifestResourceStream("_01_SimpleDemo.log4net.xml");

log4net.Config.XmlConfigurator.Configure(xml);

ILog log = LogManager.GetLogger("test");

log.Debug("调试信息");

log.Info("一般信息");

log.Warn("警告");

try

{

int.Parse("ddd");

}

catch (Exception ex)

{

log.Error("一般错误", ex);

}

log.Fatal("致命错误");

五、配置文件详解

Log4net的配置文件主要分为两大部分:分别是 【自定义配置节点】和

【核心代码配置】,自定义配置节点代码固定,如下图,核心代码配置主要位于:<log4net></log4net>节点中,里面包括<appender></appender>节点配置日日志输出途径 和 <root></root>节点,用于设置记录日志的级别和启用哪些输出途径。  

几点说明:

1、自定义配置节点  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" /> 代码固定,直接复制即可。

2、<root></root> 节点主要用来: 配置日志的的输出级别和加载日志的输出途径。

A: level中的value值表示该值及其以上的日志级别才会输出,日志级别包括:OFF > FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息) > ALL ,比如:

<level value="INFO"></level> 表示只有INFO及其以上的日志级别才会被保存。

PS:OFF表示所有信息都不写入,ALL表示所有信息都写入。

B: <appender-ref></appender-ref>标签用于加载日志的输出途径代码,通过ref和appender标签的中name属性相关联,比如:

<appender-ref ref="RollingFileAppender"></appender-ref>  表示开启txt文档保存日志的方式。

3、<appender></appender>节点,用来配置日志的输出途径的,本节主要介绍了输出到 【txt文本文档】中 和 【数据库】。

A:分享一下数据库的表结构,详细配置见下面的代码分享,需要注意字段类型相匹配,并且要显式指定其长度。

B:关于txt文本文档的命名,可以存放到一个文件夹里,也可以按照时间来区分文件夹,并且命名可以 动态+指定命名的方式。

C:关于日志文件大小的说明和文件个数的说明,主要需要三个节点配合使用(实际开发中,如果一个txt特别大,打开的时候会非常的慢,卡顿,所以该步骤有必要配置一下)。

PS:首先要配置 RollingStyle 节点为Size模式或者Composite模式,然后配置 maximumFileSize 节点设置每个文件的大小,最后配置 MaxSizeRollBackups 节点,设置日志文件的个数。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。

用下面的代码简单测试一下:

<param name="RollingStyle" value="Composite" />

<param name="maximumFileSize" value="10KB" />

<param name="MaxSizeRollBackups" value="5" />

详细代码如下:

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<!-- 一. 添加log4net的自定义配置节点-->

<configSections>

<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />

</configSections>

<!--二. log4net的核心配置代码-->

<log4net>

<!--(一) 配置日志的输出途径-->

<!--1. 输出途径(一) 将日志以回滚文件的形式写到文件中-->

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">

<!--1.1 文件夹的位置(也可以写相对路径)-->

<param name="File"  value="D:MyLog1" />

<!--相对路径  C/S程序生成在Debug目录下-->

<!--<param name="File"  value="/Logs/" />-->

<!--1.2 是否追加到文件-->

<param name="AppendToFile" value="true" />

<!--1.3 使用最小锁定模型(minimal locking model),以允许多个进程可以写入同一个文件 -->

<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

<!--1.4 配置Unicode编码-->

<Encoding value="UTF-8" />

<!--1.5 是否只写到一个文件里-->

<param name="StaticLogFileName" value="false" />

<!--1.6 配置按照何种方式产生多个日志文件 (Date:日期、Size:文件大小、Composite:日期和文件大小的混合方式)-->

<param name="RollingStyle" value="Composite" />

<!--1.7 介绍多种日志的的命名和存放在磁盘的形式-->

<!--1.7.1 在根目录下直接以日期命名txt文件 注意&quot;的位置,去空格 -->

<param name="DatePattern" value="yyyy-MM-dd&quot;.log&quot;" />

<!--1.7.2 在根目录下按日期产生文件夹,文件名固定 test.log  -->

<!--<param name="DatePattern" value="yyyy-MM-dd/&quot;test.log&quot;"  />-->

<!--1.7.3 在根目录下按日期产生文件夹,这是按日期产生文件夹,并在文件名前也加上日期  -->

<!--<param name="DatePattern" value="yyyyMMdd/yyyyMMdd&quot;-test.log&quot;"  />-->

<!--1.7.4 在根目录下按日期产生文件夹,这再形成下一级固定的文件夹  -->

<!--<param name="DatePattern" value="yyyyMMdd/&quot;OrderInfor/test.log&quot;"  />-->

<!--1.8 配置每个日志的大小。【只在1.6 RollingStyle 选择混合方式与文件大小方式下才起作用!!!】可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志,

超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。-->

<param name="maximumFileSize" value="10MB" />

<!--1.9 最多产生的日志文件个数,超过则保留最新的n个 将value的值设置-1,则不限文件个数 【只在1.6 RollingStyle 选择混合方式与文件大小方式下才起作用!!!】

与1.8中maximumFileSize文件大小是配合使用的-->

<param name="MaxSizeRollBackups" value="5" />

<!--1.10 配置文件文件的布局格式,使用PatternLayout,自定义布局-->

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="记录时间:%date %n线程ID:[%thread] %n日志级别:%-5level %n出错类:%logger property: [%property{NDC}] - %n错误描述:%message%newline %n%newline"/>

</layout>

</appender>

<!--2. 输出途径(二) 记录日志到数据库-->

<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">

<!--2.1 设置缓冲区大小,只有日志记录超设定值才会一块写入到数据库-->

<param name="BufferSize" value="1" />

<!--2.2 引用-->

<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />

<!--2.3 数据库连接字符串-->

<connectionString value="data source=localhost;initial catalog=LogDB;integrated security=false;persist security info=True;User ID=sa;Password=123456" />

<!--2.4 SQL语句插入到指定表-->

<commandText value="INSERT INTO LogInfor ([threadId],[log_level],[log_name],[log_msg],[log_exception],[log_time]) VALUES (@threadId, @log_level, @log_name, @log_msg, @log_exception,@log_time)" />

<!--2.5 数据库字段匹配-->

<!-- 线程号-->

<parameter>

<parameterName value="@threadId" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%thread" />

</layout>

</parameter>

<!--日志级别-->

<parameter>

<parameterName value="@log_level" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%level" />

</layout>

</parameter>

<!--日志记录类名称-->

<parameter>

<parameterName value="@log_name" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%logger" />

</layout>

</parameter>

<!--日志信息-->

<parameter>

<parameterName value="@log_msg" />

<dbType value="String" />

<size value="5000" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%message" />

</layout>

</parameter>

<!--异常信息  指的是如Infor 方法的第二个参数的值-->

<parameter>

<parameterName value="@log_exception" />

<dbType value="String" />

<size value="2000" />

<layout type="log4net.Layout.ExceptionLayout" />

</parameter>

<!-- 日志记录时间-->

<parameter>

<parameterName value="@log_time" />

<dbType value="DateTime" />

<layout type="log4net.Layout.RawTimeStampLayout" />

</parameter>

</appender>

<!--(二). 配置日志的的输出级别和加载日志的输出途径-->

<root>

<!--1. level中的value值表示该值及其以上的日志级别才会输出-->

<!--OFF > FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息)  > ALL  -->

<!--OFF表示所有信息都不写入,ALL表示所有信息都写入-->

<level value="ALL"></level>

<!--2. append-ref标签表示要加载前面的日志输出途径代码  通过ref和appender标签的中name属性相关联-->

<appender-ref ref="RollingFileAppender"></appender-ref>

<appender-ref ref="AdoNetAppender"></appender-ref>

</root>

</log4net>

</configuration>

六、简单的封装及完整代码分享

这里模拟在系统框架中对Log4net进行简单的封装,然后在MVC框架中调用,并分享全部代码。

步骤一:新建Ypf.Utils类库,作为工具类库,引入log4net程序集,并将前面用到的log4net.xml 复制进来,改属性为嵌入资源,然后新建LogUtils类(不要起名为LogHelp),对Log4net的方法进行简单的封装,主要包括:初始化代码、ILog实例创建、五类日志级别的封装。

 log4net.xml文件代码如下:

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<!-- 一. 添加log4net的自定义配置节点-->

<configSections>

<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />

</configSections>

<!--二. log4net的核心配置代码-->

<log4net>

<!--(一) 配置日志的输出途径-->

<!--1. 输出途径(一) 将日志以回滚文件的形式写到文件中-->

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">

<!--1.1 文件夹的位置(也可以写相对路径)-->

<param name="File"  value="D:MyLog1" />

<!--相对路径-->

<!--<param name="File"  value="Logs/" />-->

<!--1.2 是否追加到文件-->

<param name="AppendToFile" value="true" />

<!--1.3 使用最小锁定模型(minimal locking model),以允许多个进程可以写入同一个文件 -->

<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

<!--1.4 配置Unicode编码-->

<Encoding value="UTF-8" />

<!--1.5 是否只写到一个文件里-->

<param name="StaticLogFileName" value="false" />

<!--1.6 配置按照何种方式产生多个日志文件 (Date:日期、Size:文件大小、Composite:日期和文件大小的混合方式)-->

<param name="RollingStyle" value="Composite" />

<!--1.7 介绍多种日志的的命名和存放在磁盘的形式-->

<!--1.7.1 在根目录下直接以日期命名txt文件 注意&quot;的位置,去空格 -->

<param name="DatePattern" value="yyyy-MM-dd&quot;.log&quot;" />

<!--1.7.2 在根目录下按日期产生文件夹,文件名固定 test.log  -->

<!--<param name="DatePattern" value="yyyy-MM-dd/&quot;test.log&quot;"  />-->

<!--1.7.3 在根目录下按日期产生文件夹,这是按日期产生文件夹,并在文件名前也加上日期  -->

<!--<param name="DatePattern" value="yyyyMMdd/yyyyMMdd&quot;-test.log&quot;"  />-->

<!--1.7.4 在根目录下按日期产生文件夹,这再形成下一级固定的文件夹  -->

<!--<param name="DatePattern" value="yyyyMMdd/&quot;OrderInfor/test.log&quot;"  />-->

<!--1.8 配置每个日志的大小。【只在1.6 RollingStyle 选择混合方式与文件大小方式下才起作用!!!】可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志,

超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。-->

<param name="maximumFileSize" value="10MB" />

<!--1.9 最多产生的日志文件个数,超过则保留最新的n个 将value的值设置-1,则不限文件个数 【只在1.6 RollingStyle 选择混合方式与文件大小方式下才起作用!!!】

与1.8中maximumFileSize文件大小是配合使用的-->

<param name="MaxSizeRollBackups" value="5" />

<!--1.10 配置文件文件的布局格式,使用PatternLayout,自定义布局-->

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="记录时间:%date %n线程ID:[%thread] %n日志级别:%-5level %n出错类:%logger property: [%property{NDC}] - %n错误描述:%message%newline %n%newline"/>

</layout>

</appender>

<!--2. 输出途径(二) 记录日志到数据库-->

<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">

<!--2.1 设置缓冲区大小,只有日志记录超设定值才会一块写入到数据库-->

<param name="BufferSize" value="1" />

<!--2.2 引用-->

<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />

<!--2.3 数据库连接字符串-->

<connectionString value="data source=localhost;initial catalog=LogDB;integrated security=false;persist security info=True;User ID=sa;Password=123456" />

<!--2.4 SQL语句插入到指定表-->

<commandText value="INSERT INTO LogInfor ([threadId],[log_level],[log_name],[log_msg],[log_exception],[log_time]) VALUES (@threadId, @log_level, @log_name, @log_msg, @log_exception,@log_time)" />

<!--2.5 数据库字段匹配-->

<!-- 线程号-->

<parameter>

<parameterName value="@threadId" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%thread" />

</layout>

</parameter>

<!--日志级别-->

<parameter>

<parameterName value="@log_level" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%level" />

</layout>

</parameter>

<!--日志记录类名称-->

<parameter>

<parameterName value="@log_name" />

<dbType value="String" />

<size value="100" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%logger" />

</layout>

</parameter>

<!--日志信息-->

<parameter>

<parameterName value="@log_msg" />

<dbType value="String" />

<size value="5000" />

<layout type="log4net.Layout.PatternLayout">

<conversionPattern value="%message" />

</layout>

</parameter>

<!--异常信息  指的是如Infor 方法的第二个参数的值-->

<parameter>

<parameterName value="@log_exception" />

<dbType value="String" />

<size value="2000" />

<layout type="log4net.Layout.ExceptionLayout" />

</parameter>

<!-- 日志记录时间-->

<parameter>

<parameterName value="@log_time" />

<dbType value="DateTime" />

<layout type="log4net.Layout.RawTimeStampLayout" />

</parameter>

</appender>

<!--(二). 配置日志的的输出级别和加载日志的输出途径-->

<root>

<!--1. level中的value值表示该值及其以上的日志级别才会输出-->

<!--OFF > FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息)  > ALL  -->

<!--OFF表示所有信息都不写入,ALL表示所有信息都写入-->

<level value="ALL"></level>

<!--2. append-ref标签表示要加载前面的日志输出途径代码  通过ref和appender标签的中name属性相关联-->

<appender-ref ref="RollingFileAppender"></appender-ref>

<appender-ref ref="AdoNetAppender"></appender-ref>

</root>

</log4net>

</configuration>

LogUtils类代码如下:

using log4net;

using System;

using System.Collections.Generic;

using System.Linq;

using System.Reflection;

using System.Text;

using System.Threading.Tasks;

namespace Ypf.Utils

{

public class LogUtils

{

//可以声明多个日志对象

public static ILog log = LogManager.GetLogger(typeof(LogUtils));

#region 01-初始化Log4net的配置

/// <summary>

/// 初始化Log4net的配置

/// xml文件一定要改为嵌入的资源

/// </summary>

public static void InitLog4Net()

{

Assembly assembly = Assembly.GetExecutingAssembly();

var xml = assembly.GetManifestResourceStream("Ypf.Utils.log4net.xml");

log4net.Config.XmlConfigurator.Configure(xml);

}

#endregion

/************************* 五种不同日志级别 *******************************/

//FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息)

#region 01-DEBUG(调试信息)

/// <summary>

/// Debug

/// </summary>

/// <param name="msg">日志信息</param>

public static void Debug(string msg)

{

log.Debug(msg);

}

/// <summary>

/// Debug

/// </summary>

/// <param name="msg">日志信息</param>

/// <param name="exception">错误信息</param>

public static void Debug(string msg, Exception exception)

{

log.Debug(msg, exception);

}

#endregion

#region 02-INFO(一般信息)

/// <summary>

/// Info

/// </summary>

/// <param name="msg">日志信息</param>

public static void Info(string msg)

{

log.Info(msg);

}

/// <summary>

/// Info

/// </summary>

/// <param name="msg">日志信息</param>

/// <param name="exception">错误信息</param>

public static void Info(string msg, Exception exception)

{

log.Info(msg, exception);

}

#endregion

#region 03-WARN(警告)

/// <summary>

/// Warn

/// </summary>

/// <param name="msg">日志信息</param>

public static void Warn(string msg)

{

log.Warn(msg);

}

/// <summary>

/// Warn

/// </summary>

/// <param name="msg">日志信息</param>

/// <param name="exception">错误信息</param>

public static void Warn(string msg, Exception exception)

{

log.Warn(msg, exception);

}

#endregion

#region 04-ERROR(一般错误)

/// <summary>

/// Error

/// </summary>

/// <param name="msg">日志信息</param>

public static void Error(string msg)

{

log.Error(msg);

}

/// <summary>

/// Error

/// </summary>

/// <param name="msg">日志信息</param>

/// <param name="exception">错误信息</param>

public static void Error(string msg, Exception exception)

{

log.Error(msg, exception);

}

#endregion

#region 05-FATAL(致命错误)

/// <summary>

/// Fatal

/// </summary>

/// <param name="msg">日志信息</param>

public static void Fatal(string msg)

{

log.Fatal(msg);

}

/// <summary>

/// Fatal

/// </summary>

/// <param name="msg">日志信息</param>

/// <param name="exception">错误信息</param>

public static void Fatal(string msg, Exception exception)

{

log.Fatal(msg, exception);

}

#endregion

}

}

步骤二:新建名Ypf.MVC的MVC5框架,添加对Ypf.Utils类库的引用,在Global.asax全局文件中添加对 对Log4net进行初始化。

然后就可以愉快的进行调用测试了哦。

/// <summary>

/// 测试log4net

/// 首先需要再Global中初始化log4net

/// </summary>

/// <returns></returns>

public ActionResult Index()

{

//FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息)

LogUtils.Debug("出错了");

try

{

int.Parse("ddf");

}

catch (Exception ex)

{

LogUtils.Debug("出错了",ex);

}

LogUtils.Info("出错了");

try

{

int.Parse("ddf");

}

catch (Exception ex)

{

LogUtils.Info("出错了", ex);

}

LogUtils.Warn("出错了");

try

{

int.Parse("ddf");

}

catch (Exception ex)

{

LogUtils.Warn("出错了", ex);

}

LogUtils.Error("出错了");

try

{

int.Parse("ddf");

}

catch (Exception ex)

{

LogUtils.Error("出错了", ex);

}

LogUtils.Fatal("出错了");

try

{

int.Parse("ddf");

}

catch (Exception ex)

{

LogUtils.Fatal("出错了", ex);

}

return View();

}

看完本文有收获?请转发分享给更多人~

.NET版开源日志框架Log4Net详解相关推荐

  1. Java自动日志监控框架auto-log详解

    Java自动日志监控框架auto-log详解 1. 需求概述 2. auto-log简介 2.1 auto-log定义 2.2 auto-log目的 2.3 auto-log特性 2.4 注解说明 2 ...

  2. java log4j基本配置及日志级别配置详解,java基础面试笔试题

    我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...

  3. 网易考拉海购Dubbok框架优化详解

    网易考拉海购Dubbok框架优化详解 摘要:微服务化是当前电商产品演化的必然趋势,网易考拉海购通过微服务化打破了业务爆发增长的架构瓶颈.本文结合网易考拉海购引用的开源Dubbo框架,分享支持考拉微服务 ...

  4. Java Spring框架入门详解教程【多测师_何sir】

    Spring框架入门详解教程 spring概述 spring结构 spring IOC spring DI spring概述 Spring是一个非常活跃的开源框架, 它是一个基于IOC和AOP来构架多 ...

  5. java定时任务框架elasticjob详解

    这篇文章主要介绍了java定时任务框架elasticjob详解,Elastic-Job是ddframe中dd-job的作业模块中分离出来的分布式弹性作业框架.该项目基于成熟的开源产品Quartz和Zo ...

  6. Snort日志输出插件详解

    Snort日志输出插件详解 Snort是一款老×××的开源***检测工具,本文主要讨论他作为日志分析时的各种插件的应用.Snort的日志一般位于:/var/log/snort/目录下.可以通过修改配置 ...

  7. Exceptionless - .Net Core开源日志框架

    作者:markjiang7m2 原文地址:https://www.cnblogs.com/markjiang7m2/p/11020140.html 官网地址:http://letyouknow.net ...

  8. ceph存储原理_赠书 | Linux 开源存储全栈详解——从Ceph到容器存储

    // 留言点赞赠书我有书,你有故事么?留言说出你的存储故事留言点赞前两名,免费送此书截止日期12.27号12.30号公布名单 // 内容简介 本书致力于帮助读者形成有关Linux开源存储世界的细致的拓 ...

  9. openstack架构详解图_英特尔顶级技术专家合力缔造精品:Linux开源网络全栈详解...

    日常水开篇 自1991年诞生起,Linux已经走过了接近三十年.Linux早已没有了问世时的稚气,正在各个领域展示自己成熟的魅力. 以Linux为基础,也衍生出了各种开源生态,例如网络和存储.而生态离 ...

最新文章

  1. 从农场女孩到首位图灵奖女性获得者,回顾法兰西斯·艾伦的辉煌一生
  2. 你眼中的OA行业发展前景
  3. C Primer+Plus(十一)
  4. servlet的使用
  5. Dotfuscator使用教程
  6. uni中动态加载class_Java基础·类加载、反射
  7. java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory 解决方案
  8. Winform实现漂亮动画-小火车
  9. joomla第一单元第四节K2类别设置和第五节项目视图选项
  10. python flask倒计时_Flask实践:计时器
  11. TI am335x系列(am3352)LCD驱动修改移植
  12. dos u盘测试软件,u盘DOS启动盘制作工具(BootFlashDos)
  13. 菜狗杯Misc打不开的图wp
  14. SocialFi 何以成就 Web3 去中心化社交未来
  15. 王传福的梦想,不止7000亿
  16. 什么是死锁,如何避免死锁?
  17. 树莓派4安装Debian10
  18. (无美国卡)如何进行美国号码是否可正常接收短信的验证,解决方案详见内文...
  19. 大数据-玩转数据-MaxCompute 字符串函数
  20. layui 利用tab选项卡实现:上一步,下一步操作

热门文章

  1. 图像坐标:我想和世界坐标谈谈(B)
  2. 第五章 - 图像形态学 - 基于图像金字塔的图像分割(cvPyrSegmentation)
  3. 最优化作业第六章——共轭梯度法和鲍尔法
  4. windows系统环境变量过长解决方案(PATH too long installer unable to modify Path)
  5. binaryoperator java_BinaryOperatorT接口的用法示例
  6. linux怎么切换不同版本的r,在linux中用同一个版本的R 同时安装 Seurat2 和 Seurat3
  7. 编译py-faster-rcnn的问题汇总及解决方法
  8. Javasript设计模式之链式调用
  9. [No0000E6]C# 判断与循环
  10. sql server自动备份