阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

CentOS上配置rsyslog客户端用以远程记录日志

136次阅读
没有评论

共计 2454 个字符,预计需要花费 7 分钟才能阅读完成。

rsyslog 是一个开源工具,被广泛用于 Linux 系统以通过 TCP/UDP 协议转发或接收日志消息。rsyslog 守护进程可以被配置成两种环境,一种是配置成日志收集服务器,rsyslog 进程可以从网络中收集其它主机上的日志数据,这些主机会将日志配置为发送到另外的远程服务器。rsyslog 的另外一个用法,就是可以配置为客户端,用来过滤和发送内部日志消息到本地文件夹(如 /var/log)或一台可以路由到的远程 rsyslog 服务器上。

假定你的网络中已经有一台已经配置好并启动的 rsyslog 服务器,本指南将为你展示如何来设置 CentOS 系统将其内部日志消息路由到一台远程 rsyslog 服务器上。这将大大改善你的系统磁盘空间的使用,尤其是当你还没有一个用于 /var 目录的独立的大分区。

CentOS 上配置 rsyslog 客户端用以远程记录日志

步骤一:安装 Rsyslog 守护进程

在 CentOS 6 和 7 上,rsyslog 守护进程已经预先安装了。要验证 rsyslog 是否已经安装到你的 CentOS 系统上,请执行如下命令:

  1. # rpm -qa | grep rsyslog
  2. # rsyslogd -v

CentOS 上配置 rsyslog 客户端用以远程记录日志

如果处于某种原因,rsyslog 守护进程没有出现在你的系统中,请使用以下命令来安装:

  1. # yum install rsyslog

步骤二:配置 Rsyslog 守护进程为客户端

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

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

  1. # nano /etc/rsyslog.conf

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

  1. *.*@192.168.1.25:514

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

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

  1. *.*@@192.168.1.25:514

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

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

  1. kern.*@192.168.1.25:514

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

CentOS 7:

  1. # systemctl restart rsyslog.service

CentOS 6:

  1. # service rsyslog restart

非 syslog 日志的转发

在另外一种环境中,让我们假定你已经在机器上安装了一个名为“foobar”的应用程序,它会在 /var/log 下生成 foobar.log 日志文件。现在,你想要将它的日志定向到 rsyslog 服务器,这可以通过像下面这样在 rsyslog 配置文件中加载 imfile 模块来实现。

首先,加载 imfile 模块,这只需做一次。

  1. module(load=“imfile”PollingInterval=“5”)

然后,指定日志文件的路径以便 imfile 模块可以检测到:

  1. input(type=“imfile”
  2. File=“/var/log/foobar.log”
  3. Tag=“foobar”
  4. Severity=“error”
  5. Facility=“local7”)

最后,定向 local7 设备到远程 rsyslog 服务器:

  1. local7.*@192.168.1.25:514

别忘了重启 rsyslog 进程哦!

步骤三:让 Rsyslog 进程自动启动

要让 rsyslog 客户端在每次系统重启后自动启动,请运行以下命令:

CentOS 7:

  1. # systemctl enable rsyslog.service

CentOS 6:

  1. # chkconfig rsyslog on

小结

在本教程中,我演示了如何将 CentOS 系统转变成 rsyslog 客户端以强制它发送日志消息到远程 rsyslog 服务器。这里我假定 rsyslog 客户端和服务器之间的连接是安全的(如,在有防火墙保护的公司网络中)。不管在任何情况下,都不要配置 rsyslog 客户端将日志消息通过不安全的网络转发,或者,特别是通过互联网转发,因为 syslog 协议是一个明文协议。要进行安全传输,可以考虑使用 TLS/SSL 来加密日志消息的传输。

————————————– 分割线 ————————————–

RHEL5.4 部署中央日志服务器之 rsyslog+Log Analyzer http://www.linuxidc.com/Linux/2012-01/51853.htm

CentOS 6.3 下利用 Rsyslog+LogAnalyzer+MySQL 部署日志服务器 http://www.linuxidc.com/Linux/2013-07/86956.htm

使用 rsyslog mysql 和 logAnalyzer 的日志服务器 http://www.linuxidc.com/Linux/2012-09/70717.htm

CentOS 6.3 下利用 Rsyslog+LogAnalyzer+MySQL 部署日志服务器 http://www.linuxidc.com/Linux/2013-07/86956.htm

RHEL5.4 部署中央日志服务器之 rsyslog+loganalyzer  http://www.linuxidc.com/Linux/2010-12/30801.htm

————————————– 分割线 ————————————–

Rsyslog 的详细介绍 :请点这里
Rsyslog 的下载地址 :请点这里

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计2454字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中