日志
日志
- 日志文件是重要的系统信息文件,其中记录了许多重要的系统事件,包括用户的登录信息、系统的启动信息、系统的安全信息、邮件相关信息、各种服务相关信息等。
- 日志对于安全来说也很重要,它记录了系统每天发生的各种事情,通过日志来检查错误发生的原因或者受到攻击时攻击者留下的痕迹。
- 即日志是用来记录重大事件的工具
系统重要的日志的存放目录
cd /var/log/
查看每个用户的上次登录
lastlog
系统常用日志
日志管理服务
CentOS7.6日志服务是“rsyslogd” ,就是它在写日记!正经人谁写日记啊
查询rsyslogd服务是否已经启动
ps aux | grep "rsyslog" | grep -v "grep" //其中-v是反向匹配,就是不选择"grep",可用man grep查看帮助
查询rsyslogd服务的自启动状态
systemctl list-unit-files | grep rsyslog
查看日志文件
more /etc/rsyslog.conf
存放文件的格式:
- 日志类型 . 日志级别
日志类型
类型 | 注释 |
---|---|
* | ALL |
auth | pam产生的日志 |
authpriv | ssh、ftp等登录信息的验证信息 |
corn | 时间任务相关 |
kern | 内核 |
lpr | 打印 |
邮件 | |
mark(syslog)-rsyslog | 服务内部的信息,时间标识 |
news | 新闻组 |
user | 用户程序产生的相关信息 |
uucp | unix to nuix copy主机之间相关的通信 |
local 1-7 | 自定义的日志设备 |
日志级别
注意:从上到下,级别从低到高,记录信息越来越少
级别 | |
---|---|
* | ALL |
debug | 有调试信息的,日志通信最多 |
info | —般信息日志,最常用 |
notice | 最具有重要性的普通条件的信息 |
warning | 警告级别 |
err | 错误级别,阻止某个功能或者模块不能正常工作的信息 |
crit | 严重级别,阻止整个系统或者整个软件不能正常工作的信息 |
alert | 需要立刻修改的信息 |
emerg | 内核崩溃等重要信息 |
none | 什么都不记录 |
日志查看实例
查看secure日志
more /var/log/secure
日志内的信息格式:
- 时间、主机、程序、事件描述
自定义日志服务
1、在/var/rsyslog.conf中添加一个日志文件/var/log/hsp.log
vim /var/rsyslog.conf
2、进行一系列动作:例如重启
3、查看该文件
vat var/log/hsp.log
日志轮替
——日志轮替就是把旧的日志文件移动并改名,同时建立新的空日志文件,当旧日志文件超出保存的范围之后,就会进行删除
日志轮替文件命名
使用全局的日志轮替策略(就是放在同一个文件里)—— centos7使用logrotate进行日志轮替管理,要想改变日志轮替文件名字,通过/etc/logrotate.conf配置文件中“dateext”参数:
- 如果配置文件中有“dateext”参数,那么日志会用日期来作为日志文件的后缀。
- 例如“secure-20201010”。这样日志文件名不会重叠,也就不需要日志文件的改名,只需要指定保存日志个数,删除多余的日志文件即可。
- 如果配置文件中没有“dateext”参数,日志文件就需要进行改名了。
- 当第一次进行日志轮替时,当前的"secure”日志会自动改名为“secure.1”,然后新建“secure”日志,用来保存新的日志。
- 当第二次进行日志轮替时,“secure.1”会自动改名为“secure.2”,当前的“secure”日志会自动改名为"secure.1",然后也会新建“secure”日志,用来保存新的日志,以此类推。
一两年了的日志,就没必要保留。
查看logrotate配置文件
cat /etc/logrotate.conf
文件信息:
#rotate log files weekly,每周对日志文件进行一次轮替
weekly
# keep 4 weeks worth of backlogs,共保存4份日志文件,当建立新的日志文件时,旧的将会被删除
rotate 4
# create new (empty) log files after rotating old ones,创建新的空的日志文件,在日志轮替后
create
# use date as a suffix of the rotated file,使用日期作为日志轮替文件的后缀
dateext
# uncomment this if you want your log files compressed,日志文件是否压缩。如果取消注释,则日志会在转储的同时进行压缩
#compress
#RPM packages drop log rotation information into this directory,包含/etc/logrotate.d/目录中所有的子配置文件。也就是说会把这个目录中所有子配置文件读取进来
include /etc/logrotate.d
#下面是单独设置,优先级更高。
#no packages own wtmp and btmp -- we'll rotate them here
/var/log/wtmp {
monthly #每月对日志文件进行一次轮替
create 0664 root utmp #建立的新日志文件,权限是0664,所有者是root,所属组是utmp组
minsize 1M #日志文件最小轮替大小是1MB。也就是日志一定要超过1MB才会轮替,否则就算时间达到一个月,也不进行日志转储
rotate 1#仅保留一个日志备份。也就是只有wtmp和 wtmp.1日志保留而已
}
var/log/btmp {
missingok #如果日志不存在,则忽略该日志的警告信息
monthly
create 0600 root utmp
rotate 1
}
logrotate配置文件的参数
参数 | 参数说明 |
---|---|
daily | 日志的轮替周期是每天 |
weekly | 日志的轮替周期是每周 |
monthly | 日志的轮替周期是每月 |
rotate 数字 | 保留的日志文件的个数。0指没有备份 |
compress | 日志轮替时,旧的日志进行压缩 |
create mode owner group | 建立新日志,同时指定新日志的权限与所有者和所属组 |
mail address | 当日志轮替时,输出内容通过邮件发送到指定的邮件地址 |
missingok | 如果日志不存在,则忽略该日志的警告信息 |
notifempty | 如果日志为空文件,则不进行日志轮替 |
minsize大小 | 日志轮替的最小值。也就是白志一定要达到这个最小值才会轮替,否则就算时间达到也不轮替 |
size大小 | 日志只有大于指定大小才进行日志轮替,而不是按照时间轮替 |
dateext | 使用日期作为日志轮替文件的后缀 |
sharedscripts | 在此关键字之后的脚本只执行—次 |
prerotate/endscript | 在日志轮替之前执行脚本命令 |
postrotate/endscript | 在日志轮替之后执行脚本命令 |
创建轮替的两种方法
- 第一种方法是直接在/etc/logrotate.conf 配置文件中写入该日志的轮替策略
- 推荐使用第二种方法,因为系统中需要轮替的日志非常多,如果全都直接写入/etc/logrotate.conf配置文件,那么这个文件的可管理性就会非常差,不利于此文件的维护。
- 第二种方法是在/etc/logrotate.d/目录中新建立该日志的轮替文件,在该轮替文件中写入正确的轮替策略。
- 因为该目录中的文件都会被"include”到主配置文件中,所以也可以把日志加入轮替。
把自己的日志加入日志轮替
1、进入目录 /etc/logrotate.d
2、写个文件hsplog
vim hsplog
写入:
/var/log/hsp.log
{
missingok
daily
copytruncate
rotate 7
notifempty
}
内存日志
—— 有一部分日志是实时变化的,是先写入内存的,还没有写入文件。
journalctl
可以查看内存日志
注意:查看的是内存日志,重启就会清空
常用的指令
journalctl -n 3 //查看最新3条
journalctl --since 19:00 --until 19:10;10 //查看起始时间到结束时间的日志可加日期
journalctl -p err //报错日志
journalctl -o verbose //日志详细内容
journalctl_PID=1245 _COMM=sshd //查看包含这些参数的日志(在详细日志查看)
journalctl | grep sshd //与上一条等效
---------------------------
“朝着一个既定的方向去努力,就算没有天赋,在时间的积累下应该也能稍稍有点成就吧。”