配置linux syslog服务器+配置syslog客户端

参考文档:

1)https://linux.cn/article-5023-1.html:在 Linux 上配置一个 syslog 服务器

2)http://www.111cn.net/sys/CentOS/81133.htm:Linux配置syslog服务器及CentOS配置rsyslog客户端远程记录日志

3)http://qubaoquan.blog.51cto.com/1246748/293050: linux 日志logger(包括logger命令和循环日志设置)

logger -it logger_test -p local3.info "test_info"


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

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

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

syslog标准基础

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

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

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

·        目标: 发送或记录日志消息到何处

现在我们更加深入地了解一下配置是如何定义的。

设施层级定义了一种用来对内部系统进程进行分类的方法,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客户端来执行以下三个任务之一:

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

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

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

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

1.       [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.

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

1.       $ModLoad imudp

2.       $UDPServerRun 514

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

1.       $ModLoad imtcp

2.       $InputTCPServerRun 514

需要注意的是,TCP和UDP可以被同时生效来监听TCP/UDP 连接。

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

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

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

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

2.       *.*  ?RemoteLogs

3.       & ~

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

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

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

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

例如:

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

1.       authpriv.*  ?RemoteLogs

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

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

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

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

2.       *.*  ?IpTemplate

3.       & ~

在我们启用rsyslog守护进程并编辑好配置文件之后,需要重启该守护进程。

在 Debian,Ubuntu或 CentOS/RHEL 6中:

1.       $ sudo servicersyslog restart

在 Fedora 或 CentOS/RHEL 7中:

1.       $ sudosystemctl restartrsyslog

我们可以通过netstat命令来验证rsyslog守护进程是否正常工作。

1.        $ sudonetstat-tulpn |grep rsyslog

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

1.       udp    000.0.0.0:5140.0.0.0:*     551/rsyslogd

2.       udp6   00    :::514         :::*           551/rsyslogd

如果rsyslog守护进程被设置在TCP连接端口,那么应该有类似下面所示的输出。

1.       tcp    000.0.0.0:5140.0.0.0:*     LISTEN   1891/rsyslogd

2.       tcp6   00    :::514       :::*          LISTEN    1891/rsyslogd

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

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

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

在我们完成所有的这些配置之后,我们就可以启动该服务并且在中央rsyslog服务器中使用命令行工具tail -f来查看日志文件了。

 

linux 配置Rsyslog守护进程为客户端

要将你的CentOS机器转变成rsyslog客户端,将其所有内部日志消息发送到远程中央日志服务器上。

要实现该功能,请使用你喜爱的文本编辑器打开位于/etc路径下的rsyslog主配置文件:

    # nano /etc/rsyslog.conf 

开启文件用于编辑后,你需要添加以下声明到文件底部。将IP地址替换为你的远程rsyslog服务器的IP地址。

    *.* @192.168.1.25:514 

上面的声明告诉rsyslog守护进程,将系统上各个设备的各种日志消息路由到远程rsyslog服务器(192.168.1.25)的UDP端口514。

如果出于某种原因,你需要更为可靠的协议,如TCP,而rsyslog服务器也被配置为监听TCP连接,你必须在远程主机的IP地址前添加一个额外的@字符,像下面这样:

    *.* @@192.168.1.25:514 

注意,你也可以将rsyslog服务器的IP地址替换成它的主机名(FQDN)。

如果你只想要转发服务器上的指定设备的日志消息,比如说内核设备,那么你可以在rsyslog配置文件中使用以下声明。

    kern.* @192.168.1.25:514 

修改配置文件后,你需要重启进程以激活修改:

CentOS 7:

    # systemctl restart rsyslog.service 

CentOS 6:

    # service rsyslog restart 

总结

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


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在Linux上搭建syslog服务器,可以按照以下步骤进行操作: 1. 安装syslog服务:可以使用yum或apt-get等包管理工具安装syslog-ng或rsyslog等服务。 2. 配置syslog服务:可以编辑/etc/syslog-ng/syslog-ng.conf或/etc/rsyslog.conf文件,设置日志的存储路径、格式、过滤规则等。 3. 开启syslog服务:可以使用systemctl或service等命令启动syslog服务,并设置开机自启动。 4. 配置客户端:在需要将日志发送到syslog服务器客户端上,可以编辑/etc/rsyslog.conf或/etc/syslog.conf文件,设置日志的发送目标为syslog服务器的IP地址和端口号。 5. 测试:可以在客户端上生成一些日志,查看是否能够成功发送到syslog服务器,并在服务器上查看日志是否正常存储。 以上就是在Linux上搭建syslog服务器的基本步骤,具体操作可以根据不同的系统和需求进行调整。 ### 回答2: Linux是一种开源的操作系统,它允许用户自主搭建各种服务器,其中包括syslog服务器syslog是一种用于系统日志的标准协议,它用于跟踪和记录各种系统错误、警告消息、安全事件等。在Linux系统中,syslog服务器是非常重要的,因为它可以帮助管理员更好地理解系统中发生了什么事,同时能够协助分析和解决问题。 搭建Linux syslog服务器的具体步骤如下: 1. 确认系统环境:Syslog服务器一般不需要特殊的硬件要求,但是需要安装特定的软件包,例如rsyslog和sysklogd。在搭建之前要想好日志存储的位置、日志的保留时间等问题。 2. 安装rsyslog:在Ubuntu和Debian系统中,rsyslog是默认安装的。如果不确定是否已经安装,可以使用sudo apt-get install rsyslog安装。CentOS系统中也可以使用yum install rsyslog安装。 3. 配置rsyslog配置rsyslog可以通过编辑/etc/rsyslog.conf文件来实现。该文件中列出了不同类型和等级的消息,并确定了每个类型和等级的目标日志文件。可以添加自定义规则,以便将所有日志转发到集中式syslog服务器。 4. 重启rsyslog服务:在Ubuntu和Debian系统中,sudo service rsyslog restart命令可以重启rsyslog服务。在CentOS系统中,可以使用systemctl restart rsyslog.service命令重启。 5. 测试syslog服务器:在测试syslog服务器时,可以使用logger命令来生成一个日志消息,例如,logger "Hello, syslog server!"。然后查看rsyslog配置文件所指定的日志文件,查看消息是否已成功写入。 在Linux系统中搭建syslog服务器可以很好地帮助管理员监控和分析系统日志,从而更好地维护系统的正常运行。通过以上步骤,我们可以轻松地搭建一台高效可靠的syslog服务器。 ### 回答3: Syslog是一个系统日志记录工具,它可以帮助管理员更方便地记录并管理系统的各种事件,如系统启动、关闭、内核错误等。在Linux系统中,搭建Syslog服务器可以让管理员更方便地管理整个系统中的日志。 以下是搭建Syslog服务器的步骤: 1. 安装Syslog服务器Linux系统上,Syslog服务器通常使用syslog-ng或rsyslog软件。通过包管理器如apt、yum或zypper等,可以安装这些软件。例如,在Ubuntu系统上可以使用如下命令: ``` sudo apt-get install syslog-ng ``` 2. 配置Syslog服务器 一旦安装了Syslog服务器,就需要配置其收集和转发日志Syslog服务器的默认配置文件通常位于/etc/syslog-ng/syslog-ng.conf或/etc/rsyslog.conf中。对于syslog-ng服务器,可以使用一些命令来测试其工作状态,例如: ``` syslog-ng -V ``` 这将显示当前Syslog服务器的版本。默认情况下,Syslog服务器将收集/var/log目录下的所有日志文件。 3. 客户端配置 要将一台Linux主机的日志发送到Syslog服务器,需要配置客户端日志记录器,例如rsyslogsyslog-ng。以rsyslog为例,可以在/etc/rsyslog.conf文件中添加以下行来配置Syslog服务器: ``` *.info;mail.none;authpriv.none;cron.none @server_ip_address ``` 其中,server_ip_address是Syslog服务器的IP地址。这将导致该主机将所有不包括邮件、认证和计划任务的消息发送到Syslog服务器。 4. 重启服务 完成客户端服务器配置后,需要重启相关服务以使其生效。以syslog-ng为例,可以使用以下命令重启服务器: ``` systemctl restart syslog-ng ``` 此时,所有客户端上的日志记录将发送到Syslog服务器并存储在其中。管理员可以使用工具如Logrotate等来管理日志文件,定期备份和删除旧日志文件。 总之,搭建Syslog服务器对于一个Linux管理员来说是一项基本的任务。它可以帮助管理员更好地管理系统事件,并且可以提供重要的调试信息,使其更容易诊断系统问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值