Nginx教程---03.Nginx日志切割
Nginx的定时任务与自动切割
明确:
如果这个网站的访问量比较大,那么一天下来 nginx日志可能会特别的大,所以当出现这种情况呢,如果
把每天的日志都存在同一个日志文件里,会使你的日志文件大到让你怀疑人生,同时也不好管理。所以就
希望每天在一个固定的时间来产生一个新的文件来存储当天的日志,这样就方便管理了很多。
思路:就是使用 定时任务 + USER1信号量来控制Nginx重新生成新的日志文件
此处需要shell脚本(shell脚本只要记住丫的声明就没啥了),与定时任务的相关知识
linux的date命令:
date:查看当前年月日,但不是格式化的,
date -d yesterday : 查看昨天的年月日 是这样形式的 "Fri Apr 13 00:06:06 PDT 2018"
date -d yesterday +'%Y%m%d' : 格式化的昨天的日期,是这样的:20180413 (人类能看懂了)
date -s '2018-4-14 00:09:00' 然后执行 clock -w 命令:修改linux的系统时间
-
1 开始实现定时任务
① 在/usr/local/nginx/ 下建data文件夹,用于存储每天产生的日志文件 命令:[root@localhost nginx]# mkdir /data [root@localhost nginx]# cd /data/ [root@localhost data]# vim runlog.sh //建个runlog.sh文件用于写shell脚本的定时任务
我们先来测试一下,写个简单的shell脚本,返回昨天的年月日
使用命令:sh runlog.sh 来执行脚本,查看返回结果
② 正式编辑runlog.sh文件
#!/bin/bash
LOGPATH=/usr/local/nginx/logs/human.com.access.log //nginx产生的日志
BASEPATH=/data/$(date -d yesterday +%Y%m) //每天产生的日志 按照月份 进行存放
mkdir -p $BASEPATH //创建月份文件夹
bak=$BASEPATH/$(date -d yesterday +%d%H%M).human.com.access.log //将每天产生的日志放在对应的月份下
mv $LOGPATH $bak //将nginx产生的日志 剪切 到bak中
touch $LOGPATH //重新创建 human.com.access.log 日志
kill USER1 'cat /usr/local/nginx/logs/nginx.pid' //重复日志
如图:
③ 使用命令 :crontab -e 创建时钟
*/1 * * * * sh /data/runlog.sh
依次:分 时 日 月 周
如图:
以上日志的定时切割准备完毕,下面开始测试:
回到data目录下: 使用ls命令 查看 出现 201804 这个文件夹
进入 2101804 目录下,每隔一分钟执行一次 ls 命令:
OK!定时的日志切割完成,目前为测试方便,定时为一分钟执行一次日志切割,生产环境中可对 定时器 自行设置!