nginx日志切割

针对Linux 下 nginx日志全部写到一个文件中时,可以采用定时任务切割日志,这样很方便对日志管理,查看,储存

第一步、编写切割日志脚本(实质就是到固定时间的日志修改名字,并重新写nginx日志)

#!/bin/bash
#切割日志脚本,命名为 nginxLogSplit.sh. 

#nginx日志位置
LOGS_PATH=/var/log/nginx
#昨天格式化时间
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)

#把访问日志改名字昨天格式化时间
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
#把错误日志改名字昨天格式化时间
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log

## 向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件(重点),不然会继续写进之前改过的日志文件里
kill -USR1 $(cat /var/log/nginx/nginx.pid)

第二步、设置定时任务

使用 命令 crontab -e

写入 脚本:
#零点时候切割日志
0 0 * * * /bin/bash /var/log/nginx/nginxLogRotate.sh

脚本格式解释下:

.---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  *  command to be executed

(可以在 /var/spool/cron 目录下看到刚刚写进的定时任务)

这样就全部ok了,第一次弄建议先设置一个临近的时间测试一下

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值