Nginx日志分割脚本

释放双眼,带上耳机,听听看~!

文章目录

  • 一、概述
    * 二、编写日志分割脚本
    * 三、执行脚本
    * 四、验证
    * 五、总结

一、概述

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掉前一天的日志进程,开始新的一天日志记录。

给TA打赏
共{{data.count}}人
人已打赏
安全运维

WordPress网站专用docker容器环境带Waf

2020-7-18 20:04:44

安全运维

运维安全-Gitlab管理员权限安全思考

2021-9-19 9:16:14

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索