您的位置:首页 > 运维架构 > Nginx

NGINX 日志文件切割及管理

2015-12-15 11:58 633 查看
NGINX或者其他容器都存在同样的问题,就是日志文件不会自动分隔和备份,需要个性化管理。毕竟有理由相信文件越大,读写越费劲。

代码如下,实现的功能就是通过bakuppath、logpath、days、pidpath四个变量来调整自己服务的路径,然后配置定时JOB,让系统每天凌晨备份日志文件,备份完之后压缩为以事件命名的tar文件中做归档。

#!/bin/sh
bakuppath="/home/ngi****logs/"
logpath="/home/wwwlogs/a****ss.log /home/wwwlogs/ng****rror.log"
days=30
pidpath="/usr/local/nginx/logs/nginx.pid"
nginxpath="/usr/local/nginx/sbin/"

mv ${logpath} -t ${bakuppath}
# kill -USR1 `cat ${pidpath}`  # need root
cd ${nginxpath}
nginxpid=`cat ${pidpath}`
ps -u www -f | grep ${nginxpid} | grep 'nginx' | awk '{print $2}' | xargs -i kill -USR1 {}
# -HUP or -USR1 signal are ok

cd ${bakuppath}

#tar -zcf nginxlog_$(date -d "yesterday" +"%Y%m%d").tar *

tar -zcf nginxlog_$(date -d "yesterday" +"%Y%m%d%H%M%S").tar *

find ${bakuppath} -name nginxlog_*.tar -type f -mtime +$days -exec rm {} \;

#添加脚本执行权限
# chmod +x logmanager.sh

# 添加任务计划,修改/etc/crontab
# vi /etc/crontab   #在最后一行添加
# 或者使用crontab -e命令,编辑当前用户下的定时任务
# 0 0 * * * /home/nginxlogs/logmanager.sh  #表示每天凌晨执行

# */5 * * * * /home/nginxlogs/logmanager.sh  #表示每天凌晨执行  测试使用


附:

定时任务的语法说明和日志

http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt145
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  nginx