den*_*dog 22 continuous-integration github continuous-deployment google-cloud-build github-actions
我有大约 10 个单独的微服务,它们主要是用于各种数据处理作业的云功能,它们都位于一个 github 存储库中。
目标是在推送到分支时触发将这些服务有选择地部署到 Google Cloud Functions - 当单个功能已更新时。
我必须避免单个服务更新导致部署所有云功能的情况。
我当前的存储库结构:
/repo
--/service_A
----/function
----/notebook
--/service_B
----/function
----/notebook
Run Code Online (Sandbox Code Playgroud)
附带说明一下,使用 Github Actions VS Google Cloud Build 进行此类自动化的优缺点是什么?
pet*_*ans 39
GitHub Actions 支持对工作流进行路径过滤的 monorepos。您可以创建工作流以在特定路径上的文件更改时有选择地触发。
https://help.github.com/en/articles/workflow-syntax-for-github-actions#onpushpull_requestpaths
例如,当路径下的任何文件service_A/发生更改时,此工作流将在推送时触发(注意**glob 匹配嵌套目录中的文件)。
on:
push:
paths:
- 'service_A/**'
Run Code Online (Sandbox Code Playgroud)
小智 5
您还可以运行一些脚本来发现哪些服务被更改,git diff并通过GitHub REST API触发相应的作业。
可能有两个工作流main.yml和services.yml.
主工作流将被配置为始终在推送时启动,它只会启动脚本来找出哪些服务已更改。对于每个更改的服务存储库调度事件,将使用有效负载中的服务名称触发。
服务工作流将配置为在repository_dispatch上启动,并且将为每个服务包含一个作业。作业将具有基于事件负载的附加条件。
查看具有类似设置的展示:https : //github.com/zladovan/monorepo
如果您只有应用程序,那么我很抱歉...但您拥有的只是许多应用程序的存储库。
monorepo 是一个包的集合,您可以在它们之间映射依赖关系图。
但是,如果您有一组相互依赖的包,那么请继续阅读。
apps/
one/
depends:
pkg/foo
two/
depends:
pkg/bar
pkg/foo
pkg/
foo/
bar/
baz/
Run Code Online (Sandbox Code Playgroud)
答案是,您切换到一个可以描述当前 git ref 和其他 git ref 之间哪些包发生了更改的工具。
以下两个示例release在每个更改的包apps/* 及其依赖的所有包上运行 npm 脚本。
我不确定 pnpm 方法是否会默默地跳过没有release目标/命令/脚本的包。
使用 NX.dev,它会用它的命令为你解决这个问题nx affected。
nx.json在你的 monorepo 的根目录中project.json每个包中都有,那么它们target将驻留在其中。pnpx nx affected --target=release
Run Code Online (Sandbox Code Playgroud)
您的另一个选择是切换到 pnpm 并使用其过滤语法:
pnpm --filter "...{apps/**}[origin/master]" release
Run Code Online (Sandbox Code Playgroud)
如果您只是尝试并依赖在此 git 提交中更改的“哪些路径”,那么您会错过影响您实际想要部署的包的瞬态更改。
如果你有一个 github 操作,例如:
on:
push:
paths:
- 'app/**'
Run Code Online (Sandbox Code Playgroud)
那么当您只推送改变pkg/**.
| 归档时间: |
|
| 查看次数: |
7653 次 |
| 最近记录: |