`
ihuangweiwei
  • 浏览: 265350 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Nginx日志切割脚本

阅读更多

1.完整脚本

 

hww@tts-0001:~$ mkdir -p bin/
hww@tts-0001:~$ cd bin/
hww@tts-0001:~/bin$ sudo vim cut_nginx.sh

 

    脚本:

#!/bin/sh 

mv /data/logs/nginx/hww_log.log /data/logs/nginx/hww_log_$(date -d "0 day" +"%Y%m%d").log
mv /data/logs/nginx/hww_error.log /data/logs/nginx/hww_error_$(date -d "0 day" +"%Y%m%d").log 

kill -USR1 $(cat /var/run/nginx.pid) 

bzip2 -z /data/logs/nginx/hww_log_$(date -d "0 day" +"%Y%m%d").log
bzip2 -z /data/logs/nginx/hww_error_$(date -d "0 day" +"%Y%m%d").log 

rm -f /data/logs/nginx/hww_log_$(date -d "-30 day" +"%Y%m%d").log.bz2
rm -f /data/logs/nginx/hww_error_$(date -d "-30 day" +"%Y%m%d").log.bz2 

exit 0 
 

 

2.简化脚本

#!/bin/sh

hww_log=/data/logs/nginx/hww_log.log
hww_error=/data/logs/nginx/hww_error.log

dd_0=$(date -d "0 day" +"%Y-%m-%d")
dd_30=$(date -d "-30 day" +"%Y-%m-%d")

mv $hww_log $hww_log.$dd_0
mv $hww_error $hww_error.$dd_0

kill -USR1 $(cat /var/run/nginx.pid)

bzip2 -z $hww_log.$dd_0
bzip2 -z $hww_error.$dd_0

rm -f $hww_log.$dd_30.bz2
rm -f $hww_error.$dd_30.bz2

exit 0

 

该脚本把错误日志也打包了,同时自动删除30天前的打包日志

 

别忘了赋权限  

sudo chmod 755 cut_nginx.sh
 

 

3.定时执行命令

crontab命令

crontab命令的功能是在一定的时间间隔调度一些命令的执行 

crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数 
crontab -l //列出某个用户cron服务的详细内容 
crontab -r //删除某个用户的cron服务 
crontab -e //编辑某个用户的cron服务 

 定时执行

hww@tts-0001:~/bin$ sudo crontab -e


# 
# For more information see the manual pages of crontab(5) and cron(8)
# 
# m h  dom mon dow   command
0 0 * * * /home/hww/bin/cut_nginx.sh 








 

 

 

注:1.分 时 日 月 周 sh脚本路径
   2.上面的含义是每天晚上0点执行cut_nginx.sh脚本 
 

 

 

分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

Global site tag (gtag.js) - Google Analytics