欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

Shell脚本分割Nginx日志,并定期清理

程序员文章站 2022-04-29 10:15:14
...
默认nginx只会生成一个访问日志,在每天的积累下,日志文件会变的非常大,如果需要做一下日志的分析,无论是使用脚本分析,还是把日志下载本地分析,都不太方便。每天分割Nginx的访问日志,有利于分析日志。

一:新建脚本文件

vim cut_nginx_log.sh
  1. #!/bin/bash
  2. #nginx access log segmentation shell script
  3. #www.webyang.net
  4. #日志目录
  5. log_dir="/usr/local/nginx/logs/"
  6. cd $log_dir
  7. time=`date +%Y%m%d --date="-1 day"`
  8. #nginx启动目录
  9. nginx_dir="/etc/init.d/nginx"
  10. #日志保存天数
  11. save_days=15
  12. #日志文件名所处'/'分割的位置,key('/'数+1)
  13. num=6;
  14. #此处待优化(取得文件不带后缀的文件名)
  15. website=`ls $log_dir*.log | xargs -n 1 | cut -f 1 -d "." | cut -f $num -d "/"`
  16. #日志目录下所有的日志文件为文件夹,循环新建对应的时间文件
  17. for i in $website
  18. do
  19. #判断目录是否存在
  20. if[!-d $log_dir$i ];then
  21. mkdir "$i"
  22. fi
  23. mv $log_dir$i.log $log_dir$i/$i-$time.log
  24. done
  25. #删除设置天数前的数据
  26. find $log_dir/-mtime +$save_days -exec rm -rf {} \;
  27. #平滑启动nginx
  28. $nginx_dir reload
二、设置crontab,每天定时切割
如果没有安装,运行yum -y install crontabs 安装。
输入crontab -e命令(详情参考:http://www.webyang.net/Html/web/article_232.html),
输入下面的内容:
00 00 * * * /bin/bash /usr/local/nginx/cut_nginx_log.sh
1、00 00意思为00分00点,也就是凌晨0点,后面“ * * * ”为“ 日 月 年 ”无需定义
2、"/usr/local/nginx/cut_nginx_log.sh" 为你的shell的路径。

OK ! 大功告成,每天的0时就会自动完成日志的切割并存在相应的以网站日志文件命名的目录中。

三、展示
web1.log => web1/web1-20160322.log web1/web1-20160323.log
web2.log => web2/web2-20160322.log web2/web2-20160323.log

博客:http://www.webyang.net/Html/web/article_255.html

以上就介绍了Shell脚本分割Nginx日志,并定期清理,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。