由于公司Nginx服务反代了N多的域名,所以日志也比较多,之前使用的日志切割脚本是一个每新增一个日志文件,就需要往脚本中添加一行MV比较麻烦,所以根据原有的脚本修改了一下,所有nginx下logs目录中的日志文件都统一mv到备份目录!
#!/bin/sh
# nginx 日志切割
nowD=$(date -d "today" +"%d")
nowM=$(date -d "today" +"%Y%m")
yesD=$(date -d "yesterday" +"%Y%m%d")
#nginx 日志路径
nglogpath=/opt/log_cutting_nginx/logs
#日志切割后的路径
bakpath=/opt/backup/$nowM
# 判断备份目录是否存在,不存在就创建。
if [ ! -d "$bakpath" ]; then
echo "创建文件夹"
mkdir -p $bakpath
else
echo "文件夹已存在"
fi
#将日志MV到备份目录
#第一步、ls -l /logs 日志目录将所有日志名取出来
#第二步、排除非log的文件使用 grep log
#第三步、awk '{sub(/.{4}$/,"")}1') 删除文件名最后4个字符,以便后面备份时拼接日期上去
#for i in $(ls -l $nglogpath/ |grep log |awk '{print $9}'|awk -F ".log" '{print $1}');do
for i in $(ls -l $nglogpath/ |grep log |awk '{print $9}'|awk '{sub(/.{4}$/,"")}1');do
#将日志文件备份到备份文件夹,且文件名加上当前年月日
mv $nglogpath/${i}.log $bakpath/${i}_${yesD}.log
echo $i
done
#reload 一下nginx使其重新生成日志文件
/usr/local/nginx/sbin/nginx -s reload