Nginx访问日志切割脚本

1、说明
随着时间的增加,Nginx 的访问日志会越来越大,下图是新部署的线上 Zabbix 监控网站运行了十几天左右产生的访问日志达到213M。

Nginx访问日志切割脚本

所以必须进行日志分割,要求如下:

1、每天的日志单独生成一个文件
2、保留30天的访问日志

2、编写脚本
vim /usr/local/nginx/logs/nginx_log_rotate.sh

#! /bin/bash
 
logs_path="/usr/local/nginx/logs/"
log_name="access.log"
pid_path="/usr/local/nginx/logs/nginx.pid"
 
#日志文件集中存放的路径
[ -d /usr/local/nginx/logs/access_log ] || mkdir /usr/local/nginx/logs/access_log
access_logs_path="/usr/local/nginx/logs/access_log/"
 
#移动日志
mv ${logs_path}${log_name} ${access_logs_path}$(date --date="yesterday"+"%Y-%m-%d")_${log_name}
 
#生成新的access.log文件
kill -USR1 `cat ${pid_path}`
 
#删除一个月之前的日志
cd ${access_logs_path}
find . -ctime +30 -name "*access.log" |xargs rm -f
exit 0
脚本增加可执行权限

chmod a+x /usr/local/nginx/logs/nginx_log_rotate.sh
 
3、加入计划任务
每天凌晨运行脚本
crontab -e

00 00 * * * /usr/local/nginx/logs/nginx_log_rotate.sh
 
重启crond服务

service crond restart

运行脚本会生成 access_log 文件夹,下图是到今天为止的所有日志

Nginx访问日志切割脚本

下面关于Nginx的文章您也可能喜欢,不妨参考下:

CentOS 7.2下编译安装PHP7.0.10+MySQL5.7.14+Nginx1.10.1 

Nginx实现集群的负载均衡配置过程详解

Nginx高级应用--负载均衡与rewrite规则 

CentOS 6.4安装配置Nginx+Pcre+php-fpm

CentOS 6.8下源码安装 Nginx 1.11.10 

CentOS 7 编译安装Nginx1.10.2 脚本启动失败解决思路

Nginx简单实现网站的负载均衡 

Nginx 的详细介绍请点这里
Nginx 的下载地址请点这里

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/7663a9206628b054fd40bef06234805f.html