问题现状
- 测试环境机器磁盘有限
- 保留的日志文件如果过多或者log4j中没有配置滚动删除,会出现磁盘不足,最终导致流水线发布失败
问题解决
1、通过流水线方式配置应用部署的机器ip执行shell命令动态删除日志文件,腾出磁盘空间
2、具体shell命令
#! /bin/bash
maxUsage=30
diskUsage=`df -h | grep -w '/app' | awk '{printf $5}' | sed 's#%##i'`
if [ $diskUsage -ge $maxUsage ]; then
echo "/app usage $diskUsage greater than max $maxUsage"
find /app/back-app*/log/bak/ -mtime +3 -type f -name "*" -exec rm -Rf {} \; >/dev/null 2>&1
fi
exit 0
备注:
1、find命令中,exec选项是相当的强大,例如:find /app/back-app*/log/bak/ f -name '*' -mtime +3 -exec rm -rf {} \;删除访问时间超过三天的日志
2、> /dev/null 2>&1语句解释:
>:输出重定向
覆盖写到文件的末尾
/dev/null :特殊文件
这是一个伪设备专用文件,俗称“黑洞”
2>&1:文件描述符
无论何时执行程序,操作系统总是打开三个文件STDIN,stdout和stderr,这些文件的文件描述符分别为0,1,2。
所以2>&1只是说将stderr重定向到stdout