Files
2025-09-03 21:00:35 +00:00

6.2 KiB
Raw Permalink Blame History

date, slug, sidebar_position
date slug sidebar_position
2023-05-24T15:00:00+08:00 design 40

Gitea Actions设计

Gitea Actions由多个组件组成。本文檔将对它们進行逐个描述。

Act

nektos/act 项目是一个优秀的工具允许你在本地运行GitHub Actions。 我们受到了它的启发並思考它是否可能為Gitea运行Actions。

然而,尽管nektos/act被设计為一个命令行工具但我们实际上需要的是一个专為Gitea修改的Go库。 因此,我们在gitea/act基础上進行了分叉。

这是一个软分叉,将定期跟進上游。 虽然添加了一些自定义提交,但我们会尽力避免对原始代码進行太多更改。

分叉的 act 只是Gitea特定用途的桥接或适配器。 還添加了一些额外的提交,例如:

  • 将執行日志输出到日志记录器钩子以便报告给Gitea
  • 禁用 GraphQL URL因為Gitea不支持它
  • 每个Job启动一个新的容器而不是重复使用以确保隔离性。

这些修改没有理由合並到上游。 如果使用者只想在本地运行可信的Actions它们是没有意义的。

然而,将来可能会出現重叠,例如两个项目都需要的必要错误修复或新功能。 在这些情况下,我们将向上游存放庫贡献变更。

act runner

Gitea的Runner被稱為act runner因為它基于act。

与其他CIRunner一样我们将其设计為Gitea的外部部分这意味着它應該在与Gitea不同的服务器上运行。

為了确保Runner连接到正确的Gitea实例我们需要使用令牌注册它。 此外Runner通過声明自己的標籤向Gitea报告它可以运行的Job類型。

之前,我们提到工作流文件中的 runs-on: ubuntu-latest 表示該Job将在具有ubuntu-latest標籤的Runner上运行。 但是Runner如何知道要运行 ubuntu-latest?答案在于将標籤映射到环境。 这就是為什么在注册過程中添加自定义標籤时,需要输入一些复杂内容,比如my_custom_label:docker://centos:7。 这意味着Runner可以接受需要在my_custom_label上运行的Job並通過使用centos:7镜像的Docker容器来运行它。

然而Docker不是唯一的選择。 act 也支持直接在主机上运行Job。 这是通過像linux_arm:host这样的標籤实現的。 这个標籤表示Runner可以接受需要在linux_arm上运行的Job並直接在主机上运行它们。

標籤的设计遵循格式label[:schema[:args]]。 如果省略了schema则默认為host

因此,

  • my_custom_label:docker://node:18:使用node:18 Docker镜像运行带有my_custom_label標籤的Job。
  • my_custom_label:host:在主机上直接运行带有my_custom_label標籤的Job。
  • my_custom_label:等同于my_custom_label:host
  • my_custom_label:vm:ubuntu-latest:(僅為示例,未实現)使用带有ubuntu-latest ISO的虚拟机运行带有my_custom_label標籤的Job。

通信协议

由于act runner是Gitea的独立部分我们需要一种协议让Runner与Gitea实例進行通信。 然而我们不认為让Gitea监听一个新端口是个好主意。 相反我们希望重用HTTP端口这意味着我们需要一个与HTTP兼容的协议。 因此我们選择使用基于HTTP的gRPC。

我们使用actions-proto-defactions-proto-go 進行连接。 有关 gRPC 的更多信息,請访问其官方网站

网络架构

让我们来看一下整體的网络架构。 这将帮助您解决一些问题並解释為什么使用回环地址注册Runner是个不好的主意。

network

图片中标记了四个网络连接,並且箭头的方向表示建立连接的方向。

连接 1act runner到Gitea实例

act runner 必須能够连接到Gitea以接收任务並发送執行结果回来。

连接 2Job容器到Gitea实例

即使Job容器位于同一台机器上它们的网络命名空间与Runner不同。 举个例子,如果工作流中包含 actions/checkout@v4Job容器需要连接到Gitea来获取代码。 获取代码並不总是运行某些Job所必需的但在大多数情况下是必需的。

如果您使用回环地址注册Runner当Runner与Gitea在同一台机器上时Runner可以连接到Gitea。 然而如果Job容器尝试从本地主机获取代码它将失败因為Gitea不在同一个容器中。

连接 3act runner到互联网

当您使用诸如 actions/checkout@v4 的一些Actions时act runner下载的是脚本而不是Job容器。 默认情况下,它从github.com下载,因此需要访问互联网。如果您设置的是 self 那么默认将从您的当前Gitea实例下载那么此步骤不需要连接到互联网。 它還默认从Docker Hub下载一些Docker镜像这也需要互联网访问。

然而,互联网访问並不是绝对必需的。 您可以配置您的Gitea实例从您的内部网络设施中获取 Actions 或镜像。

实际上您的Gitea实例可以同时充当 Actions 市场和镜像註冊表。 您可以将GitHub上的Actions存放庫镜像到您的Gitea实例並将其用作普通Actions。 而 Gitea 容器註冊表 可用作Docker镜像註冊表。

连接 4Job容器到互联网

当使用诸如actions/setup-go@v5的Actions时可能需要从互联网下载资源以设置Job容器中的Go语言环境。 因此成功完成这些Actions需要访问互联网。

然而,这也是可選的。 您可以使用自定义的Actions来避免依赖互联网访问或者可以使用已安裝所有依赖项的打包的Docker镜像来运行Job。

总结

使用Gitea Actions只需要确保Runner能够连接到Gitea实例。 互联网访问是可選的,但如果没有互联网访问,将需要额外的工作。 换句话说当Runner能够自行查询互联网时它的工作效果最好但您不需要将其暴露给互联网無论是單向還是双向

如果您在使用Gitea Actions时遇到任何网络问题希望上面的图片能够帮助您進行故障排除。