CentOS 7中Nginx日志定时拆分实现过程详解
一、编写拆分脚本(splitNginxLog.sh)
*因为本例中设置每天0点进行日志的拆分,所以folder和rq均设置采用昨天的日期进行归档。
#!/bin/bash
folder=`date-dyesterday+%Y%m`
rq=`date-dyesterday+%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文件的存放目录下运行如下语句,测试拆分脚本是否成功。
#shsplitNginxLog.sh
如果提示$'\r':未找到命令的解决,则有可能是.sh文件编码问题,是因为在Windows编辑器中编写的脚本与在linux中的有一些区别。
处理方法:
1.安装dos2unix用于转化编码
#yuminstalldos2unix
2.转换编码
#dos2unixsplitNginx.sh
三、设置定时自动执行
#crontab-l//列出所有的定时任务
#crontab-e//编辑定时任务
在其中编写如下语句:
0000***bash/root/splitNginxLog.sh
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。