您的位置:首页 > 运维架构 > Nginx

Nginx按天分割轮询日志文件

2014-07-24 14:19 591 查看
使用linux系统自带的日志轮询工具logrotate

logrotate 介绍

-------------------------------------

logrotate 程序是一个日志文件管理工具。用来把旧的日志文件删除,并创建新的日志文件,我们把它叫做“转储”。我们可以根据日志文件的大小,也可以根据其天数来转储,这个过程一般通过cron 程序来执行。

logrotate 程序还可以用于压缩日志文件,以及发送日志到指定的E-mail 。

logrotate 的配置文件是/etc/logrotate.conf。主要参数如下表:

 

参数 功能

compress 通过gzip 压缩转储以后的日志

nocompress 不需要压缩时,用这个参数

copytruncate 用于还在打开中的日志文件,把当前日志备份并截断

nocopytruncate 备份日志文件但是不截断

create mode owner group 转储文件,使用指定的文件模式创建新的日志文件

nocreate 不建立新的日志文件

delaycompress 和compress 一起使用时,转储的日志文件到下一次转储时才压缩

nodelaycompress 覆盖delaycompress 选项,转储同时压缩。

errors address 专储时的错误信息发送到指定的Email 地址

ifempty 即使是空文件也转储,这个是logrotate 的缺省选项。

notifempty 如果是空文件的话,不转储

mail address 把转储的日志文件发送到指定的E-mail 地址

nomail 转储时不发送日志文件

olddir directory 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统

noolddir 转储后的日志文件和当前日志文件放在同一个目录下

prerotate/endscript 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行

postrotate/endscript 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行

daily 指定转储周期为每天

weekly 指定转储周期为每周

monthly 指定转储周期为每月

rotate count 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份

tabootext [+] list 让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, 

.rpmsave, v, 和~

size size 当日志文件到达指定的大小时才转储,Size 可以指定bytes (缺省)以及KB (sizek)或者MB 

(sizem).

Nginx日志文件access.log的轮询实例(RedHat Linux)

------------------------------------------------------------------------------

nginx安装在目录/usr/local/nginx

nginx的access.log日志存放在/usr/local/nginx/logs/access.log

第一步:

在/etc/logrotate.d/文件目录下添加一个nginx文件内容如下

/usr/local/nginx/logs/access.log {
daily
rotate 365
postrotate
/bin/kill -USR1 `/bin/cat /usr/local/nginx/logs/nginx.pid`
endscript
}


需要注意的是/etc/logrotate.conf中的include /etc/logrotate.d需要处于非注释状态

第二步:

logrotate是作为linux系统日志的管理工具存在。他可以轮换,压缩,邮件发送系统日志文件。默认的logrotate被加入cron(cron是一个linux下 的定时执行工具 ,可以在无需人工干预的情况下运行作业)的/etc/cron.daily中作为每日任务执行。/var/lib/logrotate/statue中默认记录logrotate上次轮换日志文件的时间。

因此要实现日志的自动轮询还需要配置cron的/etc/crontab文件,如下:

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name command to be executed
59  23  *  *  * root run-parts /etc/cron.daily


上面表示每天的 23:59 执行/etc/cron.daily目录中的所有可执行文件

配置完成后重启cron服务。

/sbin/service crond start //启动服务

/sbin/service crond stop //关闭服务

/sbin/service crond restart //重启服务
/sbin/service crond reload //重新载入配置

这样,每天都会自动轮询,生成access.log - n日志了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: