zoukankan      html  css  js  c++  java
  • 过滤器

    severity and facility 
    
    
    Facility  定义日志消息的来源,以方便对日志进行分类,facility 有以下几种:  
      
      
    --kern   内核消息  
      
    --user    用户级消息  
      
    --mail    邮件系统消息  
      
    --daemon   系统服务消息  
      
    --auth     认证系统消息  
      
      
    --syslog    日志系统自身消息  
      
    --lpr      打印系统消息  
      
      
    Priority/Severity Level  
    除了日志来源以外,对于同一来源产生的日志消息,还进行了优先级划分,  
      
    优先级氛围以下几种:  
      
      
    --Emergency     系统已经不可用  
      
    --Alert         必须立即进行处理  
      
    --Critical       严重错误  
      
    --Error          错误  
      
    --Warning        警告  
      
    --Notice         正常信息,但是较为重要  
      
      
    --Infomatinal   正常信息 
    
    
    Filter Conditions 过滤条件:
    
    Rsyslogs 提供4种不同的 过滤条件:
    
    “传统”的严重性和设备基于选择器
    
    基于属性的过滤器
    
    基于表达式的过滤器
    
    基于BSD blocks块的
    
    
    
    选择器:
    
    
    选择器是传统的过滤syslog消息的方式。 它们使用它们原来的语法 一直保存在rsyslog里,
    
    因为它是总所周知的,高效的和 需要用于兼容stock syslogd 配置文件。
    
    
    如果你只是需要过滤基于优先级和设备,你应该这样做使用 selector lines. 
    
    
    它们不是2等公民在rsyslog里,提供了最好的性能对于job.
    
    
    选择器字段本身有两部分组成,一个设备和一个优先级,通过一个.分隔。
    
    
    这两个部分都是不区分大小写,也可以指定为一个10进制数,但是不好这样做,
    
    你会被警告。设备和优先级都是在syslog(3)描述的。
    
    
    下面提到的名字对应于类似LOG_-values 是在 /usr/include/syslog.h.
    
    
    facility 是下面关键字之一:
    
    authpriv, cron, daemon, kern, lpr, mail, mark, news, security (same as auth), syslog, user, uucp and local0 through local7. 
    
    
    关键字 security 不应该用于人任何其他和标记只能内部使用,因此不能被用于应用。
    
    无论如何,你需要指定和重定向这些消息。
    
    facility 指定了子系统 会产生消息,例如 所有的mail 程序的log 使用 facility (LOG_MAIL) 如果它们记录日志使用syslog
    
    
    
    优先级是 下面的关键词之一:
    
    debug, info, notice, warning, warn (same as warning), err, error (same as err), crit, alert, emerg, panic (same as emerg).
    
    
    关键词error, warn和panic 是过时的,不能再被使用,优先级定义了 消息的安全
    
    
    原始的BSD syslogd 行为是所有特定的优先级的消息和更高的是被记录根据给定的action.
    
    Rsyslogd 行为相同,但是有一些扩展。
    
    
    除了以上提到的名字 rsyslogd(8) 理解下面的扩展:
    
    一个星号 ("*") 代表所有的facilities或者所有的优先级,
    
    
    取决于它使用在哪里。
    
    关键字none 表示给定的facility没有优先级。
    
    你可以指定多个facilities 使用相同的邮件及模式 在一个语句里使用,分隔。
    
    
    你可以指定 多个facilities 
    
    记住只有facility 部分,优先级部分会被跳过
    
    
    多个选择器可以通过一个acion被指定使用 (";")分隔。
    
    
    记住每个selector 字段是能够覆盖前面的。使用这个行为你可以排除一些优先级
    
    
     Rsyslogd 有一个语法扩展到原始的BSD 源, 让其使用更加直观。
    
    你可以优先于米格优先级 使用一个("=") 到特定的单个优先级。
    
    
    你也可以(两个都是有效的)优先于优先级使用一个感叹号(!) 来忽略所有的优先级,
    
    
    无论是确切这个或者任何更好的优先级。
    
    如果你使用两个表达式相比感叹号 
    
    
    
    基于属性的过滤器:
    syslog local5 nginx-zjzc01;
    
    
    
    基于属性的过滤器是唯一的对于rsyslogd,它允许规律在任何属性, 像主机名,syslogtag和msg
    
    所有的当前支持的属性的列表可以被找到在属性替换文档(但是记住,只有属性,没有替换是支持的)
    
    在这个过滤器,每个属性可以被检查通过一个指定的值, 使用一个指定的比较操作符。
    
    
    
    基于属性的过滤器必须以一列开始 在column 0,这个高速rsyslogd 它是一个新的过滤器类型。
    
    
    列必须跟着属性的名字, 一个逗号, 比较操作符的名字来进行,另外一个逗号和对值进行比较。
    
    
    这个值必须被引号引起来, 可以有空格和tabs 在逗号之间.
    
    
    属性的名字和比较操作符是区分大小写的,因此 "msg"工作,当"MSG"不是一个正确的属性名字。简单的说,语法如下:
    
    
    :property, [!]compare-operation, "value"
    
    
    比较操作:
    
    下面的比较操作符当前是支持的:
    
    contains:
    
    检查如果提供的字符串在是是包含,这个必须是一个准确的匹配,不支持通配符
    
    
    isequal 相等:
    
    
    
    提供的值和属性内容比较, 这两个值必须完全等价匹配。
    
    不同包含是contains  搜索值在属性值里的任何地方,然而 所有的分字符串必须是相同的对于isequal
    
    因此 isequal  对于字段像syslogtag 或者FROMHOST是有用的,在那里你知道确切的内容。
    
    
    startswith: 从开始
    
    
    检查是否值是被准确找到在属性值的开始,比如 如果你搜索"val" :
    
    :msg, startswith, "val"
    
    
    它是一个匹配如果msg 包含  “values are in this message” 
    
    
    但是它不会匹配 如果 msg 是 “There are values in this message" (这种情况,“contains” would match).
    
    
    注意  “startswith”到目前为止最快的相比正则表达式。
    
    
    因此 一旦它们被实施,它可以非常有意思(性能) 来使用  “startswith”.
    
    regex:
    
    比较 属性提供正则表达式
    
    
    ereregex
    
    
    你可以使用 "!" 在比较操作符的前面, 这个操作的结果是否定的。比如, 如果msg 包含 “This is an informative message”,
    
    下面的例子不会匹配
    
    ! 表示否定
    
    :msg, contains, "error"
    
    but this one matches:
    
    :msg, !contains, "error"
    
    使用否定可能是有用的 如果你想做一些通用的处理,但是排除一些特定的值。
    
    你可以使用discard action 连接,例子将是:
    
    *.* /var/log/allmsgs-including-informational.log
    :msg, contains, "informational"  ~
    *.* /var/log/allmsgs-but-informational.log
    
    
    
    不要忽略波浪线在第2行,在这个例子,所有的消息是写入到文件 allmsgs-including-informational.log.
    
    
    然后,所有的消息包含 字符串 “informational” 会被丢弃。
    
    
    这意味着 配置文件 行 在  “discard line” (在第2行在我们的例子)不会英语这个消息
    
    然后,所有剩下的行会写入到文件 allmsgs-but-informational.log.
    
    
    值的一部分:
    
    值是一个引号引起来的字符串,它支持一些转义序列:
    
    
    " 引号字符(例如  “String with ”Quotes””)
    
    \  反斜杠字符 (e.g. “C:\tmp”) 正常 C:app
    
    
    转义字符总是以一个开始,二外的转义字符 可能被增加。
    
    
    反斜杠字符必须被转义。
    
    
    
    可能的,"msg" 是最突出使用的情况 在属性基于过滤器,它是实际的消息文本,如果 你想要规律基于一些消息内容
    
    (例子: 特定代码的存在)的基础上,这个可以简单的实现:
    
    :msg, contains, "ID-4711"
    
    
    这个过滤器匹配当消息包含字符串  “ID-4711”.
    
    
    过滤器必须匹配当消息包含 字符串 “ID-4711”. 请注意 比较是区分大小写的,
    
    所以 它不会匹配如果 “id-4711”  会包含在消息内
    
    :msg, regex, "fatal .* error"
    
    
    
    这个过滤器使用一个POSIX 正则表达式,它匹配当字符串包含字符“fatal” and “error”  和任何其他在它们之间
    
    (比如 “fatal net error” and “fatal lib error” but not “fatal error” )
    
    
    获得基于属性的过滤器可能有时候是具有挑战的,
    
    为了帮助你尽可能小的努力,rsyslogs 分隔debug信息对于所有基于属性的过滤器 在它们的评估阶段。
    
    为了启用它,运行rsyslogd 在前台指定-d 选项
    
    
    基于表达式的过滤器:
    
    
    基于表达式过滤器允许过滤 在任意复杂的表达式,可以包含布尔运算,算术运算和字符串操作。
    
    
    表达式过滤会变成一个完整配置脚本语言。
    
    
    不幸的是,它们的语法会轻微的变化在这个过程中。
    
    
    因此如果你现在使用它们,你需要准备改变你的配置文件 。然而, 我们尝试实现脚本facility 尽可能的
    
    
    基于表达式的过滤器通过关键字if ,它们有这种格式:
    
    
    if expr then action-part-of-selector-line
    
    
    if和then  是固定的关键字,必须是存在的。"expr" 是一个表达式,
    
    因此表达式文档的细节  
    
    
    “action-part-of-selector-line”  是一个action,就像你知道的(例如 “/var/log/logfile”来写整个文件)
    
    
    *.* /var/log/file1 # the traditional way
    if $msg contains 'error' then /var/log/errlog # the expression-based way
    
    
    BSD 风格Blocks:
    
    注意:rsyslog v7+ 不再支持BSD-风格的blocks 由于技术原因,因此 强烈不推荐使用它们
    
    Examples 例子:
    
    *.* /var/log/file1 # the traditional way
    if $msg contains 'error' then /var/log/errlog # the expression-based way
    
    
    现在,你需要指定数值的值如果你想要检查facilities and severity. 
    
    
    那些可以找到在 RFC 5424. 如果你喜欢那样,你也可以使用文本属性。
    
    
    确保使用正确的。 作为表达式支持是启用的, 这个会改变。
    
    
    比如,如果你想要过滤消息  有 facility local0, start with “DEVNAME” and have either “error1” or “error0” 
    
    在消息内容里,你可以使用下面的过滤器:
    
    if $syslogfacility-text == 'local0' and $msg startswith 'DEVNAME' and ($msg contains 'error1' or $msg contains 'error0') then 
    
    /var/log/somelog
    
    
    请注意,上面的必须在一行上! 如果你想要存储所有的信息除了那些包含"err01"和"err02",你只要加上一个 not
    
    
    if $syslogfacility-text == 'local0' and $msg startswith 'DEVNAME' and not ($msg contains 'error1' or $msg contains 'error0') then 
    
    /var/log/somelog

  • 相关阅读:
    linux内核源码之基础准备篇
    GDB 自动化操作的技术-PYTHON
    GDB 调试PYTHON
    GCC onlinedocs
    深入CSS,让网页开发少点“坑”
    多款控件新版发布,新特性抢鲜知
    如何选择前端框架:ANGULAR VS EMBER VS REACT
    推荐10个很棒的AngularJS学习指南
    Top 15 不起眼却有大作用的 .NET功能集
    最全数据结构详述: List VS IEnumerable VS IQueryable VS ICollection VS IDictionary
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13350417.html
Copyright © 2011-2022 走看看