linux之系统日志管理

1.rsyslog                

          ##此服务是用来采集日志的,它不产生日志,只是起到采集作用

          vim  /etc/rsyslog.conf        ##查看采集日志信息

          /var/log/messages            ##服务信息日志
           /var/log/secure            ##系统登陆日志
           /var/log/cron                ##定时任务日志
           /var/log/maillog            ##邮件日志
           /var/log/boot.log            ##系统启动日志

 指定路径采集路径

            在指定日志的下一行  设定 *.*               /var/log/westos    重新启动服务,用ll命令查看westos采集的服务内容。

 linux之系统日志管理 

2.指定日志采集路径


**   *(什么类型日志).*(什么级别的日志)   /var/log/westos ##所有级别所有类型

什么类型的日志.什么级别的日志        /var/log/file    ##日志采集规则

##日志类型分为:
auth        ##pam产生的日志
authpriv    ##ssh,ftp等登陆信息的验证信息
cron        ##时间任务相关
kern        ##内核
lpr        ##打印
mail        ##邮件
mark(syslog)-rsyslog    ##服务内部的信息,时间标识
news        ##新闻组
user        ##用户程序产生的相关信息
uucp        ##unix to unix copy,unix主机之间相关的通讯
local 1~7    ##自定义的日志设备

##日志级别分为:
debug        ##有调试信息的,日志信息最多
info        ##一般信息的日志,最常用
notice        ##最具有重要性的普通条件的信息
warning        ##警告级别
err        ##错误级别,阻止某个功能或者模块不能正常工作的信息
crit        ##严重级别,阻止整个系统或者整个软件不能正常工作的信息
alert        ##需要立刻修改的信息
emerg        ##内核崩溃等严重信息
none        ##什么都不记录

##注意:从上到下,级别从低到高,记录的信息越来越少
##详细的可以查看手册:man 3 syslog

 

2.日志的远程同步

1)在日志的发送方:

           vim /etc/rsyslog.conf
           *.*        @172.25.254.200 (接受方的ip)        ##"@表示udp  @@表示tcp"""

           systemctl  restart  rsyslog

2)在日志的接受方:
          vim  /etc/rsyslog.conf
          $ModLoad  imudp         ##日志接受模块
          $UDPServerRun 514    ##开启接受端口


         systemctl  restart  rsyslog
         systemctl  stop  firewalld        ##关闭火墙
         systemctl  disable  firewalld    ##设定火墙开机关闭

           linux之系统日志管理

                

3)测试:
         在发送方和接受方都清空日志文件
         > /var/log/messages

         在日志的发送方
         logger test

         cat /var/log/messages    ##查看日志已经完成

         在日志接受方查看
          cat /var/log/messages

          linux之系统日志管理

          linux之系统日志管理

###日志采集格式的设定##
在接收方:

vim /etc/rsyslog.conf
systemctl restart rsyslog

$template LOGFMT, "%timegenerated% %FROMHOST-IP% %syslogtag% %msg%\n"
*.*                            /var/log/westos;LOGFMT

%timegenerated%        ##显示日志时间
%FROMHOST-IP%        ##显示主机ip
%svslogtag%        ##日志记录目标
%msg%            ##日志内容
\n            ##换行

cat /var/log/westos

linux之系统日志管理

linux之系统日志管理

3.时间同步服务

服务名称
      chronyd

1)在服务端:
vim /etc/chrony.conf
22    allow 172.25.254.0/24        ##允许那些客户端来同步本机时间
29     local stratum 10                   ##本机不同步任何主机的时进,本机作为时间源

systemctl restart chronyd
timedatectl set-timezone Asia/Shanghai

linux之系统日志管理

linux之系统日志管理

2)在客户端:
vim /etc/chrony.conf
server 172.25.254.200 iburst(三行删掉一行改)   ##本机立即同步200主机的时间

systemctl restart chronyd
timedatectl set-timezone Asia/Shanghai        ##管理时间改时区

3)测试
[[email protected] Desktop]# chronyc sources -v
210 Number of sources = 1

  .-- Source mode  '^' = server, '=' = peer, '#' = local clock.
 / .- Source state '*' = current synced, '+' = combined , '-' = not combined,
| /   '?' = unreachable, 'x' = time may be in error, '~' = time too variable.
||                                                 .- xxxx [ yyyy ] +/- zzzz
||                                                /   xxxx = adjusted offset,
||         Log2(Polling interval) -.             |    yyyy = measured offset,
||                                  \            |    zzzz = estimated error.
||                                   |           |                         
MS Name/IP address         Stratum Poll Reach LastRx Last sample
===============================================================================
^* 172.25.254.216                0   7     0   10y     +0ns[   +0ns] +/-    0ns
##出现问号?时,要注意火墙是否关闭

linux之系统日志管理
linux之系统日志管理


4.timedatectl 命令

timedatectl    ##管理系统时间
         status            ##显示当前时间信息
        set-time        ##设定当前时间
eg:timedatectl set-time "2018-11-11 11:11:11"    ##设定当前时间为2018年11月11日11点11分11秒
        set-timezone        ##设定当前时区
eg:timedatectl set-timezone Asia/Shanghai    ##设定当前时区为东8区

        set-local-rtc 0|1    ##设定是否使用utc时间 (1开0关)
        list-timezones        ##查看支持的所有时区

linux之系统日志管理

linux之系统日志管理

linux之系统日志管理

5.journal

1.journalctl           ##日志查看工具
            -n 3           ##查看最近三条日志
            -p err        ##查看错误日志
            -o verbose    ##查看日志的详细参数
            --since      ##查看从什么时间开始的日志
            --until        ##查看从什么时间截止的日志

linux之系统日志管理

linux之系统日志管理

linux之系统日志管理

linux之系统日志管理

linux之系统日志管理

 

2.如何使用systemd-journald保存系统日志
默认systemd-journald是不保存系统日志到硬盘的
那么关机后再次开机只能看到本次开机之后的日志
上一次关机之前的日志是无法查看的

mkdir /var/log/journal
chgrp systemd-journal /var/log/journal
chmod g+s /var/log/journal
killall -1 systemd-journald

ls /var/log/journal
946cb0e817ea4adb916183df8c4fc817

reboot        ##重启
journalctl -n 6

linux之系统日志管理

linux之系统日志管理