gitlabrunner在末尾抛出“清理基于文件的变量00:01错误:作业失败:退出代码1”
即使我的所有步骤都成功通过,Gitlab CI 显示了这一点 - “清理基于文件的变量 00:01 错误:作业失败:退出代码 1”
并最终失败了。同样有趣的是,这只发生在我的主分支上。它在其他分支上成功运行。有没有人遇到过这个问题并找到了解决方案?
- >
for dir in $(git log -m -1 --name-only -r --pretty="format:" "$CI_COMMIT_SHA"); do
if [[ -f "$dir" ]]; then
SERVICE=$(echo "$dir")
# helm install the service
fi
done
- echo "deployed"
回答
概述
这让我发疯了,我仍然不确定合适的答案是什么。我自己刚刚遇到了这个问题,并在这个问题上投入了几个小时。我认为 GitLab 在命令替换方面搞砸了(昨天显示了一个新版本),尽管我可能对这个问题或其时间有误。它似乎也只发生在某些命令替换而不是其他命令替换中,我最初怀疑它可能与输出到 相关/dev/null,但不会深入研究。它总是在启动命令替换后立即失败。
我的代码
我有类似于你的代码(下面的简化版本),尝试以多种方式操作它,但每次使用命令替换都会产生相同的失败消息:
Cleaning up file based variables 00:01 ERROR: Job failed: exit code 1
我所做的尝试包括以下内容:
- folders=$(find .[^.]* * -type d -maxdepth 0 -exec echo {} ; 2>/dev/null)
- >
while read folder; do
echo "$folder"
done <<< "$folders"
和 ...
- >
while read folder; do
echo "$folder"
done <<< $(find .[^.]* * -type d -maxdepth 0 -exec echo {} ; 2>/dev/null)
这两个版本在我的本地机器上都成功了,但在 GitLab 中失败了(我上面可能有错别字 - 请不要仔细检查,它是我实际程序的简化版本)。
我是如何修复它的
$(...)我没有使用命令替换,而是选择了进程替换<(...),它似乎没有问题。
- >
while read folder; do
echo "$folder"
done < <(find .[^.]* * -type d -maxdepth 0 -exec echo {} ; 2>/dev/null)
如果可能,我会尝试在您的代码中替换相同的内容:
- >
while read dir; do
# the rest goes here
done < <(git log -m -1 --name-only -r --pretty="format:" "$CI_COMMIT_SHA")
问题也可能出在 if 语句(回声)中的那一行,您可以将其替换为以下内容:
read SERVICE < <(echo "$dir")
同样,不确定这会为您解决问题,因为我仍然不确定原因是什么,但它解决了我的问题。祝你好运。
- Thank you for avoiding me from "sunk hours into this issue" 🙂
THE END
二维码