linux 日志切割脚本,Nginx访问日志切割脚本

1、说明

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

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

37972a45dc98f549cf9f15661933a187.png

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

Nginx 的详细介绍:请点这里

Nginx 的下载地址:请点这里

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值