log4net各种Filter使用【转】

log4net里面的filter类常用的为: 
    1、DenyAllFilter 
       拒绝所用的日志输出 
       <filter type="log4net.Filter.LevelMatchFilter"> 
           <param name="LevelToMatch" value="DEBUG" />       
       </filter> 
       <filter type="log4net.Filter.DenyAllFilter" /> 
       上面的配置是如果日志的输出级别不符合DEBUG要求的话,则不输出任何日志。 
    2、LevelMatchFilter 
       这个类里面有两个属性,一个是LevelToMatch这个属性是你要匹配输出日志的级别,比如: 
        <filter type="log4net.Filter.LevelMatchFilter"> 
           <param name="LevelToMatch" value="DEBUG" />       
        </filter> 
       这样的话,只有级别是DEBUG的日志才能输出。 
       另外这个类还有一个重要的属性就是AcceptOnMatch这个属性是设置如果这个条件匹配的话,是否接受输出打印,比如说: 
        <filter type="log4net.Filter.LevelMatchFilter"> 
           <param name="LevelToMatch" value="DEBUG" />       
        </filter> 
        <filter type="log4net.Filter.StringMatchFilter"> 
           <param name="StringToMatch" value="debug" />       
        </filter> 
       如果日志的级别为DEBVG的话,也就是说符合了第一个Filter的条件,日志就输出,则StringMatchFilter就不执行了。如果这样写的话,就会继续向下执行过滤: 
        <filter type="log4net.Filter.LevelMatchFilter"> 
           <param name="LevelToMatch" value="DEBUG" />   
           <AcceptOnMatch value="false"></AcceptOnMatch>    
        </filter> 
        <filter type="log4net.Filter.StringMatchFilter"> 
           <param name="StringToMatch" value="debug" />       
        </filter> 
       如果这样写的话,即使第一个Filter符合了条件则第二个Filter也会继续执行。 
    3、LevelRangeFilter 
       配置文件是这样的: 
        <filter type="log4net.Filter.LevelRangeFilter"> 
            <param name="LevelMin" value="DEBUG" /> 
            <param name="LevelMax" value="ERROR" /> 
        </filter> 
    4、LoggerMatchFilter 
       配置文件是这样的: 
        <filter type="log4net.Filter.LoggerMatchFilter"> 
            <param name="LoggerToMatch" value="Client" /> 
        </filter> 
    5、StringMatchFilter 
       配置文件是这样的: 
        <filter type="log4net.Filter.StringMatchFilter"> 
            <param name="StringToMatch" value="/blog/Client.Program" /> 
        </filter>

level定义记录的日志级别,就是说,你要记录哪个级别以上的日志,级别由低往高依次是:
ALL
DEBUG
INFO
WARN
ERROR
FATAL
None
说明:有的博客中写的是INFO的比DEBUG的低,可是进过我的亲自测验,还是INFO的比DEBUG的要高

log4net各种Filter使用【转】的更多相关文章

  1. log4net各种Filter使用

    log4net里面的filter类常用的为: 1.DenyAllFilter 拒绝所用的日志输出 <filter type="log4net.Filter.LevelMatchFilt ...

  2. 【改进】用Log4net建立日志记录

    上一篇随笔中只使用了普通的文件读写来进行日志的写入,正如很多朋友说的,频繁的对文件进行读写会造成很多的问题,代码缺少边界控制和操作控制,没有对资源进行管理,是非常典型的bad code. 然后经过前辈 ...

  3. django 操作数据库--orm(object relation mapping)---models

    思想 django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM). PHP:activerecord Java:Hibernate C#:Ent ...

  4. MVC扩展Filter,通过继承HandleErrorAttribute,使用log4net或ELMAH组件记录服务端500错误、HttpException、Ajax异常等

    □ 接口 public interface IExceptionFilter{    void OnException(ExceptionContext filterContext);} Except ...

  5. Log4net - 规则简介

    参考页面: http://www.yuanjiaocheng.net/CSharp/csharprumenshili.html http://www.yuanjiaocheng.net/entity/ ...

  6. Log4net - 项目使用的一个简单Demo

    参考页面: http://www.yuanjiaocheng.net/entity/entitytypes.html http://www.yuanjiaocheng.net/entity/entit ...

  7. log4net使用手册

    1. log4net简介 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介.Java平台下,它还 ...

  8. quartz定时+log4net日志+exchangeservice发邮件

    main using System; using System.Collections.Generic; using System.Linq; using System.Text; using Sys ...

  9. .NET WebAPI 用ExceptionFilterAttribute实现错误(异常)日志的记录(log4net做写库操作)

    好吧,还是那个社区APP,非管理系统,用户行为日志感觉不是很必要的,但是,错误日志咱还是得记录则个.总不能上线后报bug了让自己手足无措吧,虽然不管有木有错误日志报bug都是件很头疼的事... 我们知 ...

随机推荐

  1. Linux shell 通配符 / glob 模式

    概念 glob 模式(globbing)也被称之为 shell 通配符,名字的起源来自于 Unix V6 中的 /etc/glob (详见 man 文档).glob 是一种特殊的模式匹配,最常见的是通 ...

  2. andrioid 分享到其它(短信,qq,微信等功能)

    public static void share(Context context, String text) { Intent intent = new Intent(Intent.ACTION_SE ...

  3. 003.安装nginx(lnmp)

    一.下载nginx 下载nginx源码包,解压: [root@huh ~]# cd /usr/local/src/ [root@huh src]# wget http://nginx.org/down ...

  4. WPF RichTextbox

    WPFTextBoxAutoComplete AvalonEdit WPF SyntaxHighlightBox   WinForm 下的 Fast Colored TextBox for Synta ...

  5. Comparison of SQL Server Compact, SQLite, SQL Server Express and LocalDB

    Information about LocalDB comes from here and SQL Server 2014 Books Online. LocalDB is the full SQL ...

  6. spark dataframe unionall

    今天本来想写一个spark dataframe unionall的demo,由于粗心报下面错误: Exception in thread "main" org.apache.spa ...

  7. Linux Kernel代码艺术——系统调用宏定义

    我们习惯在SI(Source Insight)中阅读Linux内核,SI会建立符号表数据库,能非常方便地跳转到变量.宏.函数等的定义处.但在处理系统调用的函数时,却会遇到一些麻烦:我们知道系统调用函数 ...

  8. java集合中List与set的区别

       java集合中List与set的区别.     List可以存储元素为有序性并且元素可以相同.     set存储元素为无序性并且元素不可以相同.     下面贴几段代码感受一下: ArrayL ...

  9. Oracle数据库

    一.数据库表空间和数据文件 解析:一个数据库下可以开N个表空间,一个表空间可以包含N个数据文件.表空间是逻辑概念. 二.关于listener.ora位置 修改该界面上的数据,会影响指定路径的监听配置文 ...

  10. GHOST急速安装win10或win7

    首先说说写这篇博客的原因,我自己曾经被装各种系统弄得焦头烂额,各种刻光盘光驱安装,写优盘安装以及pe盘恢复系统等等,每次都各种方式尝试一下,太浪费时间了,所以天真的想着能不能有一个类似"一劳 ...