一、编写拆分脚本(splitNginxLog.sh)
* 因为本例中设置每天0点进行日志的拆分,所以folder和rq均设置采用昨天的日期进行归档。
#!/bin/bash folder=`date -d yesterday +%Y%m` rq=`date -d yesterday +%Y%m%d` # 原始日志路径 logs_path="/var/log/nginx/sitename.com/" # 日志备份路径 logs_backup_path="/var/log/nginx/sitename.com/$folder" # 要分割的日志 logs_access="access" logs_error="error" # 创建备份路径 [ -d $logs_backup_path ]||mkdir -p $logs_backup_path # 将日志移入备份文件夹 mv ${logs_path}${logs_access}.log ${logs_backup_path}/${logs_access}_${rq}.log mv ${logs_path}${logs_error}.log ${logs_backup_path}/${logs_error}_${rq}.log # 终止nginx的pid pid_path="/var/run/nginx.pid" kill -USR1 $(cat $pid_path)
二、测试日志拆分脚本
在.sh文件的存放目录下运行如下语句,测试拆分脚本是否成功。
# sh splitNginxLog.sh
如果提示$’ ’: 未找到命令的解决,则有可能是.sh文件编码问题,是因为在Windows编辑器中编写的脚本与在linux中的有一些区别。
处理方法:
1. 安装dos2unix用于转化编码
# yum install dos2unix
2. 转换编码
# dos2unix splitNginx.sh
三、设置定时自动执行
# crontab -l //列出所有的定时任务 # crontab -e //编辑定时任务
在其中编写如下语句:
00 00 * * * bash /root/splitNginxLog.sh
参考资料:
日志拆分部分
https://blog.csdn.net/molaifeng/article/details/82667158
https://www.jianshu.com/p/1ccdd3e390ac
https://cloud.tencent.com/developer/article/1508110
https://www.cnblogs.com/free-long/p/8005082.html
编码转换部分
https://www.cnblogs.com/duanjt/p/9677589.html
SH文件执行部分
https://blog.csdn.net/hpf247/article/details/79190600
定时执行部分
https://www.cnblogs.com/cqlb/p/9772207.html
关于日期函数的使用