justcode.ikeepstudying.com
Linux日志文件总管——logrotate, MySQL慢日志分割, 配置 logrotate 的终极指导 - Just Code
日志文件包含了关于系统中发生的事件的有用信息,在排障过程中或者系统性能分析时经常被用到。对于忙碌的服务器,日志文件大小会增长极快,服务器会很快消耗磁盘空间,这成了个问题。除此之外,处理一个单个的庞大日志文件也常常是件十分棘手的事。 logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。例如,你可以设置logrotate,让/var/log/foo日志文件每30天轮循,并删除超过6个月的日志。配置完后,logrotate的运作完全自动化,不必进行任何进一步的人为干预。另外,旧日志也可以通过电子邮件发送,不过该选项超出了本教程的讨论范围。 主流Linux发行版上都默认安装有logrotate包,如果出于某种原因,logrotate没有出现在里头,你可以使用apt-get或yum命令来安装。 在Debian或Ubuntu上: apt-get install logrotate cron 在Fedora,CentOS或RHEL上: yum install logrotate crontabs logrotate的配置文件是/etc/logrotate.conf,通常不需要对它进行修改。日志文件的轮循设置在独立的配置文件中,它(们)放在/etc/logrotate.d/目录下。 size 1G:仅当日志文件大于1Gb时才旋转日志文件 dateext:通过使用格式YYYYMMDD而不是使用数字添加日期扩展来存档旧日志文件。 compress:使用gzip压缩旧日志文件(默认压缩程序) delaycompress:推迟前一个日志文件的压缩,直到下一个旋转cylce missingok:如果缺少日志文件,请不要发出错误消息 rotate 20:在删除旧日志之前保留20个日志文件 notifempty:不要旋转空日志文件 sharedscripts:运行prerotate和postrotate脚本只需一次,无论多少个日志与通配符模式匹配 nocopytruncate:创建副本后,请勿截断原始日志文件 create 660 mysql mysql:轮换后,使用权限模式660创建mysql拥有的新日志文件 postrotate:旋转完成后执行的脚本 样例一 在第一个样例中,我们将创建一个10MB的日志文件/var/log/log-file。我们将展示怎样使用logrotate来管理该日志文件。 我们从创建一个日志文件开始吧,然后在其中填入一个10MB的随机比特流数据。 # touch /var/log/log-file # head -c 10M < /dev/urandom > /var/log/log-file 由于现在日志文件已经准备好,我们将配置logrotate来轮循该日志文件。让我们为该文件创建一个配置文件。 # vim /etc/logrotate.d/log-file /var/log/log-file …