优选主流主机商
任何主机均需规范使用

CentOS 7中Nginx日志定时拆分详细步骤教程:轻松实现日志管理优化

一、编写拆分脚本(splitNginxLog.sh)

* 因为本例中设置每天0点进行日志的拆分,所以folder和rq均设置采用昨天的日期进行归档。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 #!/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

如果提示$’\r’: 未找到命令的解决,则有可能是.sh文件编码问题,是因为在Windows编辑器中编写的脚本与在linux中的有一些区别。

处理方法:

1. 安装dos2unix用于转化编码

# yum install dos2unix

2. 转换编码

# dos2unix splitNginx.sh

三、设置定时自动执行

# crontab -l //列出所有的定时任务
# crontab -e //编辑定时任务

在其中编写如下语句:

00 00 * * * bash /root/splitNginxLog.sh

以上就是本文的全部内容,希望对大家的学习有所帮助。

未经允许不得转载:搬瓦工中文网 » CentOS 7中Nginx日志定时拆分详细步骤教程:轻松实现日志管理优化