nginx 按天分割日志

nginx默认的日志是统一写到 安装目录的log下的 ,访问日志是 access.log,错误日志是error.log
而且并没有提供一个可配置的地方,对于生产环境,日志都集中在一块儿,没过几天日志文件就可以大到几个G,只能是使用操作系统的定时任务,自己写脚本定时执行,将log日志进行切割。

参考网上前辈的文章,自己写了一个脚本出来。代码如下:

#定义日志的源路径,即nginx的默认log路径
source_log_path=/usr/local/nginx/logs
#定义保存后的路径位置
dest_log_path=/opt/logs/nginx
#定义log文件的名称,以每天为单位,定义日志的前缀为昨天的日期,因为定时任务拟在凌晨零点后执行。
yesterday=$(date -d "yesterday" +%Y%m%d) 
#echo ${yesterday}
#rm -rf ${dest_log_path}/*
#指定移动
mv ${source_log_path}/access.log ${dest_log_path}/nginx_access_${yesterday}.log
mv ${source_log_path}/error.log  ${dest_log_path}/nginx_error_${yesterday}.log 
#移动后,重新向nginx的主进程发送信息,令nginx的主进程将日志重新打开。否则日志将会继续写到mv后的路径中
kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`
cd ${dest_log_path} 
#进入日志的路径,查询前天前的日志,然后将其删掉。
find . -mtime +7 -name "*20[1-9][3-9]*" |xargs rm -rf
exit 0 

最后,将该代码保存到一个sh文件,并将该文件加入到系统的定时任务中。

#定时任务的文件在 /etc/crontab 下,vi此文件,设置为每天 零点 执行。
0 0 * * * root /bin/sh /opt/sampleEnvironment/commands/nginxlogperday.sh
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值