此配置文件可以直接拿来用,配置文件上面有详细用法说明,里面也有详细注释说明。此配置文件涵盖按照日期记录和按照文件大小(建议)的实例。

又包括:按照Fatal、Info、Error、Debug、Warn的所有级别来分别存放不同位置or不同文件的实例。直接上代码更直观,如下:

<?xml version="1.0" encoding="utf-8" ?>
<!--具体用法:、把log4net.config文件放到和Web.config文件同级目录
、在Web.config文件的<appSettings>下 添加:<add key="log4net.Config" value="log4net.config"/><add key="log4net.Config.Watch" value="True"/>
、把log4net.dll放到bin下并引用
、调用类或基类里 添加:public static readonly log4net.ILog Log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
、开始应用:Log.Fatal("Fatal");Log.Info("Info");Log.Error("Error");Log.Debug("Debug");Log.Warn("Warn");
-->
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net, Version=1.2.11.0, Culture=neutral, PublicKeyToken=669e0ddf0bb1aa2a" />
</configSections>
<log4net>
<root>
<!--定义日志类型-->
<appender-ref ref="RollingFileAppender" /> <!--定义所有类型的日志,所有日志都记录下来-->
<appender-ref ref="FatalRollingFileAppender"/> <!--定义只记录Fatal类型的日志记录-->
<appender-ref ref="ErrorRollingFileAppender" /><!--定义只记录Error类型的日志记录-->
<appender-ref ref="InfoRollingFileAppender" /> <!--定义只记录Info类型的日志记录-->
<appender-ref ref="DebugRollingFileAppender" /><!--定义只记录Debug类型的日志记录-->
<appender-ref ref="WarnRollingFileAppender" /> <!--定义只记录Warn类型的日志记录-->
</root>
<!--所有日志记录到一个文件-->
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender" >
<file value="Log\fulllog.txt" /><!--日志文件存放位置-->
<appendToFile value="true" /> <!--是否追加-->
<rollingStyle value="Size" /> <!--按照文件大小or日期来记录文件-->
<maxSizeRollBackups value="" /><!--备份文件的个数-->
<maximumFileSize value="100KB" /><!--设定单个文件大小,超过大小另新建-->
<staticLogFileName value="true" /><!--是否使用静态文件名-->
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level [%rms used] - %message%newline" /><!--输出日志每行的头部记录文件-->
</layout>
</appender>
<!--此实例是按照日期记录日志:不建议使用-->
<appender name="FatalRollingFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="Fatal">
<file value="Log\Fatal.txt" /><!--日志文件存放位置-->
<appendToFile value="true" /> <!--是否追加-->
<rollingStyle value="Date" /> <!--按照日期来记录日志-->
<datePattern value="yyyyMMdd&quot;.log&quot;" /> <!--重命名日志文件的日期后缀规则-->
<staticLogFileName value="true" /><!--是否使用静态文件名-->
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" /><!--输出日志每行的头部记录文件-->
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Fatal" /> <!--这里很关键:此处和上面的LEVEL="Fatal"是对应的,eg:如果是记录Error日志,那么上面和这里三处都是Error-->
<param name="LevelMax" value="Fatal" /> <!--这两行必须一致才行-->
</filter>
</appender>
<!--此实例是按照文件大小记录日志:建议使用-->
<appender name="ErrorRollingFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="Error">
<file value="Log\Error.txt" /><!--日志文件存放位置-->
<appendToFile value="true" /><!--是否追加-->
<rollingStyle value="Size" /><!--按照文件大小来记录日志:建议用-->
<maxSizeRollBackups value="" /> <!--最多日志文件保留个数,:只保留最新的10个文件-->
<maximumFileSize value="20MB" /> <!--超过指定大小后,另新建文件,20MB:超过20M后新建-->
<staticLogFileName value="true" /><!--是否使用静态文件名-->
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level [%logger] [%property{NDC}] - %message%newline" /><!--输出日志每行的头部记录文件-->
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Error" /><!--这里很关键:此处和上面的LEVEL="Fatal"是对应的,eg:如果是记录Error日志,那么上面和这里三处都是Error-->
<param name="LevelMax" value="Error" /> <!--这两行、上面 LEVEL="Error" 必须一致才行-->
</filter>
</appender>
<appender name="InfoRollingFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="Info">
<file value="Log\Info.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="" />
<maximumFileSize value="1024KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level [%logger] [%property{NDC}] - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Info" />
<param name="LevelMax" value="Info" />
</filter>
</appender>
<appender name="DebugRollingFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="Debug">
<file value="Log\Debug.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="" />
<maximumFileSize value="1024KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level [%logger] [%property{NDC}] - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Debug" />
<param name="LevelMax" value="Debug" />
</filter>
</appender>
<appender name="WarnRollingFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="Warn">
<file value="Log\Warn.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="" />
<maximumFileSize value="1024KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level [%logger] [%property{NDC}] - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="Warn" />
<param name="LevelMax" value="Warn" />
</filter>
</appender>
</log4net>
</configuration>

后台调用如下:

namespace MvcApplication8.Controllers
{
public class HomeController : Controller
{
public static readonly log4net.ILog Log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public ActionResult Index()
{
Log.Fatal("Fatal");
Log.Info("Info");
Log.Error("Error");
Log.Debug("Debug");
Log.Warn("Warn");
ViewBag.Message = "欢迎使用 ASP.NET MVC!"; return View();
}
}
}

注意:切忌要在你的程序config文件里加上这句话::<appSettings><add key="log4net.Config" value="log4net.config"/><add key="log4net.Config.Watch" value="True"/></appSettings>

<!--具体用法:1、把log4net.config文件放到和Web.config文件同级目录
              2、在Web.config文件的<appSettings>下 添加:<add key="log4net.Config" value="log4net.config"/><add key="log4net.Config.Watch" value="True"/>
              3、把log4net.dll放到bin下并引用
              4、调用类或基类里 添加:public static readonly log4net.ILog Log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
              5、开始应用:Log.Fatal("Fatal");Log.Info("Info");Log.Error("Error");Log.Debug("Debug");Log.Warn("Warn");
-->

log4net记录系统错误日志到文本文件用法详解(最新)的更多相关文章

  1. log4net记录系统错误日志到文本文件用法详解

    log4net是一个完全免费开源的插件,可以去官网下载源码. 一般系统操作日志不会用log4net,自己写代码存入数据库更方便合理,但是系统部署后运行在客户环境,难免会发生系统bug.崩溃.断网等无法 ...

  2. Python中内置的日志模块logging用法详解

    logging模块简介 Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用.这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/P ...

  3. C# 使用Log4Net记录程序日志

    在之前的博客中,写过使用系统内置的Trace类记录程序日志,具体请参考:C# 使用Trace记录程序日志.这篇博客将介绍如何使用Log4Net记录程序日志. 首先需要引用Log4Net.dll,我们可 ...

  4. C#中四步轻松使用log4net记录本地日志

    在这里,记录我在项目中使用log4net记录本地日志的步骤.在不会之前感觉很难,很神秘,一旦会了之后其实没那么难.其实所有的事情都是一样的,下面我就分享一下我使用log4Net的经验. 第一步:首先从 ...

  5. C#中四步轻松使用log4net记录本地日志(WPF有点小区别)

    在这里,记录我在项目中使用log4net记录本地日志的步骤.在不会之前感觉很难,很神秘,一旦会了之后其实没那么难.其实所有的事情都是一样的,下面我就分享一下我使用log4Net的经验. 第一步:首先从 ...

  6. ASP.NET MVC中Log4Net记录错误日志的使用

    第一.在管理NuGet程序包 =>下载 Log4Net 第二.在web.config配置Log4Net 1:在<configuration>节点下 <configSection ...

  7. linux dmesg命令参数及用法详解(linux显示开机信息命令)

    linux dmesg命令参数及用法详解(linux显示开机信息命令) http://blog.csdn.net/zhongyhc/article/details/8909905 功能说明:显示开机信 ...

  8. SVN中tag branch trunk用法详解

    SVN中tag branch trunk用法详解 2010-05-24 18:32 佚名 字号:T | T 本文向大家简单介绍一下SVN中tag branch trunk用法,SVN中tag bran ...

  9. [转帖]强大的strace命令用法详解

    强大的strace命令用法详解 文章转自: https://www.linuxidc.com/Linux/2018-01/150654.htm strace是什么? 按照strace官网的描述, st ...

随机推荐

  1. [学习]仿照cnblog 搭建 Oracle RAC 双节点 困.. 后续做不下去了..

    1. 学习地址: https://blog.csdn.net/yuzifen?t=1 2. 克隆之前创建好的虚拟机: 3. 给虚拟机增加新的硬盘. 注意事项 1) 必须是厚置备的磁盘才可以. 2) 必 ...

  2. Java乐观锁、悲观锁

    乐观锁 乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号 ...

  3. delphi开发学习四:TClientDataSet与TDataSetProvider控件使用实例

    1.TClientDataSet控件 通过TClientDataSet控件可以建立瘦客户端的应用程序,且数据执行效率较高,但它不能和数据库自动连接,程序中必须制定它如何获取数据.一般情况下,TClie ...

  4. cnblog博客CSS定制

    一.页面定制CSS #home { margin: 0 auto; width: 80%;/*原始65*/ min-width: 980px;/*页面顶部的宽度*/ background-color: ...

  5. 【转载】css3动画简介以及动画库animate.css的使用

    原文地址:http://www.cnblogs.com/2050/p/3409129.html 在这个年代,你要是不懂一点点css3的知识,你都不好意思说你是个美工.美你妹啊,请叫我前端工程师好不好. ...

  6. 对synchronized的一点理解

    一.synchronized的使用(一).synchronized同步方法1. “非线程安全”问题存在于“实例变量”中,如果是方法内部的私有变量,则不存在“非线程安全”问题.2. 如果多个线程共同访问 ...

  7. MySql--学习成长过程

    MySql--学习成长过程 模拟测试: QQ数据库管理 一.创建数据库并添加关系和测试数据 1 ##创建QQ数据库,完成简单的测试 2 3 #创建数据库 4 DROP DATABASE IF EXIS ...

  8. Avito Cool Challenge 2018 自闭记

    A:n==2?2:1. #include<iostream> #include<cstdio> #include<cmath> #include<cstdli ...

  9. Java开发23种设计模式

    设计模式(Design Patterns) -- --  -- 可复用面向对象软件的基础 设计模式(Design Patterns)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结. ...

  10. 【BZOJ2423】最长公共子序列(动态规划)

    [BZOJ2423]最长公共子序列(动态规划) 题面 BZOJ 洛谷 题解 今天考试的时候,神仙出题人\(fdf\)把这道题目作为一个二合一出了出来,我除了orz还是只会orz. 对于如何\(O(n^ ...