问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

创建并运行您的第一个极狐GitLab CI/CD 流水线

创作时间:
作者:
@小白创作中心

创建并运行您的第一个极狐GitLab CI/CD 流水线

引用
1
来源
1.
https://docs.gitlab.cn/jh/ci/quick_start/

本教程将指导您在极狐GitLab中配置和运行第一个CI/CD流水线。通过本文,您将学习如何创建流水线、配置作业以及查看流水线状态。适合对CI/CD有一定了解但尚未在GitLab中实践的用户。

先决条件

开始之前,请确保满足以下条件:

  • 您有一个需要使用CI/CD的极狐GitLab项目
  • 您拥有该项目的所有者或维护者角色

如果您还没有项目,可以创建一个公共项目或使用SaaS服务(https://jihulab.com)。

步骤

要创建并运行您的第一个流水线:

  1. 确保您有可用的runner来运行您的作业。如果您使用JihuLab.com,可以跳过此步骤,因为JihuLab.com为您提供了实例runner。

  2. 在仓库的根目录下创建.gitlab-ci.yml文件。此文件将定义CI/CD作业。当您提交文件到仓库时,runner就会运行您的作业,作业结果会在流水线中展示。

确保您有可用的runner

在极狐GitLab中,runners是运行CI/CD作业的代理。要查看可用的runner:

  1. 在左侧边栏中,选择搜索或前往,然后找到您的项目。
  2. 选择设置 > CI/CD
  3. 展开Runners

只要您看到至少一个runner,它旁边有一个绿色圆圈,就表示您有可用的runner来处理您的作业。

创建.gitlab-ci.yml文件

.gitlab-ci.yml文件是一个YAML文件,您可以在其中配置GitLab CI/CD的特定指令。在此文件中,您定义:

  • runner应执行的作业的结构和顺序
  • runner在遇到特定条件时应做出的决定

创建一个.gitlab-ci.yml文件:

  1. 在左侧边栏中,选择项目信息 > 详细信息
  2. 在文件列表上方,选择要提交的分支,点击加号图标,然后选择新建文件
  3. 对于文件名称,输入.gitlab-ci.yml,并在较大的窗口中粘贴以下示例代码:
build-job:
  stage: build
  script:
- echo "Hello, $GITLAB_USER_LOGIN!"
test-job1:
  stage: test
  script:
- echo "This job tests something"
test-job2:
  stage: test
  script:
- echo "This job tests something, but takes more time than test-job1."
- echo "After the echo commands complete, it runs the sleep command for 20 seconds"
- echo "which simulates a test that runs 20 seconds longer than test-job1"
- sleep 20
deploy-prod:
  stage: deploy
  script:
- echo "This job deploys something from the $CI_COMMIT_BRANCH branch."
  environment: production

此示例展示了四个作业:build-jobtest-job1test-job2deploy-prod。当查看作业时,echo命令中列出的注释会展示在UI中。$GITLAB_USER_LOGIN$CI_COMMIT_BRANCH的预定义变量的值会在作业运行时填充。

  1. 点击提交变更。提交后,流水线开始。

查看流水线和作业的状态

现在可以查看您的流水线和作业了:

  1. 前往构建 > 流水线。就会展现一个具有三个stage的流水线:
  2. 通过选择流水线ID来可视化查看您的流水线:
  3. 通过选择作业名称来查看作业详情。比如,deploy-prod

您已经成功创建了您的第一个流水线。恭喜您!

现在您可以开始自定义您的.gitlab-ci.yml文件,并定义更高级的作业。

.gitlab-ci.yml tips

下面是一些使用.gitlab-ci.yml文件的提示。对于完整的.gitlab-ci.yml语法,请参阅完整的CI/CD YAML语法参考。

  • 使用流水线编辑器来编辑您的.gitlab-ci.yml文件。
  • 每个作业都包含一个脚本部分,并属于一个阶段:
  • stage描述了作业的顺序执行。如果可用的runner,单个阶段中的作业将并行运行。
  • 使用needs关键字来按顺序运行作业,以增加流水线的速度和效率。
  • 您可以设置额外的配置来定制您的作业和阶段的执行方式:
  • 使用rules关键字来指定何时运行或跳过作业。onlyexcept旧关键字仍然支持,但不能与rules在同一个作业中使用。
  • 使用cacheartifacts关键字在流水线中存储依赖项和作业输出,即使使用每个作业的临时runner。
  • 使用default关键字来指定应用于所有作业的额外配置。此关键字通常用于定义before_scriptafter_script部分,这些部分应该在每个作业上运行。
© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号