欢迎光临
专业Linux运维二十年

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

脚本之家
赞(0) 打赏
未经允许不得转载:Linux老运维 » CentOS 7中Nginx日志定时拆分实现过程详解

觉得文章有用就打赏一下文章作者

非常感谢你的打赏,我们将继续提供更多优质内容,让我们一起创建更加美好的网络世界!

支付宝扫一扫

微信扫一扫