rsyslog 配置简介

2013-12-30

Dec 31 22:02:36 linux-64 rsyslogd-2039: imuxsock begins to drop messages from pid 6927 due to rate-limiting Dec 31 22:02:39 linux-64 rsyslogd-2039: imuxsock lost 133250 messages from pid 6927 due to rate-limiting 模块

完整的模块列表在这里。 下面仅对常用的各类别模块做简单的介绍。

输入模块(im 前缀)


imfile - 转换文本文件为日志
imrelp - 通过 RELP 可靠的接收日志。

$ModLoad imrelp # 加载模块 $InputRELPServerRun 514 # 在 514 端口监听
imudp - 通过 UDP 接收日志

$ModLoad imudp $UDPServerRun 514
imtcp - 通过 TCP 接收日志

$ModLoad imtcp $InputTCPMaxSessions 500 $InputTCPServerRun 514
imptcp - 同 imtcp,但针对 Linux 做高性能定制

$ModLoad imptcp $InputPTCPServerRun 514
immark - 周期性输出标记信息

设置为60,每分钟产生一个 mark 日志

$MarkMessagePeriod 60
imklog - 获取内核日志(通过 dmesg 也能看到相关信息)
imuxsock - UNIX socket

缺省情况下从 /dev/log 获取日志。

# netstat -nxp|grep /dev/log unix 3 [ ] DGRAM 7439519 9074/rsyslogd /dev/log

$ModLoad imuxsock # needs to be done just once $SystemLogRateLimitInterval 0 # turn off rate limiting $InputUnixListenSocketCreatePath on # turn on for next socket $InputUnixListenSocket /var/run/sshd/dev/log $InputUnixListenSocketHostName jail1.example.net $AddUnixListenSocket /jail/1/dev/log $InputUnixListenSocketHostName jail2.example.net $AddUnixListenSocket /jail/2/dev/log
impstats - rsyslog 内部数据周期统计

输出模块(om 前缀)


omfile - 输出到文件

支持静态文件;通过模板支持动态文件;
omfwd - 内置模块,转发

*.* @192.168.2.11:10514 *.* @@192.168.2.11:10514
omsnmp - SNMP trap 输出

$ModLoad omsnmp $actionsnmptransport udp $actionsnmptarget localhost $actionsnmptargetport 162 $actionsnmpversion 1 $actionsnmpcommunity public *.* :omsnmp:
omrelp - RELP output module

$ModLoad omrelp *.* :omrelp:loghost.example.com:20514
omusrmsg - 内置模块,发送日志到指定用户

# Emergencies are sent to everybody logged in. *.emerg :omusrmsg:*
omprog - 发送日志给程序处理

为方便程序解析,日志的输出最好采用 json 格式输出。

$ModLoad omprog $ActionOMProgBinary /home/app/rtdatamq/save_log_data.py :programname,startswith,"log4report" :omprog:;RSYSLOG_TraditionalFileFormat
ommail - 发送邮件
输出到数据库等


ommysql - MySQL
ompgsql - PostgreSQL
ommongodb - MongoDB
omlibdbi - 通用数据库模块
omhdfs - Hadoop's HDFS
omelasticsearch - ElasticSearch

其他模块

消息过滤(fm 前缀),消息解析(pm 前缀),字符串生成(sm 前缀),库模块,等。 规则

规则由过滤器和动作组成。 过滤器


基于设施/优先级的过滤器

格式如下:

. 其中:

表示生成日志的子系统。取值范围为 auth,authpriv,cron, daemon,kern,lpr,mail,news,syslog,user,uucp,local0 到 local7, 参考

man 3 syslog。其对应的数值请参考 /usr/include/sys/syslog.h, 注意需要忽略移位操作。

表示日志的级别,取值范围为(从低到高,数值对应 0-7) debug,info,notice,warning,err,crit,alert,emerg。 参考

man 3 syslog。

在级别前可以增加相应的修饰符,例如加 = 表示仅选择该优先级的日志,加 ! 表示选择不等于优先级的所有日志,不加任何符号则表示选择该优先级及之上的日志。 * 可以用来表示所有的日志子系统和/或消息级别。关键字 none 表示未指定级别的日志。如果要定义多个设置/优先级,使用 , 分隔即可。 如果要定义多个过滤条件,则使用 ; 分隔。

示例如下:

kern.* # 选择所有级别的内核日志 mail.crit # 选择所有级别为 crit 及之上的邮件系统相关日志 cron.!info,!debug # 选择所有 cron 日志信息,排除优先级为 info 和 debug 的日志 *.=debug # 选择所有的调试级别日志 *.*;auth,authpriv.none # 选择所有级别的日志,以及认证相关无级别的日志
基于属性的过滤器

格式如下:

:, [!], "" 其中 ! 表示对匹配结果取反。

该过滤器可以对所有日志的属性进行过滤(相对传统的 syslog 程序而言),例如: timegenerated 或者 syslogtag,所有的属性列表如下,完整的列表可以参考 这里的 Available Properties 节。部分属性如下:

属性名 说明

msg 日志正文

hostname 日志中的主机名

fromhost 从该主机接收到的消息,可能不是最开始的发送主机

fromhost-ip fromhost 的 IP

syslogtag 日志标签,如 named[12345]

programname 日志标签的静态部分,如 named

pri 日志的 PRI 部分

pri-text PRI 的文本表示,如 syslog.info

syslogfacility 日志类别

syslogfacility-text日志类别的文本表示

syslogseverity 日志级别

syslogseverity-text日志级别的文本表示

timegenerated 日志接收时间,或理解为 timereceived

timereported 日志内的报告时间,或生成时间

$now 当前时间,YYYY-MM-DD

$year 当前年,YYYY

$month 当前月,MM

$day 当前日志,DD

$hour 当前小时,24 小时格式,HH

$hhour 当前半小时,0-29 对应 0,30-59 对应 1

$qhour 当前1/4小时,0-3

$minute 当前分钟,MM

timegenerated 和 timereported 的差别请参考 What is the difference between timereported and timegenerated?

每一个属性可以使用下面的比较操作来和某一个指定的值进行从而定义过滤器。
操作符 说明

contains 属性包含指定的字符串

isequal 属性等于指定的字符串

startswith属性由指定字符串开始

regex POSIX BRE 正则表达式

ereregex POSIX ERE 正则表达式

示例如下:

:msg,contains,"error" # 选择包含 error 的日志 :hostname,isequal, "host1" # 选择主机名为 host1 的日志 :msg,!regex,"fatal .* error" # 选择不匹配指定正则表达式的日志
基于RainerScript的过滤器

格式如下:

if then 其中, 表示表达式,例如: "$msg startswith 'DEVNAME' or $syslogfacility-text == 'local0'"。 如果表达式结果为真,则会执行相应的动作。 动作


保存日志到指定文件

例如:

cron.* -/var/log/cron.log 如果文件路径前有 “-” 则表示每次输出日志时不同步(fsync)指定日志文件。 文件路径既可以是静态文件也可以是动态文件。动态文件由模板前加 ? 定义。
通过网络发送日志

格式如下:

@[()]:[] @ 表示使用 UDP 协议。@@ 表示使用 TCP 协议。 可以为: z 表示使用 zlib 压缩,NUMBER 表示压缩级别。多个选项 使用 , 分隔。

例如:

*.* @192.168.0.1 # 使用 UDP 发送日志到 192.168.0.1 *.* @@example.com:18 # 使用 TCP 发送到 "example.com" 的 18 端口 *.* @(z9)[2001::1] # 使用 UDP 发送消息到 2001::1,启用 zlib 9 级压缩
发送消息到特定用户

例如

:msg,contains,"error" liuzx 发送包含 error 的日志到用户 liuzx。多个用户则用 , 分隔,* 表示所有用户。用户 的 mesg (参考

man 1 mesg)权限需要设置为 y。

上面的写法随 rsyslog 版本不同,可能会有如下警告信息,最好做调整。

action 'liuzx' treated as ':omusrmsg:liuzx' - please change syntax, 'liuzx' will not be supported in the future
更多动作

参考输出模块的文档。例如 omprog 输出日志到指定程序的标准输入,ommysql 输出 到 MySQL 数据库,ompgsql 输出日志到 PostgreSQL, ...
丢弃日志

例如

cron.* ~ 丢弃所有信息,即该配置之后的动作不会看到该日志。

随 rsyslog 版本不同,如果有如下警告信息,则将 ~ 修改为 stop。

warning: ~ action is deprecated, consider using the 'stop' statement instead [try http://www.rsyslog.com/e/2307 ]

对每一个过滤条件,可以指定多个动作,每个动作一行即可。这种情况下,也可以通过 “&” 来表示上一行的过滤体检。例如:

:msg,contains,"error" liuzx & @192.168.1.1

包含 “error” 日志被同时发送给用户 liuzx 和通过 UDP 发送到 192.168.1.1。

日志输出模板

通过模板可以更具需要来控制日志输出的样式。格式如下:

$template ,"text %% more text", []

$template 为模板指令。 为模板名。"" 之间的文本为模板格式。 被 % 包含的文本对应相关的属性。 指定修改 模板功能的一些选项,例如 sql 或者 stdsql 会格式化文本为 SQL 查询。


动态文件输出

通过日志和/或系统属性决定输出文件名。

$template DynamicFile,"/var/log/test_logs/%timegenerated%-test.log" *.* ?DynamicFile 使用 timegenerated 生成文件名,使用该模板则在前面加上 ?。

其他例子如下:

$template DailyPerHostLogs,"/var/log/syslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/messages.log"
根据属性控制日志输出格式

使用下面的格式可以对模板之中的属性做各种修改操作从而定制日志的格式:

%[:::]% 属性名,可用的属性名参考上文。

表示对属性值字符串的操作范围。 设置 为 R, 为正则表达式即可以通过正则 表达式定义范围。

则表示属性选项。完整的列表可以参考 这里的 Property Options 节。

一些示例如下:

%msg% # 日志的完整消息文本 %msg:1:2% # 日志消息文本的最开始两个字符 %msg:::drop-last-lf% # 日志的完整消息文本,移出最后的换行符 %timegenerated:1:10:date-rfc3339% # 时间戳的头10个字符并按 RFC3999 标准格式化

下面是一些模板例子。

输出日志的级别,类别,收到日志时的时间错,主机名,消息标签,消息正文, 加上换行符:

$template verbose,"%syslogseverity%,%syslogfacility%,%timegenerated%,%HOSTNAME%,%syslogtag%,%msg%\n"

输出日志来源,时间以及日志标签,正文,同时还有蜂鸣声():

$template wallmsg,"\r\nMessage from syslogd@%HOSTNAME% at %timegenerated% ...\r\n %syslogtag% %msg%\n\r"

格式化日志以便于直接进行 SQL 操作:

$template dbFormat,"insert into SystemEvents (Message, Facility,FromHost, Priority, DeviceReportedTime, ReceivedAt, InfoUnitID, SysLogTag) values ('%msg%', %syslogfacility%, '%HOSTNAME%',%syslogpriority%, '%timereported:::date-mysql%', '%timegenerated:::date-mysql%', %iut%, '%syslogtag%')",sql

以 json 格式输出,方便程序解析:

$template jsonFormat,"{\"message\":\"%msg:::json%\",\"fromhost\":\"%HOSTNAME:::json%\",\"facility\":\"%syslogfacility-text%\",\"priority\":\"%syslogpriority-text%\",\"timereported\":\"%timereported:::date-rfc3339%\",\"timegenerated\":\"%timegenerated:::date-rfc3339%\"}\n" 注意,message 的内容会在最前面多一个空格,其解释请参考这里。

rsyslog 也提供了一些预定义的模板(以 RSYSLOG_ 为前缀),参考 这里 的 Reserved Template Names 节,其定义如下:

RSYSLOG_FileFormat

"%TIMESTAMP:::date-rfc3339% %HOSTNAME% %syslogtag%%msg:::sp-if-no-1st-sp%%msg:::drop-last-lf%\n\"

RSYSLOG_TraditionalFileFormat

"%TIMESTAMP% %HOSTNAME% %syslogtag%%msg:::sp-if-no-1st-sp%%msg:::drop-last-lf%\n\"

RSYSLOG_ForwardFormat

"<%PRI%>%TIMESTAMP:::date-rfc3339% %HOSTNAME% %syslogtag:1:32%%msg:::sp-if-no-1st-sp%%msg%\"

RSYSLOG_TraditionalForwardFormat

"<%PRI%>%TIMESTAMP% %HOSTNAME% %syslogtag:1:32%%msg:::sp-if-no-1st-sp%%msg%\"

使用这些模板,则在动作后附加 “;template_name” 即可,例如:

:programname,startswith,"cron" -/var/log/cron;RSYSLOG_TraditionalFileFormat

深入理解

队列是理解 rsyslog 内部原理和配置的重要基础, 参考 Understanding rsyslog Queues 和 Turning Lanes and Rsyslog Queues - an Analogy。 下图概要性的说明了 rsyslog 内的数据流图。


队列相关的配置指令:

$WorkDirectory /rsyslog/work # 中间文件存放路径 $ActionQueueType LinkedList # [FixedArray/LinkedList/Direct/Disk] $ActionQueueFileName relpact # 定义队列文件名 $ActionResumeRetryCount -1 # 重试次数, -1 表示无限重试 $ActionQueueSaveOnShutdown on # rsyslog 关闭时将队列内容存盘,防止数据丢失 *.* :omrelp:172.19.2.10:2514