nginx定时任务切割日志

Nginx定时日志切割


现有的日志都会存在access.log文件中,但是随着时间的推移,这个文件的内容会越来越多,体积会越来越大,不便于运维 人员查看,所以我们可以通过把这个大的日志文件切割为多份不 同的小文件作为日志,切割规则可以以天为单位,如果每天有几 百G或者几个T的日志的话,则可以按需以每半天或者每小时对曰志切割一下。


具体步骤如下:

1.创建一shell可执行文件:cut_my_log.sh,内容为:

#!/bin/bash
LOG_PATH="/var/log/nginx/"
RECORD_TIME=$(date -d "yesterday" +%Y-%m-%d+%H:%M)
PID=/va r/run/nginx/nginx.pid
mv ${LOG_PATH}/access.log ${LOG_PATH}/access.${RECORD_TIME}.log
mv ${LOG_PATH}/error.log ${LOG_PATH}/error.${RECORD_TIME}.log 
#进程发送信号,用于重开打开日志文件
kill -USR1 'cat $PID'
  1. 为cut_my_log.sh添加可执行的权限:
chmod +x cut_my_log.sh
  1. 测试日志切割后的结果:
./cut_my_log.sh

4.安装定时任务

yum install crontabs

5.crontab -e编辑并且添加一行新的任务
(定时任务使用cron表达式)

*/1 * * * * /usr/local/nginx/sbin/cut_my_log.sh

6.重启定时任务:

service crond restart 
  • 常用定时任务命令:
命令 说明
service crond start 启动服务
service crond stop 关闭服务
service crond restart 重启服务
service crond reload 重新载入配置
crontab -e 编辑任务
crontab -1 查看任务列表
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容