共计 1477 个字符,预计需要花费 4 分钟才能阅读完成。
1、说明
随着时间的增加,Nginx 的访问日志会越来越大,下图是新部署的线上 Zabbix 监控网站运行了十几天左右产生的访问日志达到 213M。
所以必须进行日志分割,要求如下:
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 的文章您也可能喜欢,不妨参考下:
CentOS 7.2 下编译安装 PHP7.0.10+MySQL5.7.14+Nginx1.10.1 http://www.linuxidc.com/Linux/2016-09/134804.htm
Nginx 实现集群的负载均衡配置过程详解 http://www.linuxidc.com/Linux/2017-02/140549.htm
Nginx 高级应用 – 负载均衡与 rewrite 规则 http://www.linuxidc.com/Linux/2017-02/140476.htm
CentOS 6.4 安装配置 Nginx+Pcre+php-fpm http://www.linuxidc.com/Linux/2013-08/88984.htm
CentOS 6.8 下源码安装 Nginx 1.11.10 http://www.linuxidc.com/Linux/2017-03/141908.htm
CentOS 7 编译安装 Nginx1.10.2 脚本启动失败解决思路 http://www.linuxidc.com/Linux/2017-01/139794.htm
Nginx 简单实现网站的负载均衡 http://www.linuxidc.com/Linux/2017-02/140351.htm
Nginx 的详细介绍:请点这里
Nginx 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-04/142965.htm