这两天项目遇到一个问题,进程产生的log没有回滚机制,导致长时间运行后,存储被占满了,但是linux自带的回滚机制被裁减掉了,所以自己写了个脚本来控制进程的日志回滚
#!/bin/dash
MAXLOGSIZE="10"
LOGPATH=/tmp/log/ru_agent.log
LOGNAME=ru_app.log
while :
do
LOGSIZE=$(du -a $LOGPATH | awk '{print $1}')
echo $MAXLOGSIZE
echo $LOGSIZE
if [ $LOGSIZE -gt $MAXLOGSIZE ];then
echo "ok"
echo " " > $LOGPATH
cat /dev/null > $LOGPATH
> $LOGPATH
else
echo "no ok"
fi
sleep 59
done
这里有一点需要注意,就是进程在重定向log到文件里的时候,要用追加的方式重定向,不然,执行了这个脚本之后,清除一次,log将不会再打印到重定向的文件里
追加方式即 >> 比如:
echo aaa >> 1.txt
将 aaa 追加到 1.txt中