我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux系统中如何安装Syslog

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux系统中如何安装Syslog

这篇文章主要介绍了Linux系统中如何安装Syslog,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Syslog常被称为系统日志或系统记录,是一种用来在互联网协议(TCP/IP)的网上中传递记录档消息的标准。这个词汇常用来指涉实际的syslog 协议,或者那些提交syslog消息的应用程序或数据库。

Linux系统中如何安装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 imudp2.$UDPServerRun 514

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

1.$ModLoad imtcp2.$InputTCPServerRun 514

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

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

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

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

1.$template RemoteLogs,"/var/log/%HOSTNAME%/%PROGRAMNAME%.log" *2.*.*  ?RemoteLogs3.& ~

在此对该模板进行简单解释,$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.*.*  ?IpTemplate3.& ~

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

在 Debian,Ubuntu 或 CentOS/RHEL 6中:

1.$ sudo service rsyslog restart

在 Fedora 或 CentOS/RHEL 7中:

1.$ sudo systemctl restart rsyslog

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

1. $ sudo netstat -tulpn | grep rsyslog

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

1.udp     0 0    0.0.0.0:514    0.0.0.0:*      551/rsyslogd2.udp6    0 0    :::514         :::*           551/rsyslogd

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

1.tcp     0 0     0.0.0.0:514   0.0.0.0:*     LISTEN    1891/rsyslogd2.tcp6    0 0     :::514        :::*          LISTEN    1891/rsyslogd

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

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

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

Linux系统中如何安装Syslog
在 Linux 上配置一个 syslog 服务器在 Linux 上配置一个 syslog 服务器

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

感谢你能够认真阅读完这篇文章,希望小编分享的“Linux系统中如何安装Syslog”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux系统中如何安装Syslog

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux系统中如何安装Syslog

这篇文章主要介绍了Linux系统中如何安装Syslog,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Syslog常被称为系统日志或系统记录,是一种用来在互联网协议(TCP/I
2023-06-27

如何进行Linux系统syslog分析

如何进行Linux系统syslog分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、日志系统之syslogsyslog是Linux系统中默认的日志守护进程,RHEL5上
2023-06-28

Linux系统中syslog服务器的安装方法是什么呢

小编今天带大家了解Linux系统中syslog服务器的安装方法是什么呢,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Linux系统中
2023-06-28

Linux系统中如何安装perl

这篇文章主要介绍了Linux系统中如何安装perl,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Perl是一种动态解释型的脚本语言,借取了C、sed、awk、shell sc
2023-06-28

Linux系统中如何安装OpenCV

这篇“Linux系统中如何安装OpenCV”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“Linux系统中如何安装OpenCV”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所
2023-06-28

Linux系统中如何安装Jenkins

这篇“Linux系统中如何安装Jenkins”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“Linux系统中如何安装Jenkins”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解
2023-06-28

Linux系统中如何安装openssl

这篇文章将为大家详细讲解有关Linux系统中如何安装openssl,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。openssl简介:openssl是一个安全套接字层密码库,囊括主要的密码算法、常用密钥、证
2023-06-28

Linux系统中如何安装telnet

这篇文章将为大家详细讲解有关Linux系统中如何安装telnet,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Telnet属于TCP/IP协议的一部分,它可以为用户提供在本地计算机上完成远程
2023-06-28

Linux系统中如何安装Mono

这篇文章给大家分享的是有关Linux系统中如何安装Mono的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、安装libgdiplus使用windwos编译的一个裁剪图片的程序,想通过mono在linux下运行,但
2023-06-28

Linux系统中如何安装eclipse

这篇“Linux系统中如何安装eclipse”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“Linux系统中如何安装eclipse”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章
2023-06-28

Linux系统中如何安装JDK

这篇文章主要为大家展示了Linux系统中如何安装JDK,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“Linux系统中如何安装JDK”这篇文章吧。 JDK这是Java Development Kit
2023-06-28

Linux系统中如何安装MySQL

这篇文章给大家分享的是有关Linux系统中如何安装MySQL的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、获取mysql YUM源打开网址:https://dev.mysql.com/downloads/re
2023-06-28

Linux系统中如何安装FTP

这篇文章主要介绍了Linux系统中如何安装FTP,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。FTP是 TCP/IP 协议组中的协议之一。FTP协议包括两个组成部分,其一为F
2023-06-27

Linux系统中如何安装MariaDB

小编给大家分享一下Linux系统中如何安装MariaDB,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!MariaDB数据库管理系统是 MySQL 的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是
2023-06-27

Linux系统中如何安装Wireshark

小编给大家分享一下Linux系统中如何安装Wireshark,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! Wireshark是非常流行的网络封包分析软件,可以截取各种网络数据包,并显示数据包详细信息。常用于开发测试过程各
2023-06-28

Linux系统中如何安装tensorflow

这篇文章主要为大家展示了“Linux系统中如何安装tensorflow”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux系统中如何安装tensorflow”这篇文章吧。TensorFlow
2023-06-28

Linux系统中如何安装Qt

这篇文章主要为大家展示了Linux系统中如何安装Qt,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“Linux系统中如何安装Qt”这篇文章吧。Qt 是一种更快,更智能的方式来为多个屏幕创建创新的设备
2023-06-28

Linux系统中如何安装Informix

这篇“Linux系统中如何安装Informix”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“Linux系统中如何安装Informix”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢
2023-06-28

Linux系统中如何安装curl

这篇文章主要介绍了Linux系统中如何安装curl,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。curl是一个使用URL语法在命令行下使用的文本传输工具。curl简介:cur
2023-06-28

Linux系统中如何安装wine

小编给大家分享一下Linux系统中如何安装wine,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!wine简介:Wine (“Wine Is Not an Emul
2023-06-28

编程热搜

目录