当前位置:首页 > 技术 > 正文内容

nginx日志切割及历史日志删除脚本

醉清风2020-01-09技术1761

如果使用LNMP网站环境的话,默认nginx只会生成一个访问日志,并且是在每天的积累,日志文件会变的非常大,如果需要做一下日志的分析,无论是使用脚本分析,还是把日志下载本地分析,都不太方便。每天分割Nginx的访问日志,有利于分析日志。

脚本内容:

#!/bin/bash
#function:cut nginx log files shell
#设置您的网站访问日志保存的目录
log_files_path="/usr/local/nginx/logs/"
log_files_dir=${log_files_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")
#设置你想切割的nginx日志文件名称,比如设置的日志文件名是notenet.cn.log 的话,那这里直接填写 notenet.cn 即可
log_files_name=(access)
#设置nginx执行文件的路径。
nginx_sbin="/usr/local/nginx/sbin/nginx"
#设置你想保存的日志天数,我这里设置的是保存30天之前的日志
save_days=60
############################################
#Please do not modify the following script #
############################################
mkdir -p $log_files_dir
log_files_num=${#log_files_name[@]}
#cut nginx log files
for((i=0;i<$log_files_num;i++));do
mv ${log_files_path}${log_files_name[i]}.log ${log_files_dir}/${log_files_name[i]}_$(date -d "yesterday" +"%Y%m%d").log
done
#delete 60 days ago nginx log files
find $log_files_path -mtime +$save_days -exec rm -rf {} \;
$nginx_sbin -s reload


将这个脚本添加到计划任务,每天执行一次即可:

00 00 * * * /bin/cutlog.sh
扫描二维码至手机访问

扫描二维码推送至手机访问。

版权声明:本文由红柚酱发布,如需转载请注明出处。

转载请注明出处:https://www.notenet.cn/post/113.html

标签: nginxlinuxLNMP

相关文章

mysql中怎么重置清空id,id从1开始自动递增方法

mysql中怎么重置清空id,id从1开始自动递增方法

有时候我们在使用mysql的时候,设置了id自动递增,然后删除了一些数据,再次增数据的时候,id就出现累计的情况,怎么重置清空id呢,下面来分享一下方法重置清空id,id从1开始自动递增方法使用mys...

nginx如何根据http_referer实现跳转或屏蔽?

nginx如何根据http_referer实现跳转或屏蔽?

1、根据特定的 http_referer 实现跳转在配置文件的 server {} 中加入如下配置:if ($http_referer ~* “www.baidu.com...

【漏洞预警】VMware vCenter任意文件读取漏洞

【漏洞预警】VMware vCenter任意文件读取漏洞

2020年10月14日,阿里云应急响应中心监测到VMware vCenter特定版本存在任意文件读取漏洞,攻击者通过构造特定的请求,可以读取服务器上任意文件。漏洞描述VMware vCenter 服务...

 EOS 在 Ubuntu 18.04.1 LTS 环境上的安装

EOS 在 Ubuntu 18.04.1 LTS 环境上的安装

 EOS 在 Ubuntu 18.04.1 LTS 环境上的安装测试教程环境:Ubuntu 18.04.1 LTS1,github库下载源码。(新旧版本无变化)$ git ...

Mysqldump参数大全

Mysqldump参数大全

参数说明–all-databases , -A导出全部数据库。mysqldump -uroot -p –all-databases–all-tablespaces , -Y导出全部表空间。mysqld...