相关技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > 相关技巧 > git流水线(Pipeline)导致分支(Branch)无法合并

git流水线(Pipeline)导致分支(Branch)无法合并问题及解决

作者:阿wei程序媛

这篇文章主要介绍了git流水线(Pipeline)导致分支(Branch)无法合并问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

最近我的分支往main分支合并代码的时候,一直提请我流水线成功的时候自动合并,由于我对gitlab的熟悉度不是很高,第一次看到这个流水线问题,所以就对此问题,找了解决方法

一、什么是 Pipeline 

Pipeline中文称为流水线,是分阶段执行的构建任务。

如:安装依赖、运行测试、打包、部署开发服务器、部署生产服务器等流程。

每一次 push 或者 Merge Request 都会触发生成一条新的 Pipeline。

二、GitLab 中有一个 CI/CD 功能 

GitLab CI/CD 是 GitLab Continuous Integration (Gitlab持续集成)的简称。

GitLab 自 GitLab 8.0 开始提供了持续集成的功能,且对所有项目默认开启。

只要在项目仓库的根目录添加 .gitlab-ci.yml 文件,并且配置了Runner(运行器),那么每一次 push 或者合并请求(Merge Request)都会触发 CI Pipeline

三、解决方法

在 Pipelines 没有运行成功之前是无法进行分支合并(Merge Request)的,我们可以对此进行解决,有以下几种解决办法。

1、跳过 Pipeline

只需要在 commit message 中带上 [ci skip] 或 [skip ci],这个 commit 就不会触发 pipeline。

推送命令:

git commit -m "xxxx[skip ci]"

或者

git commit -m "xxxx" -m "[skip ci]"

2、直接关闭流水线功能

方法一:打开项目设置——CI/CD ,链接:在项目后面加上 /settings/ci_cd

取消勾选 Auto DevOps下面的 默认为Auto DevOps流水线 

方法二:删掉项目下的 .gitlab-ci.yml 文件。

我就是用的方法二实现的,简单粗暴,我到现在都不知道,项目文件里为什么多一个.gitlab-ci.yml

问题是解决了,但是还是不了解内因,下一步目标就是搞透gitlab。。。。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文