导读 | 通常来讲,日志是任何故障排除过程当中很是重要的一部分,但这些日志会随着时间增加。在这种状况下,咱们须要手动执行日志清理以回收空间,这是一件繁琐的管理任务。为了解决这个问题,咱们能够在 Linux 中配置 logrotate 程序,它能够自动执行日志文件的轮换、压缩、删除和用邮件发出。咱们能够配置 logrotate 程序,以便每一个日志文件能够在天天、每周、每个月或当它变得太大时处理。 |
logrotate 是如何工做的html
默认状况下,logrotate 命令做为放在 /etc/cron.daily 中的 cron 任务,天天运行一次,它会帮助你设置一个策略,其中超过某个时间或大小的日志文件被轮换。
命令:linux
/usr/sbin/logrotate
配置文件: /etc/logrotate.conf,这是 logrotate 的主配置文件。logrotate 还在 /etc/logrotate.d/ 中存储了特定服务的配置。确保下面的那行包含在 /etc/logrotate.conf 中,以读取特定服务日志配置。git
include /etc/logrotate.d`
logrotate 历史: /var/lib/logrotate.statusgithub
重要的 logrotate 选项:post
compress --> 压缩日志文件的全部非当前版本 daily,weekly,monthly --> 按指定计划轮换日志文件 delaycompress --> 压缩全部版本,除了当前和下一个最近的 endscript --> 标记 prerotate 或 postrotate 脚本的结束 errors "emailid" --> 给指定邮箱发送错误通知 missingok --> 若是日志文件丢失,不要显示错误 notifempty --> 若是日志文件为空,则不轮换日志文件 olddir "dir" --> 指定日志文件的旧版本放在 “dir” 中 postrotate --> 引入一个在日志被轮换后执行的脚本 prerotate --> 引入一个在日志被轮换前执行的脚本 rotate 'n' --> 在轮换方案中包含日志的 n 个版本 sharedscripts --> 对于整个日志组只运行一次脚本 size='logsize' --> 在日志大小大于 logsize(例如 100K,4M)时轮换
配置命令行
让咱们为咱们本身的示例日志文件 /tmp/sample_output.log 配置 logrotate。日志
第一步:在 /etc/logrotate.conf 中添加如下行。htm
/tmp/sample_output.log { size 1k create 700 root root rotate 4 compress }
在上面的配置文件中:教程
第二步:一般,你须要等待一天才能等到 logrotate 由 /etc/cron.daily 执行。除此以外,你能够用下面的命令在命令行中运行:ip
/usr/sbin/logrotate /etc/logrotate.conf
在执行 logrotate 命令以前的输出:
[root@rhel1 tmp]# ls -l /tmp/ total 28 -rw-------. 1 root root 20000 Jan 1 05:23 sample_output.log
在执行 logrotate 以后的输出:
[root@rhel1 tmp]# ls -l /tmp total 12 -rwx------. 1 root root 0 Jan 1 05:24 sample_output.log -rw-------. 1 root root 599 Jan 1 05:24 sample_output.log-20170101.gz [root@rhel1 tmp]#
这样就能确认 logrotate 成功实现了。
via: http://www.linuxroutes.com/configure-logrotate/
做者:Manmohan Mirkar 译者:geekpi 校对:wxy
原文来自:https://linux.cn/article-8227-1.html
本文地址:http://www.linuxprobe.com/configure-logrotate-tutorial.html