由于双十一来临,公司需要统计nginx资源的使用情况,给出了维护系统的nginx使用情况,发现我自己维护的2台nginx server存在硬盘使用过大的问题,由于nginx没做日志切割,所以一个文件的大小达到了21G。
采用了crontab来切割了nginx的日志。
在crontab中配置表达式以及脚本地址即可。把下面的脚本做成一个split_nginx_log.sh
放到sbin目录下
脚本如下,
#!/bin/bash
#
# 分割nginx日志文件
#
# 输入 crontab -e 命令,添加定时脚本:
# 0 0 * * * /usr/local/nginx/sbin/split_nginx_log.sh
#
# nginx日志文件目录
log_dir=/usr/local/webserver/nginx/logs/
# 昨天日期
yesterday=$(date -d "yesterday" +"%Y%m%d")
# nginx pid 文件路径
pid_path=/usr/local/webserver/nginx/nginx.pid
# 重命名日志文件
mv ${log_dir}access.log ${log_dir}access.${yesterday}.log
mv ${log_dir}error.log ${log_dir}error.${yesterday}.log
# 向Nginx主进程发送重新打开日志信号
kill -USR1 $(cat ${pid_path})
# 删除30天以上的日志文件
find ${log_dir} -name "*.log" -mtime +30 -exec rm -Rf {} \;