请教如何保护.gitlab-ci.yaml 不会被其他人修改和 cicd 流程安全

2022-08-31 11:47:39 +08:00
 zong400
比如其他人合并代码,能不能锁定这个文件,或者干脆隐藏
cicd 流程如果设置只能在 main 分支触发,分支保护设置只有 master 能 push 和 merge 是否足够防止误触发
1630 次点击
所在节点    GitLab
6 条回复
AoEiuV020CN
2022-08-31 12:31:48 +08:00
关键你“其他人”是谁,
pr 的话直接禁止 pr 触发 ci 或者需要手动允许才触发 ci 就可以,
其他项目参与人的话,我只知道 access token 可以不给 workflow 权限就无法修改 ci 配置,其他方法参与就没办法了,
zong400
2022-08-31 15:07:46 +08:00
其他人是指普通开发人员,我表述得不清楚
superwater
2022-09-01 14:29:10 +08:00
@AoEiuV020CN 楼主问的是 GitLab..

@zong400 这个文件可以指到其他仓库。。
zong400
2022-09-01 17:10:02 +08:00
@superwater 是指 include 其他仓库的 yaml ? 但是 gitlab-ci 本身还是能被修改吧?
superwater
2022-09-01 22:01:24 +08:00
可以把.gitlab-ci.yaml 放到其他指定的仓库里面,项目设置里面可以指定
yyttrr
2023-04-06 16:49:13 +08:00
抛弃业务代码仓库的,gitlab-ci.yml 文件,或者仅保留基本 check build 功能
自己写一个 http 服务接收业务代码仓库的 push 动作 webhook
不同仓库的构建流程在运维平台维护写到数据库里面,运维平台有单独的权限设置
触发了对应的打包在用 trigger 触发 build 仓库的 job ,把构建参数传进去,进行构建,build 仓库仅运维可见

这一套支撑百来个研发十几个技术栈几千个代码仓库还是没问题的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/876679

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX