logrotate 是操作系统用来管理日志的工具,支持日志的切割、压缩、清理以及邮件报警等,通过 crontab 服务定时运行,也可以用这个工具来管理我们自己的服务日志,只需要简单配置下配置文件即可
logrotate 配置helloworld.conf
,多份日志可以直接写在一个配置文件里面,也可以分成多个文件 include
进来
/path/to/log/hello.log /path/to/log/world.err { hourly rotate 24 notifempty nocompress missingok copytruncate dateext dateformat .%Y%m%d%H olddir /path/to/log/bk/ postrotate echo "update to aws s3" endscript }
hourly
: 日志切割按照小时来切割,logrotate 3.9.0 以后版本才支持,但是其实真正的调度是在 crontab 里面配置的
rotate
: 保留多少个历史文件
notifempty
: 如果文件为空,则不切分文件,默认是 ifempty
nocompress
: 不压缩文件
missingok
: 忽略文件缺失信息
copytruncate
: 创建一个日志的拷贝,并且截断老的日志,适合那种一直写一个文件,也不关闭的服务。由于这个阶段的过程会有一小段时间,可能会有数据丢失
dateext
: 使用日期后缀
dateformat
: 日期后缀的格式
olddir
: 备份目录
postrotate/endscript
: 切割后执行的命令,这个选项非常灵活,可以实现一些强大的功能,比如日志上传,日志分析等等
运行
直接执行 logrotate -f helloworld.conf
可以强制执行切割,测试是否生效
上面测试没有问题之后,crontab -e
加入到 crontab 里面即可
59 * * * * /path/to/logrotate /path/to/helloworld.conf >/dev/null 2>&1
转载请注明出处
本文链接:http://www.hatlonely.com/2018/04/16/linux-%E6%97%A5%E5%BF%97%E7%AE%A1%E7%90%86%E6%9C%8D%E5%8A%A1-logrotate/
SpaceSniffer怎么开启日志扫描警告功能-开启日志扫描警告功能的方法
【老男孩Linux技术分享】5分钟带你搞懂日志采集利器Filebeat!