nginx的日志如果不做切割的话,文件的内容会越来越多,体积会越来越大,不便于运维查看。所以我们可以通过把大的日志文件切割成多份不同的小文件作为日志,切割规则可以以天为单位,如果每天有几百甚至上千G,则可以按需以半天或者小时为单位进行切割。
手动切割
具体步骤如下:
1、创建一个shell可执行文件
vi /usr/local/nginx/sbin/cut_nginx_log.sh
cut_nginx_log.sh,内容为:
#!/bin/bash
# Description: rotate nginx access logs
#nginx pid 文件位置
NGX_PID=`cat /usr/local/nginx/logs/nginx.pid`
#记录格式
RECORD_TIME=$(date +%F -d 'yesterday')
#nginx日志路径
LOGS_DIR="/var/log/nginx"
#nginx日志文件名
ERROR_LOG_NAME="error.log"
ACCESS_LOG_NAME="access.log"
#nginx文件重命名
cd $LOGS_DIR
/usr/bin/mv $ERROR_LOG_NAME ${RECORD_TIME}_${ERROR_LOG_NAME}
/usr/bin/mv $ACCESS_LOG_NAME ${RECORD_TIME}_${ACCESS_LOG_NAME}
#向nginx主进程发送信号,用于重新打开文件
/bin/kill -USR1 $NGX_PID
2、赋予可执行权限:
chmod +x /usr/local/nginx/sbin/cut_nginx_log.sh
3、手动执行脚本即可:
/usr/local/nginx/sbin/cut_nginx_log.sh
定时切割
1.安装定时任务:
yum install -y crontabs
2.执行crontab -e
crontab -e
3.添加一条新的定时任务
#nginx日志切割每天0分0时切割一次
0 0 * * * /usr/local/nginx/sbin/cut_nginx_log.sh
4、重启定时任务
service crond restart
附常用定时任务命令:
service crond start //启动服务
service crond stop //关闭服务
service crond restart //重启服务
service crond reload //重新载入配置
crontab -e //编辑任务
crontab -1 //査看任务列表