文章目录
- 一、概述
* 二、编写日志分割脚本
* 三、执行脚本
* 四、验证
* 五、总结
一、概述
Nginx自身不具备日志分割处理的功能,但可以通过Nginx信号控制功能的脚本实现日志的自动切割,并通过Linux的计划性周期性地进行日志切割。
二、编写日志分割脚本
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| 1[root@localhost ~]# vim jiaoben.sh
2#!/bin/bash
3#Filename:fenge.sh
4d=$(date -d "-1 day" "+%Y%m%d") ##前一天时间
5logs_path="/var/log/nginx" ###自己创建的nginx日志存放目录
6pid_path="/usr/local/nginx/logs/nginx.pid" ###nginx日志进程号
7[ -d $logs_path ] || mkdir -p $logs_path
8 ##如果没有这个文件,则创建
9mv /usr/local/nginx/logs/access.log ${logs_path}/access.log-$d
10 ##将nginx访问日志移动到自建的日志存放目录
11kill -USR1 $(cat $pid_path) ##杀死昨天的日志进程号
12find $logs_path -mtime +30 | xargs rm -rf ##清空30天前的日志
13
14
15 |
三、执行脚本
1 2 3
| 1[root@localhost ~]# bash jiaoben.sh
2
3 |
四、验证
1 2 3 4
| 1[root@localhost ~]# ls /var/log/nginx/
2access.log-20191224
3
4 |
五、总结
可以通过周期性计划任务让该脚本在每天的凌晨12点执行,即该日志会保存前一天的所有内容,在保存的同时会kill掉前一天的日志进程,开始新的一天日志记录。