返回顶部
首页 > 资讯 > 服务器 >rsyslog详解
  • 928
分享到

rsyslog详解

linux运维服务器 2023-09-06 10:09:23 928人浏览 八月长安
摘要

一、日志介绍 日志概念 日志是系统用来记录系统及应用程序运行时的一些相关信息的文本文件 日志作用 日志是为了保存相关程序的运行状态、错误信息等,为了对系统进行分析、保存历史记录以及在出现错误时发现

一、日志介绍

  1. 日志概念

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

  2. 日志作用

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

  3. linux系统日志类型

    内核信息

    服务信息

    应用程序信息

二、rsyslog

1、rsyslog介绍

rsyslog是linux系统中用来实现日志功能的服务。默认已经安装,并且自动启用。作用:主要用来采集日志,不生产日志其特性包括:支持输出日志到各种数据库,如 MysqlpostgresqlmongoDB 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.priorityaction# facility.priority  日志类型.级别# action  保存位置(文件、用户、日志服务器)# 记录mail日志等级为error及以上日志mail.err/var/log/mail_err.log# 将mail的所有信息,除了info以外,其他的都写入/var/adm/mailmail.*;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#重启rsyslogsystemctl restart rsyslog

日志格式效果

# NOW | timestamp:8:15| hostname| syslogseverity-text | syslogtag | msg2021-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

来源地址:https://blog.csdn.net/wq1205750492/article/details/124929232

--结束END--

本文标题: rsyslog详解

本文链接: https://lsjlt.com/news/396903.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • rsyslog详解
    一、日志介绍 日志概念 日志是系统用来记录系统及应用程序运行时的一些相关信息的文本文件 日志作用 日志是为了保存相关程序的运行状态、错误信息等,为了对系统进行分析、保存历史记录以及在出现错误时发现...
    99+
    2023-09-06
    linux 运维 服务器
  • rsyslog+mysql怎么用
    这篇文章主要为大家展示了“rsyslog+mysql怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“rsyslog+mysql怎么用”这篇文章吧。 1. ...
    99+
    2024-04-02
  • rsyslog 8.11.0 (v8-stable) 发布
    Rsyslog 是一个 syslogd 的多线程增强版。rsyslog项目的目标是提供一个更可靠的系统日志守护进程和配置。所谓“可靠”,是指支持如TCP或RFC 3195(系统日志可靠)可靠的传输...
    99+
    2023-06-17
    rsyslog
  • Rsyslog+H3C日志系统
    一、交换机发送日志到linux主机[9F-3600V2-EI]info-center loghost 192.168.11.36[9F-3600V2-EI]info-center enable 二、linux下配置   1.建立日志文件路径...
    99+
    2023-01-31
    系统 日志 Rsyslog
  • Centos 6.5 ----日志系统Rsyslog
                     &...
    99+
    2024-04-02
  • CentOS8中怎么配置Rsyslog
    这篇文章主要介绍“CentOS8中怎么配置Rsyslog”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CentOS8中怎么配置Rsyslog”文章能帮助大家解决问题。Rsyslog 是一个 sysl...
    99+
    2023-06-27
  • Ubuntu18.04 LTS如何安装Rsyslog
    今天小编给大家分享一下Ubuntu18.04  LTS如何安装Rsyslog的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2023-06-28
  • rsyslog管理分布式日志
    背景有一个4台机器的分布式服务,不多不少,上每台机器上查看日志比较麻烦,用Flume,Logstash、ElasticSearch、Kibana等分布式日志管理系统又显得大材小用,所以想到了centos自带...
    99+
    2024-04-02
  • Centos6.7mini搭建rsyslog+loganalyzer(未完待续)
    rsyslog是linux自带的日志软件,也可以收集本机和其他设备的syslog日志;loganalyzer是一个日志查看系统,基于lamp平台。但是我安装完后查看时,日志内容刷新反映很慢,不知到是什么原因...
    99+
    2024-04-02
  • 最新版的rsyslog有哪些优点
    这篇文章主要介绍“最新版的rsyslog有哪些优点”,在日常操作中,相信很多人在最新版的rsyslog有哪些优点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”最新版的rsyslog有哪些优点”的疑惑有所帮助!...
    99+
    2023-06-13
  • linux怎么配置rsyslog日志转发
    要配置rsyslog日志转发,可以按照以下步骤进行操作:1. 安装rsyslog软件:在终端中运行以下命令安装rsyslog软件:`...
    99+
    2023-10-12
    linux
  • Linux自学笔记——日志服务之rsyslog
    日志:历史事件日志历史事件: 时间,事件 时间级别(日志级别):事件的关键性程度;事件:系统引导启动、应用程序启动、应用程序尤其是服务类应用程序运行过程中的一些事件:系统日志服务:&em...
    99+
    2024-04-02
  • Linux下rsyslog日志服务的示例分析
    这篇文章主要介绍了Linux下rsyslog日志服务的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Linux上的Syslog(系统日志协议)服务可以充当网络上的企业...
    99+
    2023-06-27
  • 【Linux】rsyslog日志服务(配置,测试、日志转储)
    一、rsyslog简介 Rsyslog的全称是 rocket-fast system for log ,可用于接受来自各种来源的输入,转换 它们,并将结果输出到不同的目的地。 它提供了高性能、强大的安全功能和模块化设计。虽然rsys...
    99+
    2023-09-02
    linux 服务器 网络 Powered by 金山文档
  • centos下怎么配置rsyslog日志收集服务器
    今天小编给大家分享一下centos下怎么配置rsyslog日志收集服务器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。rsy...
    99+
    2023-06-27
  • EventBus详解 (详解 + 原理)
    一、EventBus的使用介绍 EventBus简介 EventBus是一个开源库,由GreenRobot开发而来,是用于Android开发的 “事件发布—订阅总线”, 用来进行模块间通信、解藕。它可以使用很少的代码,来实现多组件之间...
    99+
    2023-08-31
    android
  • @Profile注解详解
    @Profile:Spring为我们提供的可以根据当前环境,动态的激活和切换一系列组件的功能;开发环境develop、测试环境test、生产环境master数据源:(/dev) (/test) (/master)@Profile:指定组件在...
    99+
    2018-01-19
    java教程 注解
  • @TableField注解详解
    @TableField(value = "email")//指定数据库表中字段名 如果数据库和实体类的字段名不一致,可以使用@TableField注解指定数据库表中字段名。  2、@TableField(exist = "false")/...
    99+
    2023-09-02
    数据库 sql java
  • 详解@Override注解
    目录 1.是什么 2.为什么用 3.举例说明 1)示例一 2)示例二 3)示例三 1.是什么 @Override注解是伪代码,用于表示被标注的方法是一个重写方法。 @Override注解,只能用于标记方法,并且它只在编译期生效,不会保留...
    99+
    2023-09-24
    java
  • @PreAuthorize注解详解
    @PreAuthorize注解会在方法执行前进行权限验证,支持Spring EL表达式,它是基于方法注解的权限解决方案。只有当@EnableGlobalMethodSecurity(prePostEnabled=true)的时候,@PreA...
    99+
    2023-09-14
    spring java mybatis
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作