rsyslog详解

一、日志介绍

  1. 日志概念

    日志是系统用来记录系统及应用程序运行时的一些相关信息的文本文件

  2. 日志作用

    日志是为了保存相关程序的运行状态、错误信息等,为了对系统进行分析、保存历史记录以及在出现错误时发现、分析错误使用

  3. linux系统日志类型

    内核信息

    服务信息

    应用程序信息

二、rsyslog

1、rsyslog介绍

rsyslog是linux系统中用来实现日志功能的服务。默认已经安装,并且自动启用。

作用:主要用来采集日志,不生产日志

其特性包括:

	支持输出日志到各种数据库,如 MySQL,PostgreSQL,MongoDB ElasticSearch,等等;
	
	通过 RELP + TCP 实现数据的可靠传输(基于此结合丰富的过滤条件可以建立一种 可靠的数据传输通道供其他应用来使用);
	
	精细的输出格式控制以及对消息的强大 过滤能力;

	高精度时间戳;队列操作(内存,磁盘以及混合模式等); 支持数据的加密和压缩传输等。

2、rsyslog概念

facility

设施,用来定义日志消息的来源,方便对日志进行分类

日志类型日志内容
kern内核信息
user用户程序产生的相关信息
mail邮件系统信息
daemon守护进程产生的信息
authpam认证系统信息
syslog日志系统自身信息
authprivssh、ftp等登录信息
cron系统执行定时任务产生的信息
lpr打印相关信息
mark服务内部的信息,时间标识
uucpUnix-to-Unix Copy 两个unix之间的相关通信
local0-local7保留,本地使用

priority

日志级别,定义不同消息的级别

日志等级说明(级别从低到高,记录信息越来越少)
0debug包含详细的开发情报的信息,通常只在调试一个程序时使用。
1info通用性信息,一般用来提供有用信息,
2notice正常信息,但是较为重要,可能需要处理
3warning警告信息
4error/err错误信息,某个功能或者模块不能正常工作的信息
5crit严重级别,系统或整个软件不能正常工作的信息,例如硬盘错误
6alert需要立刻修改的信息,如系统数据库被破坏,ISP连接丢失。
7emerg紧急情况,内核奔溃等重要信息
none什么也不记录

日志设施的配置

符号说明
.比后面还要高的信息等级都会记录下来
.=只有后面这个消息等级会被记录下来
.!除了后面的消息等级,其他的都会被记录下来(注意前面需要先有其他过滤规则,否则什么不记录)

3、rsyslog配置

rsyslog.conf组成
  • modules,模块,配置加载的模块,如:ModLoad imudp.so配置加载UDP传输模块

  • global directives,全局配置,配置ryslog守护进程的全局属性,比如主信息队列大小(MainMessageQueueSize)

  • rules,规则(选择器+动作),每个规则行由两部分组成,selector部分和action部分,这两部分由一个或多个空格或tab分隔,selector部分指定源和日志等级,action部分指定对应的操作

  • 模板(templates)

  • 输出(outputs)

常用modules
  • imudp,传统方式的UDP传输,有损耗
  • imtcp,基于TCP明文的传输,只在特定情况下丢失信息,并被广泛使用
  • imrelp,RELP传输,不会丢失信息,但只在rsyslogd 3.15.0及以上版本中可用
规则(rules)

规则选择器(selectors)

selector也由两部分组成,设施和优先级,由点号.分隔。

第一部分为消息源或称为日志设施,第二部分为日志级别

多个选择器用;分隔,如:*.info;mail.none

动作(action)

action是规则描述的一部分,位于选择器的后面,规则用于处理消息

消息内容可以被写入到一个日志文件中,也可以写入到数据表表或转发到其他主机, 还可以发送给主机用户 (可以指定用户名,用 * 表示所有)

RULES配置示例

写入到本地文件中

facility.priority		action

# facility.priority  日志类型.级别
# action  保存位置(文件、用户、日志服务器)


# 记录mail日志等级为error及以上日志
mail.err							/var/log/mail_err.log

# 将mail的所有信息,除了info以外,其他的都写入/var/adm/mail
mail.*;mail.!=info   /var/adm/mail


# 紧急消息(emerg级别)将使用wall显示给当前所有登录的用户
*.=emerg   		*

# 该规则将所有alert以及更高级别的消息定向到操作员的终端,即登录的用户“root”和“joey”的终端。
*.alert      root,joey

# 如果是日志服务器格式是:
*.* @192.168.100.1 (使用UDP协议发送)
*.* @@192.168.100.1 (使用TCP协议发送)

写入到mysql数据库中

# modules, 要将日志写到mysql中需要加载ommysql模块
$ModLoad ommysql 

# rule, send to mysql
#*.*       :ommysql:database-server,database-name,database-userid,database-password
*.*       :ommysql:127.0.0.1,Syslog,syslogwriter,topsecret

模板(templates)

模板允许你指定日志信息格式

也可用于生成动态文件名,或在规则中使用

**TEMPLATE_NAME:**模板的名字;

PROPERTY:rsyslog本身支持的一些属性参数。

# 使用规则
$template TEMPLATE_NAME,"text %PROPERTY% more text", [OPTION]


## 以时间字符串开头的文件
$template DynamicFile,"/var/log/test_logs/%timegenerated%-test.log"

## 以年月日主机名为目录下的文件
$template DailyPerHostLogs,"/var/log/syslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/messages.log"

## 自定义日志内容格式
$template  LOGFMT,"%timegenerated%  %FROMHOST-IP%  %syslogtag%  %msg%\n"

## 引用自定义的 动态文件名 中定义的内容
*.info ?DailyPerHostLogs
*.* ?DynamicFile
*.* /var/log/myinfo.log;LOGFMT

模板元素属性
属性说明
msg日志的信息内容,message
hostname打印该日志的主机名
sourcehostname属性的别名
fromhost接收的信息来自哪个节点。这里是dns解析的名字
fromhost-ip接收的信息来自哪个节点,这里是ip,本地是127.0.0.1
syslogtag日志记录目标
timegenerated高精度显示日志时间
timesteamp同 timegenerated
timereported日志中的时间戳
syslogseverity日志严重性等级,数字形式表示
syslogseverity-text日志严重性等级,文本形式表示
jsonmesg整个日志对象作为json表示。可能出现数据重复,譬如syslogtag包含着programname,但两者都会分别表示。所以这个属性有一些额外开销,建议只有在实际需要的时候再用。

修改模板日志

vim /etc/rsyslog.conf

# 创建一个名为cky_format的模板,其中 TIMESTAMP:8:15 表示timestamp属性值切片第八位到第十五位。
$template cky_format, "%$NOW% %TIMESTAMP:8:15% %hostname% %syslogseverity-text% %syslogtag% %msg%\n"
$ActionFileDefaultTemplate cky_format

#重启rsyslog
systemctl restart rsyslog

日志格式效果

# NOW | timestamp:8:15| hostname| syslogseverity-text | syslogtag | msg
2021-12-09 09:59:54 mycomputer    info    systemd:  Started System Logging Service.
#    时间戳         | 	 主机名   | 日志等级 | 服务进程 |   日志内容

三、rsyslog远程传输

1、UDP传输

Server端配置

/etc/rsyslog.conf


# Provides UDP syslog reception
$ModLoad imudp
$UDPServerRun 514
$AllowedSender UDP, 192.168.80.0/24

# This one is the template to generate the log filename dynamically, depending on the client's IP address.
# 根据客户端的IP单独存放主机日志在不同目录,syslog需要手动创建
$template Remote,"/var/log/syslog/%fromhost-ip%/%fromhost-ip%_%$YEAR%-%$MONTH%-%$DAY%.log"

# Log all messages to the dynamically formed file.
:fromhost-ip, !isequal, "127.0.0.1" ?Remote
# 排除本地主机IP日志记录,只记录远程主机日志
# 注意此规则需要在其它规则之前,否则配置没有意义,远程主机的日志也会记录到Server的日志文件中

Client端配置

/etc/rsyslog.conf

*.* @192.168.80.130

以上配置完成之后/etc/init.d/rsyslog restart
2、TCP传输

Server端配置

# Provides TCP syslog reception
$ModLoad imtcp
$InputTCPServerRun 514
$AllowedSender TCP, 192.168.80.0/24

# This one is the template to generate the log filename dynamically, depending on the client's IP address.
$template Remote,"/var/log/syslog/%fromhost-ip%/%fromhost-ip%_%$YEAR%-%$MONTH%-%$DAY%.log"

# Log all messages to the dynamically formed file.

:fromhost-ip, !isequal, "127.0.0.1" ?Remote

Client端配置

/etc/rsyslog.conf

*.* @@192.168.80.130
  • 16
    点赞
  • 102
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: rsyslog.conf是rsyslog日志服务的主要配置文件,用于指定日志的输入、输出、过滤、格式化等操作。以下是rsyslog.conf配置文件的详解: 1. 输入模块配置 rsyslog.conf文件中的输入模块用于指定从哪些源获取日志信息,包括本地日志、远程日志、系统日志等。常用的输入模块包括: - imuxsock:用于从Unix域套接字读取本地日志信息。 - imudp:用于从UDP协议接收远程日志信息。 - imtcp:用于从TCP协议接收远程日志信息。 - imjournal:用于从systemd-journald服务读取系统日志信息。 2. 过滤模块配置 rsyslog.conf文件中的过滤模块用于根据规则过滤日志信息,只保留符合条件的日志信息。常用的过滤模块包括: - if:用于根据条件过滤日志信息。 - regex:用于根据正则表达式过滤日志信息。 - property:用于根据属性过滤日志信息。 3. 输出模块配置 rsyslog.conf文件中的输出模块用于指定将日志信息输出到哪些目标,包括文件、数据库、网络等。常用的输出模块包括: - omfile:用于将日志信息输出到文件。 - ommysql:用于将日志信息输出到MySQL数据库。 - omelasticsearch:用于将日志信息输出到Elasticsearch搜索引擎。 - omfwd:用于将日志信息转发到远程rsyslog服务器。 4. 格式化模块配置 rsyslog.conf文件中的格式化模块用于指定日志信息的格式,包括时间、主机名、进程名、日志级别等。常用的格式化模块包括: - template:用于定义日志信息的格式模板。 - property:用于指定日志信息中的属性,如时间、主机名、进程名等。 - msg:用于指定日志信息的内容。 以上是rsyslog.conf配置文件的主要内容和功能,通过合理配置可以实现高效的日志管理和分析。 ### 回答2: rsyslog是一款流行的系统日志管理工具,可以帮助用户收集和处理多个设备和应用程序的日志信息。rsyslog的主要配置文件为rsyslog.conf,该文件包含一系列的配置项,用于指定日志的来源、目的地、格式化规则、过滤规则等。 rsyslog.conf文件的格式 rsyslog.conf文件采用基于行的格式,每个配置项都以$开头,并且每个配置项都有一个相应的值。下面是一个简单的rsyslog.conf文件的示例: $ModLoad imuxsock # 从Unix Socket收集日志 $ModLoad imklog # 从内核日志接口收集日志 $ActionFileDefaultTemplate RSYSLOG_TraditionalFileFormat $FileOwner root $FileGroup adm $FileCreateMode 0640 $DirCreateMode 0755 $Umask 0022 $WorkDirectory /var/spool/rsyslog 配置项说明 以下是rsyslog.conf文件中的常用配置项及其说明: $ModLoad:加载模块,用于收集不同来源的日志信息。比如,imfile模块用于从文件中收集日志,imudp模块用于从UDP协议中收集日志。 $Action:配置动作,用于指定将日志信息发送到哪个目的地。比如,将日志信息写入文件、发送到远程服务器、发送电子邮件等等。 $FileOwner:指定文件的所有者。 $FileGroup:指定文件的用户组。 $FileCreateMode:指定新创建文件的权限。 $DirCreateMode:指定新创建目录的权限。 $Umask:指定掩码,用于权限控制。 $WorkDirectory:指定rsyslog的工作目录。 rsyslog.conf 文件的安全性考虑 由于rsyslog.conf文件中包含敏感信息,例如日志来源、目的地和过滤规则,因此需要注意保护其安全性。一般建议将rsyslog.conf文件设置为只读或者仅给特定用户组或管理员访问。同时对其文件所在目录进行访问限制,避免敏感信息泄露。在系统更新或升级时也应该备份rsyslog.conf文件,以防丢失或损坏。 总结 rsyslog.conf是rsyslog主要的配置文件,包含了许多配置项,用于指定日志来源、目的地、格式化规则、过滤规则等。在实际使用中应当注意其安全性,并备份以避免不必要的损失。 ### 回答3: rsyslog是一个强大的系统日志收集工具,它可以从多种数据源收集日志,结合正则表达式过滤和匹配日志,并将日志发送到远程服务器或保存到本地文件中。rsyslog的配置文件非常灵活,具体配置选项也非常多,本文将对rsyslog.conf配置文件进行详解rsyslog.conf文件是rsyslog的主要配置文件,通常位于/etc目录下。配置文件中定义了rsyslog如何接受、过滤、处理并转发日志。rsyslog.conf文件由多个模块组成,每个模块定义了一些规则,常用的模块包括: 1.基础模块 *MODULES - 定义rsyslog加载的模块。 *GLOBAL - 定义全局配置。可设置日志文件格式、工作目录、日志文件保存周期等。 *DEFAULT - 定义默认规则,用于处理日志消息的行为。 2.输入模块 *IMUDP - 通过UDP接收日志。 *IMTCP - 通过TCP接收日志。 *IMKLOG - 通过内核日志接收日志。 *IMFILE - 通过本地文件接收日志。 3.过滤器模块 *IF - 判断条件语句。 *EXPR - 操作符。 *PROPERTY - 判断日志属性。 *PRIFILT - 过滤器参数。 4.输出模块 *ACTION - 定义发送日志消息的操作。 *OMFILE - 将日志文件写入本地文件。 *OMSYSLOG - 发送日志至远程syslog服务器rsyslog.conf的基础语法类似于C语言的语法,其中#表示注释,$表示变量,*表示通配符。 例如: $ModLoad ompgsql # 加载PostgreSQL输出插件 $template myfmt, "SELECT user_info(%msg%) as usermsg" # 定义输出格式 *.* :ompgsql:localhost,mylog,postgres,postgres # 发送日志至PostgreSQL服务器 上面的示例代码定义了一个输出模块,利用PostgreSQL保存收集到的日志,并在输出前使用了自定义的输出模板。 需要注意的是,rsyslog.conf配置文件中的配置是按照从上到下逐步执行的,因此在编写配置文件时,需要仔细思考,确保各个模块的顺序和执行效率。 总之,rsyslog的配置文件是非常灵活的,通过合理的配置,可以将日志收集、过滤、发送等各个环节完美的串联起来,为系统的监控和分析提供大大的便利和效率。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值