于一 发表于 2017-7-9 08:41:01

rsyslog服务专题及案例

  一、Rsyslog服务基本介绍
  syslog服务器可以用作一个网络中的日志监控中心,rsyslog是一个开源工具,被广泛用于Linux系统以通过TCP/UDP协议转发或接收日志消息。syslog服务器可以用作一个网络中的日志监控中心,所有能够通过网络来发送日志的设施(包含了Linux或Windows服务器,路由器,交换机以及其他主机)都可以把日志发送给它。 通过设置一个syslog服务器,可以将不同设施/主机发送的日志,过滤和合并到一个独立的位置,这样使得你更容易地查看和获取重要的日志消息。
  rsyslog同时扮演了两种角色:1.作为一个syslog服务器,rsyslog可以收集来自其他设施的日志信息;2.作为一个syslog客户端,rsyslog可以将其内部的日志信息传输到远程的syslog服务器。
  设施层级: 监听何种类型的进程
    严重性 (优先) 级别: 收集何种级别的日志消息
    目标: 发送或记录日志消息到何处
  1)设施层级
  auth: 身份验证相关的消息(登录时)
    cron: 进程或应用调度相关的消息
    daemon: 守护进程相关的消息(内部服务器)
    kernel: 内核相关的消息
    mail: 内部邮件服务器相关的消息
    syslog: syslog 守护进程本身相关的消息
    lpr: 打印服务相关的消息
    local0 - local7: 用户自定义的消息 (local7 通常被Cisco 和 Windows 服务器 使用)
  2)级别
  emerg: Emergency(紧急)- 0
    alert: Alerts (报警)- 1
    crit: Critical (关键)- 2
    err: Errors (错误)- 3
    warn: Warnings (警告)- 4
    notice: Notification (通知)- 5
    info: Information (消息)- 6
    debug: Debugging (调试)- 7
  3)目标
  保存日志消息到一个本地文件;
    通过TCP/UDP将消息路由到远程的syslog服务器中;
    将其发送到一个标准输出中,例如控制台。
  二、在Linux中配置Rsyslog
  1、初始化需求
  先创建一个独立分区/var,用于存放日志文件,该分区要求空间足够大
  2、配置rsyslog
  打开文件进行编辑,查找到下面的两行所在的位置,通过删除其行首的#字符来取消注释。

    $ModLoad imudp
    $UDPServerRun 514
  $ModLoad imtcp
    $InputTCPServerRun 514
  3、创建日志接收模板
  使用文本编辑器来打开 /etc/rsyslog.conf,然后在GLOBAL DIRECTIVE块前追加以下的模板。

    $template RemoteLogs,"/var/log/%HOSTNAME%/%PROGRAMNAME%.log" *
    *.* ?RemoteLogs---------------所有消息都记录到Remotelogs中
    & ~
  . ?RemoteLogs

例如:

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

    authpriv.* ?RemoteLogs
  案例:Rsyslog+LogAnalyzer+MySQL部署日志服务器
页: [1]
查看完整版本: rsyslog服务专题及案例