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