一般的,Rsyslogd的配置文件在/etc/rsyslog.conf。
有3种格式的配置文件
强烈建议不要使用传统格式,应在基础配置中使用使用basic格式,在其它情况下使用advanced格式。
basic格式一般由简单语句组成,看起来像这样:
mail.info /var/log/mail.log
mail.err @@server.example.net
advanced格式有以下好处:
看起来是这样的:
mail.err action(type="omfwd" protocol="tcp" queue.type="linkedList")
也就是basic格式,以#开头的行以及空行直接被忽略,注释还可以用类C语言的/* */。
这种配置格式由logging规则(rules)组成。每条规则包括两部分:selector和action。这两部分由多个空格或TAB分隔。selector字段指定特定类型(facility)和优先级(priority)以关联相应的action。
selector字段由两部分组成,facility和priority,由"."分隔。各部分均为大小写无关,且都可以由对应的10进制数替代,参见(/usr/include/syslog.h)。
facility由下列类型组成:auth, authpriv, cron, daemon, ftp, kern, lpr, mail, mark, news, security (auth), syslog, user, uucp, local0 - local7。其中security 不建议使用,只作内部用途。
priority由下列组成,按重要程序升序排列:debug, info, notice, warning, warn (warning), err, error (err), crit, alert, emerg, panic (emerg)
rsyslog将记录指定priority以及更高的日志到指定action。
同时*表明任意facility和priority,具体含义取决于*出现在"."的前面或后面。关键字none表示指定facility无priority。
在同一行可以用","分隔多个facility并指定同一priority。
在同一行中可以用";"分隔多个selector采用同一action。多个selector将以从左至右的顺序处理,每一selector可以覆盖之前的selector。一般用这种方式来指定pattern中需要排除的一部分。
可以在priority前加上"=",来指定rsyslog仅记录该级别的priority,而更高级别的被忽略。
可以在priority前加上"!",来指定rsyslog忽略该级别及更高级别的priority。
以上的"=“和”!“可以联用,来指定仅忽略该级别的priority,注意必须是”!="这样的顺序。
action字段是rule中logfile的抽象描述。logfile不必是个真实文件。其可以是以下类型:
Regular File 常规文件
文件名必须指定绝对路径。
可以在文件名前加上"-",来避免每条log就同步一次文件。
Named Pipes 命名管道
fifo或命名管道可以在文件名前加上管道符号"|"。fifo必须在rsyslogd启动前由mkfifo创建。
Terminal and Console 终端
可以用设备名指定tty,如/dev/console。
Remote Machine 远程服务器
在主机名前加上"@"。
List of Users 指定用户
一般critical消息会同时转发到本机的"root"用户。同样可以将需要的日志发送到指定用户的终端上。可以用","分隔用户名列表。如果这些用户已登录系统,将会收到log消息。
Everyone logged on 所有已登录用户
紧急消息用来通知当前在线用户有奇怪的事情发生。这样的消息action以"*"指定即可。
除了之前描述的传统selector外rsyslogd还支持基于属性的filter: Property-based Filters。
可以使用任意属性,如HOSTNAME, syslogtag以及msg这些。所有支持的属性列表详见rsyslog properties documentation
这种filter有如下形式:
:property, [!]compare-operation, "value"
以":“开头,紧跟属性名,再跟个”,",比较操作名,再一个",",然后是要比较的值。值必须加双引号""。 在这些",“之间可以有空格和TAB。属性名/比较操作,都是大小写相关,所以"msg"可以用,但"MSG"则是非法属性名。比较操作前的”!"表达结果相反。
比较操作列表如下:
值部分必须是带""的字符串,可以有两种转义符:
Filter还可以基于任意复杂的表达式,可以包含布尔值,数学和字符串操作。表达式可以进化为完整的配置脚本语言。不幸的是,这些语法仍在完善中,可能会有后续的修改。因此,如果你现在就用,今后很有可能需要修改配置。
基于表达式的filter由新一行的"if"开头。看起来像这样:
if expr then action-part-of-selector-line
“if” 和 “then” 是固定关键字必须存在。 "expr"是表达式,详见:expression documentation。"action-part-of-selector-line"则是通常的action(如 /var/log/logfile)。
模板是rsyslog的关键特性。此特性允许用户自定义任意格式。同时也可用于动态文件名的生成。
模板用template()语句指定,也可由传统语法$template语句指定。
template()语句是static静态的语句,意思是所有模板在rsyslog读入config文件时被定义,无法被if语句影响。
基本语法如下:
template(parameters)
此外,列表式模板支持扩展语法:
template(parameters) { list-descriptions }
每个模板有一个参数name,其指定了模板名称,以及参数type,其指定了模板类型。name参数必须唯一,否则结果无法预测。type参数指定了模板的不同类型。不同的类型可以用不同的方式定义模板内容。模板类型并不会影响(output)plugin如果处理该内容。因此,按最适合你需求的方式(从编写配置的视角而言)来使用type类型。以下是可用的类型:
以下分别描述这些类型。
在这种情况下,模板由一组常量(constant)语句和可变语句生成。这组列表在花括号"{}"跟在template定义后。此类型主要用于结构化的输出,如ommongodb。当然也可以完美的工作于基于文本的输出中。一般建议在需要复杂属性替换时使用此类型。这种情况下,基于列表的模板语法会比简单的基于字符串方式更清晰。
列表模板包括模板头(type=“list”),跟着是用花括号包围的表明从属此模板的constant和property语句。从名字可以看出,constant语句描述了固定常量文本字义,而property描述了属性值的访问。后面会讲到property有很多选项。大多数选项用于从属性中抽取一部分内容或改变获取的内容(例如改变大小写等)。
来个实际的例子:
template(name="tpl1" type="list") {
constant(value="Syslog MSG is: '")
property(name="msg")
constant(value="', ")
property(name="timereported" dateFormat="rfc3339" caseConversion="lower")
constant(value="\n")
}
这个例子或许主要用于常见的基于文件的输出。
这是用于指定常量文本的方式。文本按字面使用。一般面向基于文本的输出。例如,复杂模板构建时,经常会在末尾添加换行,这时即可以用constant语句。举个例子:
template(name="outfmt" type="list") {
property(name="$!usr!msgnum")
constant(value="\n")
}
下列是所有在常量文本内可识别的转义字符序列:
注:若在反斜杠后跟了未支持的字符,将认为是错误。行为不可预料。
在一些基于文本和基于结构使用同一个模板的情况下,没有"outname"参数的常量文本在创建name/value树结构化输出时会被忽略。因此,若希望向类似mongodb提供常量文本时,必须包括outname,例如:
template(name="outfmt" type="list") {
property(name="$!usr!msgnum")
constant(value="\n" outname="IWantThisInMyDB")
}
要生成常量的json字段,format字段要指定为"jsonf",例如:
template(name="outfmt" type="list" option.jsonf="on") {
property(outname="message" name="msg" format="jsonf")
constant(outname="@version" value="1" format="jsonf")
}
在这个例子中,constant语句会生成"@version":“1”。注意,要达到这个效果,value和format参数都必须给出。
constant语句支持下列参数:
此语句用于包含property属性文本。可以访问所有可用属性。属性列表详见rsyslog properties documentation
可以用选项指定选取部分或改变属性。支持下列参数:
要生成自定义格式,可以用多个property选项。例如要生成YYYY-MM-DD:
property(name="timereported" dateformat="date-year")
constant(value="-")
property(name="timereported" dateformat="date-month")
constant(value="-")
property(name="timereported" dateformat="date-day")
其余参数参见官网
这种情况下,模板基于完整的(CEE)子树。这种模板最常用于输出模块知道如何处理结构树,如ommongodb。例如template(name=”tpl1” type=”subtree” subtree=” ! ” ) 包 括 了 所 有 C E E 数 据 , 而 t e m p l a t e ( n a m e = ” t p l 2 ” t y p e = ” s u b t r e e ” s u b t r e e = ” !”)包括了所有CEE数据,而template(name=”tpl2” type=”subtree” subtree=” !”)包括了所有CEE数据,而template(name=”tpl2”type=”subtree”subtree=”!usr!tpl2”)仅包括从$!usr!tpl2开始的子树。当使用此类型模板时,所有数据必须用set和unset脚本语句预先构造好。要了解详情,参见官网,这里只举个例子:
set $!usr!tpl2!msg = $msg;
set $!usr!tpl2!dataflow = field($msg, 58, 2);
template(name="tpl2" type="subtree" subtree="$!usr!tpl2")
最接近于传统模板定义的语句。其有必须的参数string,其中包含了将被应用于模板的字符串。模板字符串混合了常量文本和替换变量(见Property替换)。这些变量从消息或其它动态内容中获得。基于字符串的模板可以很容易指定文本内容,特别是没有复杂属性需要处理的情况下。
以下是示例:
template(name="tpl3" type="string"
string="%TIMESTAMP:::date-rfc3339% %HOSTNAME% %syslogtag%%msg:::sp-if-no-1st-sp%%msg:::drop-last-lf%\n"
)
在’%'之间的文本由rsyslog的property替换来处理。简单来说,其包含了属性及其格式化选项。其与list模板中的property对象类似,仅是两种不同的表达方式而已。
在’%'之外的所有内容均为常量文本。
这种模板由插件(所以一般叫作"strgen"或"字符串生成器")。由于是编程实现,所以格式是固定的。由于是不可变的,因此性能上会好很多,并且一般都是因此而使用(并不是说常规模板性能就很差-而是在特定的要求超高的情况下,很可能1比特的性能差距也很关键)。具体详情需要查看具体插件的文档。必须指定plugin参数,且必须包含插件名以表明自身。注意该插件必须在使用之前加载。同样举个例子:
template(name="tpl4" type="plugin" plugin="mystrgen")
模板可用于生成动态文件名。例如,当希望将syslog按不同主机名分别写到不同文件时(每台主机一个文件),你可以如下定义模板:
template (name="DynFile" type="string" string="/var/log/system-%HOSTNAME%.log")
所有"RSYSLOG_"开头的模板名都被保留给rsyslog使用。请不要在配置中使用它们,否则将有可能在未来导致冲突。