改变nginx logrotate方式采用sh文件自动切割日志文件

Logrotate读取/etc/logrotate.d目录下的文件
这里的文件会被系统自动执行
logrotate是作为linux系统日志的管理工具存在。他可以轮换,压缩,邮件系统日志文件。
默认的logrotate被加入cron的/etc/cron.daily中作为每日任务执行。
/etc/logrotate.conf为其默认配置文件指定每个日志文件的默认规则。
/etc/logrotate.d/* 为/etc/logrotate.conf默认包含目录其中文件也会被logrotate读取。指明每个日志文件的特定规则。
/var/lib/logrotate/status中默认记录logrotate上次轮换日志文件的时间。

翻开叫nginx这个文件内容如下

1
2
3
4
5
6
7
8
9
10
11
12
13
/var/log/nginx/*.log {
        daily
        missingok
        rotate 52
        compress
        delaycompress
        notifempty
        create 640 nginx adm
        sharedscripts
        postrotate
                [ -f /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid`
        endscript
}

解释
daily 脚本按天执行
missingok 当日志为空不进行翻滚
rotate 52 当日志超过52个之后,从头开始,即第53个会覆盖第一个
compress gzip压缩,nocompress表示不压缩,如果是httpd一定要压缩,这太占硬盘了
delaycompress 延迟压缩
prerotate 开始滚动日志的时候执行的代码
postrotate 滚动日志后执行的代码 可以看到nginx在滚动之后会执行一句shell ,用来让nginx重新生成日志
全部参数详情
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).
具体执行时间没怎么搞明白。我的系统里每天是7.35左右发生第一条日志,说明在7:35 执行了这个命令。但是时间不固定。目前推测为系统滚动日志按天的计划很多要一个一个的做。大家排队。
所以使用这种默认的日志切割方式,无法比较准确的按天来分日志。(理想的方式从0:00:00开始分日志。)
日志切割操作办法第一步:删除原来自动切割
所以删除这个方式的小办法就是删除/etc/logrotate.d/nginx 这个文件
来个脚本试试
日志切割操作办法第二步
功能点:
1.自动按天切割日志
2.按时间排放文件夹
3.保留30天的日志文件
4.自动压缩日志文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/bin/bash
#set the path to nginx log files
log_files_path="/var/log/nginx/"
log_files_dir=${log_files_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")
#set nginx log files you want to cut
log_files_name=(access error)
#set the path to nginx.
nginx_sbin="/etc/init.d/nginx"
#Set how long you want to save
save_days=30
 ############################################
#Please do not modify the following script #
############################################
mkdir -p $log_files_dir
 log_files_num=${#log_files_name[@]}
 #cut nginx log files
for((i=0;i<$log_files_num;i++));do
mv ${log_files_path}${log_files_name[i]}.log ${log_files_dir}/${log_files_name[i]}_$(date -d "yesterday" +"%Y%m%d").log
gzip ${log_files_dir}/${log_files_name[i]}_$(date -d "yesterday" +"%Y%m%d").log 
done
 #delete 30 days ago nginx log files
find $log_files_path -mtime +$save_days -exec rm -rf {} \; 
 $nginx_sbin  reload

用这个脚本,设置为0:00:00开始执行,这样就可以基本在0点进行日志快速切割了。
将脚本设置到crontab 里就好了。



本文转自 boy461205160 51CTO博客,原文链接:http://blog.51cto.com/461205160/1741264

上一篇:Java多线程的例子及synchronized关键字锁定对象的用法


下一篇:引进自动化解决方案中,如何选择合适的供电保证高效率?