当前位置:  开发笔记 > 编程语言 > 正文

配置log4net以根据级别向不同的appender发送错误

如何解决《配置log4net以根据级别向不同的appender发送错误》经验,为你挑选了2个好方法。



1> Danny Varod..:

这可以使用appender中的thresholdfilter元素来完成.

请注意,阈值可以直接位于appender下,也可以作为包容性过滤器,或者在evaluator例如


  

它适用于跳过缓冲(即时输出)的包容性过滤器.



完整解释(来源):


阈值在AppenderSkeleton几乎所有的appender中实现并因此得到支持.它只是一个简单的测试,用于忽略级别低于阈值的日志记录事件.早期检查阈值,因为简单的测试非常有效.

还有另一种方法可以使用过滤器指定与阈值相同的行为.过滤器非常灵活,因为它们是可插拔的,您还可以开发自己的自定义逻辑并将其插入过滤器链中.


    
    

与阈值检查一样,过滤器在AppenderSkelton基类中实现,并且几乎所有appender都支持.上述过滤器具有相同的效果.这是一个LevelRangeFilter,将允许通过与范围内的任何级别的事件ERROR,以OFF(含).注意,这OFF是最高级别ALL的名称,相反是最低级别的名称.

过滤器具有很大的灵活性,因为可以将多个过滤器链接在一起,以便对输出的事件进行细粒度控制.因此,它们在性能方面也有较高的成本,链中的每个过滤器都是一个对象,并被要求决定正确的行动方案.在阈值过滤的简单情况下,应优先使用阈值属性而不是过滤器.

Evaluator由the实现,BufferingAppenderSkeleton因此仅由扩展此基类并提供缓冲支持的appender支持.SmtpAppender就是其中之一.

Evaluator是一个可插入的对象,BufferingAppenderSkeleton使用它来确定是否应该缓冲日志记录事件,而是立即写入/发送.如果Evaluator判定事件很重要,那么当前缓冲区的全部内容将与事件一起发送.评估程序不像阈值或过滤器那样起作用,因为它不会丢弃事件.



2> Francisco Go..:

您可以为每个appender设置不同的阈值属性.appender会忽略级别低于阈值级别的所有日志事件.我粘贴在两个appender下面,一个用于文件,另一个用于数据库(你应该设置你的连接字符串).数据库追加器具有阈值属性,指示仅将错误保存在数据库中.


  
    
    
      
      
      
      
      
        
        
        
      
      
        
        
        
        
          
        
      
      
        
        
        
        
          
        
      
      
        
        
        
        
          
        
      
      
        
        
        
        
          
        
      
      
        
        
        
        
      
       
    
    
    
      
      
      
        
      
    
    
      
      
      
    
  

推荐阅读
N个小灰流_701
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有