nginx访问日志切割脚本-阿里云开发者社区

开发者社区> 技术小胖子> 正文

nginx访问日志切割脚本

简介:
+关注继续查看

1、说明

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

wKioL1hJDW2AYqn8AAA0SQ0ucqY181.png


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

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 文件夹,下图是到今天为止的所有日志

wKioL1hJEAqSE7H6AABooLD1hZY944.png




      本文转自M四月天 51CTO博客,原文链接:http://blog.51cto.com/msiyuetian/1880769,如需转载请自行联系原作者








版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
日志系列--前端访问日志的统计分析
简介 很多个人站长在搭建网站时使用nginx作为服务器,为了了解网站的访问情况,一般有两种手段: 使用CNZZ之类的方式,在前端页面插入js,用户访问的时候触发js,记录访问请求。 分析nginx的access log,从日志中挖掘有用信息。
4165 0
nginx访问控制:如何通过map来控制http_x_forwarded_for访问限制
通过map修改访问限制 请求从lb过来,host已经变化,所以需要用http_x_forwarded_for来做限制。
3389 0
13262
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载