**注:**nginx访问日志在文件access.log里面,错误日志在error.log里面,不会自动分文件夹,某些nginx访问量大,为防止硬盘因nginx的访问日志爆满,故将nginx日志分日期存储,并只保留一定天数的日志文件。具体脚本如下:
1、docker安装的nginx
[root@server mysh]# cat nginx_logs.sh
#!/bin/bash
#日志存储路径
log_path="/usr/app/docker/nginx/logs"
#取出昨天的时间
log_date=$(date -d yesterday +%Y-%m-%d)
#将访问日志重命名,标志为昨天的日期
mv ${log_path}/access.log ${log_path}/access_${log_date}.log
#将错误日志重命名,标志为昨天的日期
mv ${log_path}/error.log ${log_path}/error_${log_date}.log
#/usr/app/nginx/sbin/nginx -s reopen
#重启nginx服务,生成新的日志文件,docker安装的nginx 直接用-s reopen可能不生效,所以直接重启服务,由于需要重启,所以定时任务一般在凌晨执行
docker restart nginx
#只保留最近7天的日志文件,减少硬盘压力
find ${log_path} -type f -name "*.log" -ctime +7 -exec rm -f {} \;
2、编译安装的nginx
[root@server mysh]# cat nginx_logs.sh
#!/bin/bash
#日志存储路径
log_path="/usr/app/nginx/logs"
#取出昨天的时间
log_date=$(date -d yesterday +%Y-%m-%d)
#将访问日志重命名,标志为昨天的日期
mv ${log_path}/access.log ${log_path}/access_${log_date}.log
#将错误日志重命名,标志为昨天的日期
mv ${log_path}/error.log ${log_path}/error_${log_date}.log
#和docker安装的nginx只有此步操作不同,nginx只带重新打开日志文件的参数,这样可以做到平滑的操作,不会影响nginx的正常运行
/usr/app/nginx/sbin/nginx -s reopen
#只保留最近7天的日志文件,减少硬盘压力
find ${log_path} -type f -name "*.log" -ctime +7 -exec rm -f {} \;
3、设置定时任务,每天定时执行任务,重命名日志且删除旧的日志。
0 0 * * * /usr/app/mysh/nginx_logs.sh # 每天00:00定时执行任务