如果您厌倦了手动构建和发布应用程序,那么可能是时候设置 CI/CD 管道了。Github Actions 使大多数项目的这个过程变得简单和免费,并且可以通过自动化应用程序的构建过程来节省您的时间。
Github Actions 是在云中运行的任务。它们可以使用 YAML 配置文件进行设置,并根据您帐户中发生的事情触发。这通常类似于“将新提交推送到主分支”,但实际上可以为许多不同的事件设置操作,包括新问题或发生时,甚至按计划作为 cron 作业。
在这种情况下,我们想设置一个自动构建。每当对存储库进行更改时,通常都会运行此过程。您可以根据需要进行设置 - 通常在master orrelease 分支上运行它,但您也可以在 dev 和 feature 分支上运行构建。
大多数构建过程也将涉及测试,Github Actions 也可以这样做。这有助于捕获导致构建失败的提交。您可能也不想部署失败的构建,因此在所有情况下预先运行测试都是有益的。
使用 Github Actions,您还可以自动化部署的发布部分。如果您有一个总是从其更新release 的master 分支,则可以将该分支视为您的部署源。您的服务器将从 Github Action 的输出下载二进制文件并更新您的代码。如果您使用 NPM、Maven 或 Docker Hub 之类的包管理器或注册表,这将变得更加容易——更新可以直接推送到注册表并在需要时拉取。
Github Actions 使用基于 YAML 的配置系统。您需要定义两个基本的东西——动作何时触发,以及一旦触发将采取什么步骤。
您的确切配置将非常广泛地取决于您为应用程序使用的语言、框架和构建系统。不过,一般过程非常相似,对于此示例,我们将使用 Gradle 构建工具为基于 Java 的应用程序设置构建。
前往您的存储库并单击“操作”。Github 足够聪明,可以识别你的 repo 包含的应用程序类型,在这里它推荐了一些构建 Java 的不同操作。
单击“Java with Gradle”会打开 YAML 文件的 Github 编辑器,该编辑器预先配置了 Java 构建。这会在每次推送到 master 和每次 pull request 到 master 时运行。您也可以将其更改为在其他分支上运行,或者为开发/功能分支设置不同的操作。
您可以在此处编辑任何变量,完成后单击右侧的“提交”。如果您将构建设置为在推送时运行,则提交将触发构建。
您可以在“操作”选项卡下找到正在进行的工作流运行。
当然,这并不总是那么容易——在现实世界中,构建环境可能非常脆弱,并且可能由于多种原因而失败。Github 为这个存储库提供的示例操作并没有使其通过启动:它甚至无法找到gradlew 运行构建。
一个奇怪的错误考虑到应该可以开箱即用,但快速搜索问题表明我们应该使用正确的 gradle-build-action 手动配置版本和参数。
要编辑您的操作配置,请转到您的操作并单击.yml 工作流名称下的文件以调出编辑器。
然后,您可以根据需要对其进行修补,然后再次提交。提交更改build.yml 算作对 的提交master,因此它将再次触发操作。
这一次,它可以正常工作,但由于一个小错误而再次失败——这个存储库需要 Gradle 7.1,而不是 6.5。无论您使用什么构建管道,您都需要解决所有这些问题,以使其与您在机器上手动执行的构建完美匹配。
一旦所有这些都整理好,我们终于可以看到成功的绿色复选标记。
除了,它不是一个真正有用的构建——构建工件在哪里?默认情况下,此操作仅构建 repo,并且不提供任何输出项。
- name: capture build artifacts
uses: actions/upload-artifact@v2
with:
name: Artifacts
path: build/libs/
再次运行构建会正确上传工件。
如果您想让这些自动下载,您需要更改在 Github 上创建发布标签时运行的操作,然后使用您的令牌(作为环境变量传递)发布到 Github 包。
on:
release:
types: [created]
...
- name: Publish to GitHub Packages
uses: gradle/gradle-build-action@4137be6a8bf7d7133955359dbd952c0ca73b1021
with:
arguments: publish
env:
USERNAME: ${{ github.actor }}
TOKEN: ${{ secrets.GITHUB_TOKEN }}
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/wlcs_6305/article/details/122845402
内容来源于网络,如有侵权,请联系作者删除!