在 Linux 上配置一个 syslog 服务器

syslog服务器能够用做一个网络中的日志监控中心,全部可以经过网络来发送日志的设施(包含了Linux或Windows服务器,路由器,交换机以及其余主机)均可以把日志发送给它。 经过设置一个syslog服务器,能够将不一样设施/主机发送的日志,过滤和合并到一个独立的位置,这样使得你更容易地查看和获取重要的日志消息。linux

 

rsyslog 做为标准的syslog守护进程,预装在了大多数的Linux发行版中。在客户端/服务器架构的配置下,rsyslog同时扮演了两种角色:1.做为一个syslog服务器,rsyslog能够收集来自其余设施的日志信息;2.做为一个syslog客户端,rsyslog能够将其内部的日志信息传输到远程的syslog服务器。windows

在此,咱们演示了在linux上如何经过rsyslog来配置一个中心化syslog服务器。 在进入详解以前,先温习一下syslog标准。服务器

 

syslog标准基础网络

当经过syslog机制来收集日志时,有3个必需要考虑到的重要事情:架构

 

设施层级: 监听何种类型的进程运维

严重性(优先) 级别: 收集何种级别的日志消息tcp

目标: 发送或记录日志消息到何处编辑器

如今咱们更加深刻地了解一下配置是如何定义的。工具

 

设施层级定义了一种用来对内部系统进程进行分类的方法,linux中的一些常见的设施包括:linux运维

auth: 身份验证相关的消息(登陆时)

cron: 进程或应用调度相关的消息

daemon: 守护进程相关的消息(内部服务器)

kernel: 内核相关的消息

mail: 内部邮件服务器相关的消息

syslog: syslog 守护进程自己相关的消息

lpr: 打印服务相关的消息

local0 - local7: 用户自定义的消息 (local7 一般被Cisco 和 Windows 服务器 使用)

 

严重性(优先)级别有固定的标准缩写和指代的值,其中的数字7具备最高的级别,这些级别包含了:

emerg: Emergency(紧急)- 0

alert: Alerts (报警)- 1

crit: Critical (关键)- 2

err: Errors (错误)- 3

warn: Warnings (警告)- 4

notice: Notification (通知)- 5

info: Information (消息)- 6

debug: Debugging (调试)- 7

 

最后,目标语句会让一个syslog客户端来执行如下三个任务之一:

保存日志消息到一个本地文件;

经过TCP/UDP将消息路由到远程的syslog服务器中;

将其发送到一个标准输出中,例如控制台。

在 rsyslog里, syslog的配置是基于如下模式进行结构化的。

 

[facility-level].[severity-level]  [destination]

 

在Linux中配置Rsyslog

在咱们理解syslog以后,如今能够经过rsyslog来将一个Linux服务器配置为一个中心syslog服务器了,另外咱们也将看到如何在一个Windows的系统上配置一个syslog客户端来发送内部日志到该syslog服务器中。

 

第1步: 初始化系统需求

要将linux主机设置为一个中央日志服务器, 咱们须要建立一个分离的 /var 分区,并分配足够大的磁盘空间或者建立一个特殊的LVM卷组。这样就会使得syslog服务器可以承担在日积月累收集日志所带来的潜在增加。

 

第2步: 让rsyslog 后台进程生效

rsyslog守护进程来自于当前的linux发布版本的预装模块,可是默认并无启动。为了可以让rsyslog守护进程可以接受外部的消息,须要编辑其配置文件/etc/rsyslog.conf.

打开文件进行编辑,查找到下面的两行所在的位置,经过删除其行首的#字符来取消注释。

$ModLoad imudp

$UDPServerRun 514

这会使得rsysolog守护进程可以在UDP端口514上接受日志消息了---UDP是一种比TCP速度快,可是并不具备TCP同样的数据流的可靠性。因此若是你须要使用可靠的传送机制,就能够经过取消如下行的注释。

 

$ModLoad imtcp

$InputTCPServerRun 514 

须要注意的是,TCP和UDP能够被同时生效来监听TCP/UDP 链接。

 

第3步:建立日志接收模板

接下来的这步,须要咱们来为远程消息建立模板,并告知rsyslog守护进程如何记录从其余客户端机器所接受到的消息。

使用文本编辑器来打开 /etc/rsyslog.conf,而后在GLOBAL DIRECTIVE块前追加如下的模板。

$template RemoteLogs,"/var/log/%HOSTNAME%/%PROGRAMNAME%.log" *

*.*  ?RemoteLogs

& ~

在此对该模板进行简单解释,$template RemoteLogs(这里“RemoteLogs” 字符串能够为任何其余的描述性的名称)指令使rsyslog后台进程将日志消息写到/var/log下的单独的本地日志文件中,其中日志文件的名称是基于远程日志发送机器的主机名以及生成该日志的应用程序名进行定义的。其中第二行暗示了咱们将RemoteLogs模板应用到全部接收到的日志上。

符号"& ~"表示了一个重定向规则,被用来告知rsyslog守护进程中止对日志消息的进一步处理,而且不要在本地写入。若是没有使用该重定向规则,那么全部的远程消息都会在写入上述描述的日志文件以外同时被写入到本地日志文件,这就意味着日志消息实际上被写了两次。使用该规则的另一个结果就是syslog服务器自己的日志消息只会被以该机器主机名命名的专有文件中。

 

若是你想要的话,也可使用下面的模式对特定的设备或严重性级别使用新的模板直接来记录日志消息。

 

[facility-level].[severity-level]    ?RemoteLogs

例如:

将所有优先级别的全部内部用户验证消息指定为RemoteLogs模板:

authpriv.*   ?RemoteLogs 

 

将全部系统进程中除开mail、用户验证和cron消息以外的进程产生的消息级别的日志指定为RemoteLogs模板:

*.info,mail.none,authpriv.none,cron.none    ?RemoteLogs

若是咱们想要将全部从远程客户端接受到的消息写入到一个以它们的IP地址命名的单个文件中,可使用如下的模板。在此咱们为该模板赋予了“IpTemplate”名称。

$template IpTemplate,"/var/log/%FROMHOST-IP%.log" 

*.*  ?IpTemplate 

& ~ 

在咱们启用rsyslog守护进程并编辑好配置文件以后,须要重启该守护进程。

 

在 Debian,Ubuntu 或 CentOS/RHEL 6中:

$ sudo service rsyslog restart 

 

在 Fedora 或 CentOS/RHEL 7中:

$ sudo systemctl restart rsyslog 

咱们能够经过netstat命令来验证rsyslog守护进程是否正常工做。

 $ sudo netstat -tulpn | grep rsyslog 

在UDP监听端口下工做的rsyslog守护进程会有相似下面的输出。

udp     0 0    0.0.0.0:514    0.0.0.0:*      551/rsyslogd 

udp6    0 0    :::514         :::*           551/rsyslogd 

若是rsyslog守护进程被设置在TCP链接端口,那么应该有相似下面所示的输出。

tcp     0 0     0.0.0.0:514   0.0.0.0:*     LISTEN    1891/rsyslogd 

tcp6    0 0     :::514        :::*          LISTEN    1891/rsyslogd

 

发送Windows日志到一个远程的rsyslog服务器

要将一个Windows客户端的日志消息转发到咱们的rsyslog服务器,须要一个安装 Windows syslog 代理。固然,有许多的syslog代理能够在windows上运行,在此咱们可使用一个自由软件程序 Datagram SyslogAgent.

在下载安装该syslog代理后,须要将其配置为做为服务运行。指定使用何种协议来发送数据,以及远程rsyslog服务器的IP地址和端口,最后指定应该传输的事件日志类型.

在咱们完成全部的这些配置以后,咱们就能够启动该服务而且在中央rsyslog服务器中使用命令行工具tail -f来查看日志文件了。

 

总结

经过建立一个能够收集本地和远程主机的中央rsyslog服务器,咱们能够更好地了解在这些系统内部究竟发生着什么,并且能够更加容易地调试它们的问题,是否在它们之间有任何延迟或崩溃存在。

免费领取兄弟连IT教育原创linux运维工程师视频/细说linux教程,详情咨询官网客服:http://www.lampbrother.net/linux/

或者勾搭Q2430675018

欢迎加入linux交流群 478068715

相关文章
相关标签/搜索