首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如果仅当对主分支进行推送或合并时才触发作业,则组合gitlab配置项规则

如果仅当对主分支进行推送或合并时才触发作业,可以通过GitLab的配置项规则来实现。

首先,在项目的根目录下创建一个名为.gitlab-ci.yml的文件,该文件是GitLab CI/CD的配置文件。

然后,在该文件中添加一个rules部分,用于定义作业的触发规则。在rules中,可以使用changes关键字指定对哪些文件的更改会触发作业。为了只在对主分支进行推送或合并时触发作业,可以使用以下配置:

代码语言:txt
复制
rules:
  - changes:
      - master

上述配置表示只有当对master分支进行推送或合并时,才会触发该作业。

接下来,你可以根据具体需求添加其他配置项,如作业的脚本、环境变量等。

以下是一个完整的示例配置文件:

代码语言:txt
复制
# .gitlab-ci.yml

# 触发规则
rules:
  - changes:
      - master

# 作业定义
job1:
  script:
    - echo "This job is triggered only when pushing or merging to the master branch"

以上配置文件中,定义了一个名为job1的作业,在该作业的脚本中输出一条信息。该作业只有当对主分支进行推送或合并时才会触发。

注意:以上配置只是示例,实际的作业定义和脚本可以根据实际情况进行修改。

腾讯云相关产品和产品介绍链接地址请自行搜索腾讯云的官方文档进行查找。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

GitLab CI CD管道配置参考 .gitlab-ci.yml文件定义字段

匹配后,根据配置作业包括在管道中从管道中排除。如果包含,作业还会 添加某些属性。 注意: rules 不能与之组合使用, only/except 因为它是该功能的替代品。...如果找到匹配检查属性以查看是否应将作业添加到管道。...允许合并请求管道,允许分支管道,可以消除重复的管道。或者,您可以使用避免最终重写规则更严格,when(always,on_successdelayed)。...同样,如果没有Git推送事件,始终返回true。它应用于分支管道合并请求管道。...规则级rules:allow_failure选项将覆盖作业级 allow_failure选项,并且仅在作业由特定规则触发应用。

22.2K20

GitLab 做 CICD 是什么感觉,太强了

,然后再将其合并分支中。...应用程序不仅会在推送到代码库的每次代码更改时进行构建和测试,而且,尽管部署是手动触发的,但作为一个附加步骤,它也可以连续部署。...在这个文件中,你可以定义要运行的脚本,定义包含的依赖,选择要按顺序运行的命令和要并行运行的命令,定义要在何处部署应用程序,以及指定是否 要自动运行脚本手动触发脚本。...二者共同构成了在每次推送到仓库的任何分支都会被触发的 Pipeline(管道)。...Review 并获得批准 合并 feature 分支到默认分支,同时自动将此次更改部署到生产环境 如果出现问题,可以轻松回滚 通过 GitLab UI 所有的步骤都是可视化的 。

2.5K40
  • 从GitLabCE CICD方法论中探索实践

    在此文件中,您可以定义要运行的脚本,定义包含和缓存依赖,选择要按顺序运行的命令和要并行运行的命令,定义要在哪里部署应用程序,以及指定是否将要自动运行脚本手动触发任何脚本。...它们都组成了在每次推送到存储库的任何分支触发的管道。 GitLab CI / CD不仅执行您已设置的作业,而且还向您显示执行期间发生的情况,就像您在终端中看到的那样: ?...将提交推送GitLab中的远程存储库中的功能分支后,将触发为项目设置的CI / CD管道。这样,GitLab CI / CD: 将自动化脚本(顺序并行)运行到: 构建并测试您的应用。...实施感到满意后: 让您的代码得到审查和批准。 将功能分支合并到默认分支GitLab CI / CD将您的更改自动部署到生产环境。 最后,如果出现问题,您和您的团队可以轻松地将其回滚。 ?...,将这个构建、部署、测试没有问题的功能分支合并分支上,然后继续服务的持续交付环节。

    2.1K31

    持续集成gitlab-ci.yml配置文档基础

    举个例子,命令中包含冒号( : ),script需要被包 在双引号中,这样YAML解析器可以正确解析为一个字符串而不是一个键值(key:value)。...点击管道将显示为该管道运行的作业。 查看工作状态: 您访问单个管道,您可以看到该管道的相关作业。点击单个作业会显示该作业运行历史,并允许您取消作业,重试作业清除作业运行日志。...出于这个原因,类似的工作可以自动组合在一起。如果作业名称以某种格式命名,它们将在常规管线图(非迷你图)中折叠为一个组。如果您没有看到重试取消按钮,您就知道管道将作业已经合并分组了。...受保护分行的安全:管道在受保护的分支上执行时,将执行严格的安全模型,只有在允许用户合并推送 特定分支允许在受保护的分支上执行以下操作 : 运行手动管道(使用Web UIPipelines API...) 运行预定的管道 使用触发器运行管道 在现有管线上触发手动操作 重试/取消现有作业(使用Web UIPipelines API) 标记为受保护的变量适用于在受保护分支上运行的作业,从而避免不受信任的用户无意中访问敏感信息

    15K30

    GitLabCICD自动集成和部署到远程服务器

    持续集成的工作原理是:将小的代码块-commits-推送到Git存储库中托管的应用程序的代码库中,并且每次推送,都要运行脚本管道来构建,测试和验证代码更改,然后再将其合并分支中。...持续交付和部署包括进一步的CI,可在每次推送到存储库默认分支将应用程序部署到生产环境。...您可以使用only指令使deploy_a部署到登台服务器,将deploy_b部署到生产服务器,当在only指令下将提交推送分支,将触发作业 deploy-production: stage: deploy...添加部署密钥 部署密钥允许服务器上克隆的存储库进行只读读写(如果启用)访问。...如果您在运行程序注册YAML配置中未使用alpine,必须根据自己的Linux系统更改命令。 ?

    6.3K30

    软件开发中常说的CICD是什么

    如果上一步脚本命令返回 0 代码,构建成功。否则视为失败。 CI 服务器将带有构建结果的请求发送到 Git 服务器。 如果构建成功,允许合并 Pull 请求。否则合并将被阻止。...任何时刻 master 分支的测试覆盖率都不应低于 50%。Jacoco 插件可以轻松解决这个问题。如果测试覆盖率值小于可接受的值,我们只需在构建返回失败进行配置即可。...例如 CD 服务器可以通知订阅者部署成功失败。 有一个重要的问题。我们什么时候应该运行 CD 作业触发因素可能会有所不同。 每次合并请求后进行部署。 按计划部署。...在每个拉取请求合并到特定分支进行部署。 将以上选项进行组合。 第一点设置流程,以便 CI 和 CD 作业始终按顺序运行。这种方法在开源项目开发中相当流行。...如果我们只需要部署 master 分支,则不需要在合并到 develop 分支触发 CD 作业。 最后一点是所有方法的汇总。例如开发分支可能会根据计划部署到开发环境。

    24920

    Gitlab CI 搭建持续集成环境

    在软件工程里,持续集成(Continuous Integration, CI)是指这样的一种实践:在一天里多次将所有开发人员的代码合并到一个共享的主干里,每次合并都会触发持续集成服务器进行自动构建,这个过程包括了编译...在此文件中,您可以定义要运行的脚本,定义包含和缓存依赖,选择要按顺序运行的命令和要并行运行的命令,定义要在哪里部署应用程序,以及指定是否将要自动运行脚本手动触发任何脚本。....post 始终是管道的最后阶段 only 定义将为其运行作业分支和标签的名称 except 定义将不运行作业分支和标签的名称 tags 管道的Git引用是标签 script 执行shell命令或者脚本...when 用于实现在发生故障发生故障时运行的作业 when 可以设置为以下值之一: 值 描述 on_success 当先前阶段中的所有作业都成功执行作业。...这是默认值 on_failure 至少一个先前阶段的作业失败执行作业 always 执行作业,而不管先前阶段的作业状态如何 manual 手动执行作业(在GitLab 8.10中已添加) 参考文献

    2.6K21

    GitLab 做 CICD 是什么感觉,太强了!!

    Git仓库中托管的应用程序代码库中,并且每次推送,都要运行一系列脚本来构建、测试和验证代码更改,然后再将其合并分支中。...应用程序不仅会在推送到代码库的每次代码更改时进行构建和测试,而且,尽管部署是手动触发的,但作为一个附加步骤,它也可以连续部署。...在这个文件中,你可以定义要运行的脚本,定义包含的依赖,选择要按顺序运行的命令和要并行运行的命令,定义要在何处部署应用程序,以及指定是否 要自动运行脚本手动触发脚本。...二者共同构成了在每次推送到仓库的任何分支都会被触发的pipeline(管道)。 GitLab CI/CD不仅可以执行你设置的job,还可以显示执行期间发生的情况,正如你在终端看到的那样: ?...并获得批准 合并feature分支到默认分支,同时自动将此次更改部署到生产环境 如果出现问题,可以轻松回滚 通过GitLab UI所有的步骤都是可视化的: ?

    9.6K43

    软件开发中常说的CICD是什么

    如果上一步脚本命令返回 0 代码,构建成功。否则视为失败。 CI 服务器将带有构建结果的请求发送到 Git 服务器。 如果构建成功,允许合并 Pull 请求。否则合并将被阻止。...任何时刻 master 分支的测试覆盖率都不应低于 50%。Jacoco 插件可以轻松解决这个问题。如果测试覆盖率值小于可接受的值,我们只需在构建返回失败进行配置即可。...例如 CD 服务器可以通知订阅者部署成功失败。 有一个重要的问题。我们什么时候应该运行 CD 作业触发因素可能会有所不同。 每次合并请求后进行部署。 按计划部署。...在每个拉取请求合并到特定分支进行部署。 将以上选项进行组合。 第一点设置流程,以便 CI 和 CD 作业始终按顺序运行。这种方法在开源项目开发中相当流行。...如果我们只需要部署 master 分支,则不需要在合并到 develop 分支触发 CD 作业。 最后一点是所有方法的汇总。例如开发分支可能会根据计划部署到开发环境。

    29520

    持续集成gitlab-ci.yml配置文档基础

    举个例子,命令中包含冒号( : ),script需要被包 在双引号中,这样YAML解析器可以正确解析为一个字符串而不是一个键值(key:value)。...点击管道将显示为该管道运行的作业。 查看工作状态: 您访问单个管道,您可以看到该管道的相关作业。点击单个作业会显示该作业运行历史,并允许您取消作业,重试作业清除作业运行日志。...出于这个原因,类似的工作可以自动组合在一起。如果作业名称以某种格式命名,它们将在常规管线图(非迷你图)中折叠为一个组。如果您没有看到重试取消按钮,您就知道管道将作业已经合并分组了。...受保护分行的安全:管道在受保护的分支上执行时,将执行严格的安全模型,只有在允许用户合并推送 特定分支允许在受保护的分支上执行以下操作 : 运行手动管道(使用Web UIPipelines API...) 运行预定的管道 使用触发器运行管道 在现有管线上触发手动操作 重试/取消现有作业(使用Web UIPipelines API) 标记为受保护的变量适用于在受保护分支上运行的作业,从而避免不受信任的用户无意中访问敏感信息

    12K20

    软件开发常说的CICD是什么

    如果上一步脚本命令返回 0 代码,构建成功。否则视为失败。 CI 服务器将带有构建结果的请求发送到 Git 服务器。 如果构建成功,允许合并 Pull 请求。否则合并将被阻止。...任何时刻 master 分支的测试覆盖率都不应低于 50%。 Jacoco 插件可以轻松解决这个问题。如果测试覆盖率值小于可接受的值,我们只需在构建返回失败进行配置即可。...例如 CD 服务器可以通知订阅者部署成功失败。 有一个重要的问题。我们什么时候应该运行 CD 作业触发因素可能会有所不同。 每次合并请求后进行部署。 按计划部署。...在每个拉取请求合并到特定分支进行部署。 将以上选项进行组合。 第一点设置流程,以便 CI 和 CD 作业始终按顺序运行。这种方法在开源项目开发中相当流行。...如果我们只需要部署 master 分支,则不需要在合并到 develop 分支触发 CD 作业。 最后一点是所有方法的汇总。例如开发分支可能会根据计划部署到开发环境。

    27930

    GitLab 内置了一个强大的 CICD 系统

    ,然后再将其合并分支中。...GitLab CI/CD 由一个名为 .gitlab-ci.yml 的文件进行配置,改文件位于仓库的根目录下。文件中指定的脚本由GitLab Runner执行。 1....在这个文件中,你可以定义要运行的脚本,定义包含的依赖,选择要按顺序运行的命令和要并行运行的命令,定义要在何处部署应用程序,以及指定是否 要自动运行脚本手动触发脚本。...二者共同构成了在每次推送到仓库的任何分支都会被触发的pipeline(管道)。...并获得批准 合并feature分支到默认分支,同时自动将此次更改部署到生产环境 如果出现问题,可以轻松回滚 通过GitLab UI所有的步骤都是可视化的: image.png

    1.1K20

    GitLabCICD实践简介

    ---- 差异点对比 分支的可配置性 使用GitLab CI,新创建的分支无需任何进一步配置即可立即使用CI管道中的已定义作业。 Jenkins 2 基于gitlab的多分支流水线可以实现。...相对配置来说gitlab更加方便一些。 定时执行构建 有时,根据时间触发作业整个管道会有所帮助。例如,常规的夜间定时构建。 使用Jenkins 2可以立即使用。...可以在应执行作业管道的那一刻以cron式语法定义。 GitLab CI没有此功能。但是,可以通过一种变通办法来实现:通过WebAPI使用同一台另一台服务器上的cronjob触发作业和管道。...拉取请求支持 如果很好地集成了存储库管理器和CI / CD平台,您可以看到请求的当前构建状态。使用这种功能,可以避免将代码合并到不起作用无法正确构建的分支中。...Jenkins 2与存储库管理器都是松散耦合的,因此在选择版本控制系统它非常灵活。此外,就像其前身一样,Jenkins 2强调了插件的支持,以进一步扩展改善软件的现有功能。

    4.6K10

    介绍新的 GitLab 分支源插件

    GitLab 组项目项目进行扫描, 根据设置的规则导入流水线任务。...索引完成后,导入的项目将所有分支合并请求和标签列示为任务。 ? 查看每个任务,您会发现左侧有一些操作: 您可以通过选择 立即构建 手动触发任务。...GitLab Api 不支持创建组 web hook,所以这个插件不支持只有 GitLab EE 支持的特性。 现在可以查看导入的项目,如果需要,可以在每个文件夹上配置不同的设置。 ?...GitLab 上 web hook 在以下事件上被触发: Push Event - 提交分支推送 Tag Event - 新标签被创建 Merge Request Event - 合并请求被创建.../更新 Note Event - 合并请求进行评论 如果令牌具有管理访问权限,还可以在 GitLab 服务器上设置系统 Hook。

    2.3K10

    GitLabCI系列之流水线语法第六部分

    如果needs:设置为指向因only/except规则而未实例化的作业,或者不存在,创建管道时会出现YAML错误。...local 引入同一存储库中的文件,使用相对于根目录的完整路径进行引用,与配置文件在同一分支上使用。 ci/localci.yml: 定义一个作业用于发布。...GitLab从trigger定义创建的作业启动,将创建一个下游管道。...[微服务架构] 父子管道: 在同一目中管道可以触发一组同时运行的子管道,子管道仍然按照阶段顺序执行其每个作业,但是可以自由地继续执行各个阶段,而不必等待父管道中无关的作业完成。...如果发现下游项目用户没有访问权限以在其中创建管道,staging作业将被标记为失败。

    3K30

    父子管道更有效地扩展应用及其存储库结构

    当前,使用这种模式,开发人员都使用同一.gitlab-ci.yml文件来为不同的应用程序组件触发不同的自动化过程,这可能会导致合并冲突和生产率下降,而团队则在等待管道“其一部分”的运行和完成。...将您创建的所有文件推送到新分支,对于管道结果,您应该看到两个作业及其后续的子作业。 ? ---- 默认情况下,一旦创建下游管道,trigger作业就会以success状态完成。...父管道不会在子管道运行成功后再显示流水线成功,而是子管道只要被触发成功了父管道成功。strategy: depend将自身状态从触发的管道合并到源作业。...我们用于artifacts保存为该CI运行生成的子配置文件,以使它们可用于子管道阶段。 Ruby脚本生成YAML,请确保缩进正确,否则管道作业将失败。 #!...将您创建的所有文件推送到新分支,对于管道结果,您应该看到三个作业(一个作业连接到其他两个作业)以及随后的两个子作业。 ? 这篇博客文章显示了一些简单的示例,使您大致了解管道现在可以完成的工作。

    1.6K21

    GitLab13.8版本CICD部分功能更新

    将按照从左到右的顺序尝试列表中的策略,直到成功进行拉取列表用尽为止。 什么时候使用多个拉策略? Docker注册表不可用并且您需要提高作业弹性,此功能很有用。...如果您使用该always策略并且注册表不可用,即使所需的镜像在本地缓存,该作业也会失败。 为了克服该问题,您可以添加在故障情况下执行的其他后备拉取策略。...如果使用expire_in来配置作业其工件仅在存在较新的工件过期。 保留最新的工件会在具有大量工作较大工件的项目中使用大量存储空间。...CI_OPEN_MERGE_REQUESTS 在分支合并请求管道中可用。一个逗号分隔的列表,该列表包含最多四个使用当前分支和项目作为合并请求源的合并请求。例如: gitlab-org/gitlab!...如果配置没有任何needs关系,则不会画线,因为每个作业取决于成功完成的前一阶段。

    1.6K20

    【前端部署第十篇】CICD基础概念了解,并实现基于 docker 的自动部署

    分支合并策略 (分支保护规则) 5. 使用 CICD 进行自动部署 6. 自建 Runner 7.....dev.shanyue.tech 此种地址 功能分支测试通过后,合并分支,「自动构建镜像并部署到生成环境中」 (一般生成环境需要手动触发、自动部署) 如下图,所有 Checks...我们进行拆分成两个阶段,并在以下简单介绍如何进行配置 事件: push 命令: 前端部署 3.1. 事件: on push 该 CI/CD 触发的事件。...branches: - master # feature/** 分支发生变更进行 Preview 功能分支部署 (见 Preview 篇) on: pull_request...分支合并策略 (分支保护规则) 「生产环境的代码必须通过 CI 检测才能上线」,但这也需要我们进行手动设置。 一般而言,我们会设置以下策略加强代码的质量管理。

    2.1K20

    Git版本控制 Git、github,gitlab相关操作

    分支的面板,点击【New Branch】 切换回分支 合并分支分支(master分支)与1.0分支进行合并 冲突解决 在newbranch分支上c.txt编写代码并提交 在master...会设置 protected 分支保护 只有有权限的人才能推送代码到 master 分支 如果有新功能开发,可以从 master 分支上检出新分支 在本地分支提交代码,并且保证按时向远程仓库推送 当你需要反馈或者帮助...以后,只有修补bug,允许将代码合并到这些分支 并且此时要更新小版本号 合并请求 创建团队: 填写信息 邀请成员 分支权限与合并请求 在指定项目上创建分支: 默认分支是受保护的...一个分支是一个受保护的分支,必须要发起合并请求后操作 设置分支权限 设置保存分支入口 展开分支保存按钮 忽略文件 在项目开发中,我们使用git托管项目往往会忽略一些不必要的文件文件夹...gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,修改.gitignore是无效的。

    29510

    GitLabCI系列之流水线语法第五部分

    artifacts 用于指定在作业成功或者失败应附加到作业的文件目录的列表。作业完成后,工件将被发送到GitLab,并可在GitLab UI中下载。...请注意以下几点: 每个合并请求最多可以公开10个作业工件。 如果指定了目录,那么如果目录中有多个文件,该链接将指向指向作业工件浏览器。...使用当前作业的名称创建档案 job: artifacts: name: "$CI_JOB_NAME" paths: - binaries/ 使用内部分支标记的名称(包括...在GitLab的UI中显示这些报告。注意:无论作业结果(成功失败),都将收集测试报告。...定义一个空数组将跳过下载该作业的任何工件不会考虑先前作业的状态,因此,如果它失败或是未运行的手动作业,则不会发生错误。 如果设置为依赖作业的工件已过期删除,那么依赖作业将失败。 ?

    3.4K20
    领券