如何使用 GitHub Actions 构建 Docker 镜像

本文将帮助您使用GitHub操作设置一个工作流,该工作流将构建和标记Docker镜像并将其推送到Docker Hub注册表。

创建 GitHub Repo

让我们从创建一个新的GitHub存储库开始,它将保存我们的代码(在我们的例子中,实际上只需要一个Dockerfile)来构建镜像。在GitHub中创建repo,并将其命名为您想要的任何名称。在repo的根目录中添加一个文件,名为Dockerfile。如果你沿着我,你将构建一个包含Angular CLI的镜像。如果你需要一个不同的镜像,那么修改以下内容以满足你的需求。Dockerfile的内容应该是:

# ./Dockerfile

FROM node:12-alpine as node-angular-cli

LABEL authors=\\\"Tinywan\\\"

# Linux setup
# I got this from another, deprecated Angular CLI image.
# I trust that developer, so I continued to use this, but you
# can leave it out if you want.
RUN apk update \\\\
  && apk add --update alpine-sdk \\\\
  && apk del alpine-sdk \\\\
  && rm -rf /tmp/* /var/cache/apk/* *.tar.gz ~/.npm \\\\
  && npm cache verify \\\\
  && sed -i -e \\\"s/bin\\\\/ash/bin\\\\/sh/\\\" /etc/passwd

# Angular CLI
RUN npm install -g @angular/cli@8

创建GitHub Action

因此,要开始使用GitHub操作,请在GitHub中的repo页面上单击Actions选项卡:

您现在应该看到一个类似于以下内容的页面:

如何使用 GitHub Actions 构建 Docker 镜像

这一步将我们登录到Docker Hub Registry。我们输出密码,然后将其传递给docker login命令。不过,这里有一些新的东西,那就是我们正在使用的秘密。GitHub在每个存储库的设置中有一个部分,您可以在其中设置用于GitHub操作等的秘密。

这很棒,因为否则就没有办法登录到第三方服务,如Docker Hub,而不把你的密码或访问密钥放在仓库中,每个人都可以看到。要找到secrets,请单击存储库顶部的设置,然后单击左侧导航列表中的Secrets,然后添加您需要的secrets,在本例中是我们的Docker Hub用户名和密码:

如何使用 GitHub Actions 构建 Docker 镜像

标签和发布

最后一步是在我们的GitHub存储库中标记一个版本。这将启动我们的工作流程的构建。要做到这一点,点击代码标签下的releases部分:

如何使用 GitHub Actions 构建 Docker 镜像

点击“Draft a new release”按钮。GitHub将引导您完成创建发布的步骤,但您应该选择标记名称和所需的发布提交。您还可以添加标题和说明。记住两件事:您在这里使用的标签名称将用作Docker镜像的标签名称,一旦您单击“发布版本”按钮,工作流将启动。一旦你准备好了,发布新版本!

查看工作流输出

要查看工作流中发生的情况,并在需要时进行调试,请返回到存储库中的Actions选项卡。一旦你创建了一个动作,该页面将看起来像这样:

除了在Actions选项卡中输出您的工作流之外,不要忘记转到Docker Hub并在那里查看您的图像!

原创文章,作者:网络技术联盟站,如若转载,请注明出处:https://www.sudun.com/ask/49844.html

Like (0)
网络技术联盟站的头像网络技术联盟站
Previous 2024年5月9日
Next 2024年5月9日

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注