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" 🙂

以上是gitlabrunner在末尾抛出“清理基于文件的变量00:01错误:作业失败:退出代码1”的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>