Github操作在容器中运行步骤

时间:2020-08-18 16:31:28

标签: docker github-actions

当前,我正在尝试在我的Github Actions工作流程中实现一个容器。但是,我在弄清楚如何在容器本身中运行步骤时遇到了困难。

使用以下工作流程:

name: Laravel

on: pull_request

jobs:
  laravel-checks:
    runs-on: ubuntu-latest
    container: thomasowow/laravel-php:7.4

    steps:
    - uses: actions/checkout@v2

    - name: Yarn
      run: |
        yarn

此工作流程导致以下错误:

/__w/_temp/c399fe7d-6cd2-4cdc-bb06-acc829cddbb8.sh: 1: /__w/_temp/c399fe7d-6cd2-4cdc-bb06-acc829cddbb8.sh: yarn: not found
##[error]Process completed with exit code 127

找不到yarnthomasowow/laravel-php:7.4在本地运行,yarn可用。我已经用其他应该在docker映像中使用的东西进行了测试,但也没有找到它们。看来这些步骤未在容器中执行。

jobs.<job_id>.container语法的文档states the following

用于运行作业中尚未指定容器的任何步骤的容器

我知道有些解决方案无需使用容器即可工作,我更愿意使用它。

有人遇到相同的问题或知道我在做什么错吗?


解决方案

@DannyB指出我的图像包含以下入口点:

["/bin/bash", "--login", "-c", "tail -f /dev/null"]

这可能是Github无法在容器中正确运行内容的原因。

图像中需要它们来安装nvm,node和yarn

SHELL ["/bin/bash", "--login", "-c"]

RUN curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.3/install.sh | bash
RUN nvm install 12.18.3
RUN npm install -g yarn

CMD ["/bin/bash"]

SHELL移至RUN npm ...解决了该问题,Github再次能够正确运行容器中的内容。

当前,如果没有旧的解决方案,我仍然无法安装纱线,但是我认为还有其他方法可以做到这一点。有人建议如何以一种干净的方式做到这一点吗?


安装节点和纱线

我能够使用this answer安装nodeyarn

ENV NODE_VERSION=12.18.3
RUN curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.34.0/install.sh | bash
ENV NVM_DIR=/root/.nvm
RUN . "$NVM_DIR/nvm.sh" && nvm install ${NODE_VERSION}
RUN . "$NVM_DIR/nvm.sh" && nvm use v${NODE_VERSION}
RUN . "$NVM_DIR/nvm.sh" && nvm alias default v${NODE_VERSION}
ENV PATH="/root/.nvm/versions/node/v${NODE_VERSION}/bin/:${PATH}"
RUN npm install -g yarn

尝试从Office Node docker映像对COPY进行了一些尝试。使用此解决方案,我可以使node正常工作。 npmyarn也在运行,但有错误。

COPY --from=node:12.18.3 /usr/local/bin/node /usr/bin/node
...

1 个答案:

答案 0 :(得分:2)

问题似乎出在您的图像中,而不是您的GitHub Actions语法中。

似乎您的入口点是:

["/bin/bash", "--login", "-c", "tail -f /dev/null"]

这与GitHub Actions的需求不兼容-因为它根本无法使用该入口点进入您的容器。

您可能需要将入口点更改为其标准的/bin/sh/bin/bash入口点。确保您可以在本地猛扑它,然后再期望GitHub Actions可以对其进行处理。

$ docker run --rm -it thomasowow/laravel-php:7.4 bash

作为“容器沙箱”的概念证明,您可以尝试以下操作,并观察其效果是否如广告所示。

name: Experiment
on: [push]

jobs:
  debug:
    runs-on: ubuntu-latest
    container: { image: alpine }
    steps:  
    - run: uname -a
    - run: cat /etc/alpine-release
    - run: touch /hello
    - run: ls /

此外,您也许可以指示GitHub Action使用类似以下内容的其他入口点:

container: 
  image: thomasowow/laravel-php:7.4
  options: "--entrypoint /bin/bash"

但是,首先,您需要确保它在本地运行,例如:

$ docker run --rm -it --entrypoint='' thomasowow/laravel-php:7.4 yarn

有关安装纱线的更新

添加到答案,因为您已经添加了问题。 在大多数情况下,在docker映像中安装东西应该很简单,包括node和yarn之类的东西。

尽管我不是节点用户,但我怀疑问题出在您正在使用nvm上。用其他语言(python,ruby),这些“版本管理器”被设计为在交互式外壳中运行,了解用户的环境和启动脚本。在docker内部,您不需要任何版本管理器-因为您不需要多个版本。

寻找方法来安装依赖项“普通香草”,并避免在Dockerfiles中使用版本管理器,而且我确信您的问题会消失,或者减少到更简单的问题。