gitlab高级功能之 CICD Steps

CICD Steps

    • 1. 介绍
    • 2. 定义 Steps
      • 2.1 Inputs
      • 2.2 Outputs
    • 3. Using steps
      • 3.1 Set environment variables
      • 3.2 Running steps locally
    • 4. Scripts
    • 5. Actions
      • 5.1 已知的问题
    • 6. 表达式
    • 7. 实操
      • 7.1 单个step
      • 7.2 多个step
      • 7.3 复用steps
      • 7.4 添加output到step
      • 7.5 使用远程step

1. 介绍

  • Steps是作业中可重用且可组合的部分。
  • 每个Step都定义可由其他Steps使用的结构化输入和输出。
  • Step可以来自本地文件、GitLab.com 存储库或任何其他 Git 源。

Steps 是用于运行作业的 shell 脚本的替代方案。它们提供了更多的结构,可以组合,并且可以测试和重用。 exec:命令是通过使用 Exec 系统调用来运行的,而不是通过运行 shell 来运行。

2. 定义 Steps

Steps在 step.yml 文件中定义。每个文件都有两个文档:规范和定义。

  • 规范提供了输入、输出、类型、描述和默认值
  • 定义提供了该步骤的实现。步骤定义有两种:
    • exec 类型,执行命令
      # (spec goes here)
      ---
      # Example exec definition
      exec:
      command: [ docker, run, -it, ubuntu, uname, -a ]
      
    • steps类型,运行一系列其他步骤
      # (spec goes here)
      ---
      # Example steps definition
      steps:- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1inputs:echo: hello ${{ inputs.name }}- name: print_system_informationstep: ./my-local-steps/uname
      

2.1 Inputs

Inputs可以是以下类型:

  • string
  • number
  • boolean
  • array
  • struct

默认输入类型是string。,如果输入没有定义默认值,那么它是必需的。
默认值不能使用仅在步骤定义中允许的表达式 (${{ }})。

2.2 Outputs

Outputs可以是以下类型:

  • string
  • number
  • boolean
  • array
  • struct
  • raw_string
  • step_result

outputs会写入 ${{ output_file }},格式为 key=value,其中 key 是输出的名称。除非类型为 raw_string,否则值应以 JSON 格式写入。

Steps写入的值类型必须与声明的类型匹配,默认的输出类型为 raw_string。

特殊的输出类型 step_result 用于将步骤的执行委托给其他步骤。例如,script 和 action-runner 步骤。

Steps类型定义中的输出使用表达式来从子步骤的输出进行聚合。由于规范中不允许使用表达式,因此 outputs 关键字出现在定义中。为了保持封装性并允许重构,调用者无法直接访问子步骤的输出。

3. Using steps

关键字 step 指向远程或本地steps;

  • 远程steps引用由 Git 仓库的 URL、符号 @ 和标签或分支(版本)组成。steps运行器会在仓库根目录下查找名为 step.yml 的文件。
  • 本地steps以 . 开头,指向一个目录,步骤运行器会在该目录中查找 step.yml 文件。本地引用始终使用路径分隔符 /,无论操作系统是什么。在加载文件时,会使用适合操作系统的分隔符。
# Example job using steps
my-job:run:- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1inputs:echo: hello $[[ GITLAB_USER_LOGIN ]]- name: print_system_informationstep: ./my-local-steps/uname

要在作业中使用steps,请在变量中提供steps并调用作业脚本关键字的steps运行程序。史诗 11525 中建议支持使用作业中的步骤作为 GitLab CI 管道配置中的运行关键字。

# Example work-around until run keyword is implemented
my-job:image: registry.gitlab.com/gitlab-org/step-runner:v0variables:STEPS: |- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1inputs:echo: hello $GITLAB_USER_LOGIN- name: print_system_informationstep: ./my-local-steps/unamescript:# Run the step-runner's ci command which ready from the STEPS environment variable- /step-runner ci

3.1 Set environment variables

你不需要为steps声明环境变量。任何以 key=value 形式写入 ${{ export_file }} 的导出都会添加到全局执行环境中。导出的值是纯字符串(无 JSON)。

你可以在steps执行期间使用 env 关键字来临时设置环境变量:

# Example job using env
my-job:run:- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1env:USER: $[[ GITLAB_USER_LOGIN ]]inputs:echo: hello ${{ env.USER }}

Steps定义还可以临时设置环境变量

# (spec goes here)
---
# Example step definition using env
env:USER: ${{ inputs.user }}
steps:- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1inputs:echo: hello ${{ env.USER }}

环境变量的优先顺序是: steps定义 -> steps参考(调用步骤) -> 全局环境

Steps定义中设置的环境变量会覆盖调用步骤时设置的变量,依此类推。

3.2 Running steps locally

要在本地运行steps,请下载 step-runner 并运行 ci 命令。这与用于在生产中运行步骤的二进制文件相同。

STEPS=$(yq '."my-job"'.run .gitlab-ci.yml) step-runner ci

您可以使用 delve 进行调试。在 pkg/runner.go) 中的 Run 处设置断点。

STEPS=$(yq '."my-job"'.run .gitlab-ci.yml) dlv debug . ci

4. Scripts

虽然通常使用steps代替 shell 脚本,但有时仍然需要 shell 脚本。 script 关键字将自动选择正确的 shell 并运行脚本。

# Example job using script
my-job:run:- name: greet_userscript: echo hello $[[ GITLAB_USER_LOGIN ]]

仅支持 bash shell

5. Actions

您可以使用 action 关键字运行 GitHub 操作。输入和输出的工作方式与步骤相同。步骤和操作可以互换使用。

# Example job using action
my-job:run:- name: greet_userstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@v1inputs:echo: hello $[[ GITLAB_USER_LOGIN ]]- name: greet_user_againaction: mikefarah/yq@masterinputs:cmd: echo ["${{ steps.greet_user.outputs.echo }} again!"] | yq .[0]

5.1 已知的问题

GitLab 中运行的操作不支持直接上传artifacts。artifacts必须写入文件系统和缓存,并使用现有的artifacts关键字进行选择。

6. 表达式

表达式是一种用双大括号 (${{ }}) 括起来的mini语言,它们可以引用inputsenv(步骤共享的环境)和先前步骤的输出(steps.<step_name>.outputs)。

表达式还可以引用work_dir,它是构建目录。 step_dir 缓存步骤定义和关联文件。以及output_file 和export_file,这是输出和导出的写入位置。

表达式与模板插值不同,模板插值使用双方括号 ($[[ ]]) 并在作业生成期间进行评估。表达式在作业环境中执行步骤之前进行计算。

7. 实操

cat stap.yml

# 规范有一个名为 who 的输入, who 是可选的,默认值为 world
spec:inputs:who:default: world
# 使用 三重破折号 (---) 将文件分隔为两个 YAML 文档:在 spec 之后添加第二个 YAML 文档,第二个文件是实现,就像函数体一样,使用 exec 键
---
exec:command: # bash 和 -c 参数启动 Bash shell 并从命令行参数获取脚本输入。除了 shell 脚本之外,您还可以使用命令来执行 docker 或 terraform 等程序。- bash- -c- "echo hello ${{ inputs.who }}" # echo hello ${{ input.name }} 参数包含 ${{ }} 内的表达式。表达式在最后可能的时刻进行计算,并且可以访问当前的执行上下文。此表达式访问输入并读取 who 的值。如果定义了who,则用定义的值替换;如果缺省没有定义who,则使用默认值。

7.1 单个step

cat .gitlab-ci.yml

stages:   # List of stages for jobs, and their order of execution- build- test- deployhello-world:variables:STEPS:expand: falsevalue: |- name: hello_world # 每个调用都会被赋予一个名称,以便您可以在后续步骤中引用输出step: . # 每次调用都指定要运行的步骤。本地引用 (.) 指向存储库的根目录image: registry.gitlab.com/gitlab-org/step-runner:v0script:- /step-runner ci # 作业脚本调用位于step-runner:v0 映像中的step-runner ci

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.2 多个step

stages:   # List of stages for jobs, and their order of execution- build- test- deployhello-world:variables:STEPS:expand: falsevalue: |- name: hello_worldstep: .- name: hello_stepsstep: .inputs:who: gitlab stepsimage: registry.gitlab.com/gitlab-org/step-runner:v0script:- /step-runner ci

在这里插入图片描述

7.3 复用steps

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.4 添加output到step

将output添加到你的 hello step中

# 规范有一个名为 who 的输入, who 是可选的,默认值为 world
spec:inputs:who:default: worldoutputs: # 在本规范中,定义了一个没有默认值的输出问候语。因为没有默认值,所以需要输出问候语;输出以 key=value 的形式写入文件 ${{ output_file }} (在运行时提供)。greeting: {}
# 使用 三重破折号 (---) 将文件分隔为两个 YAML 文档:在 spec 之后添加第二个 YAML 文档,第二个文件是实现,就像函数体一样,使用 exec 键
---
exec:command: # bash 和 -c 参数启动 Bash shell 并从命令行参数获取脚本输入。除了 shell 脚本之外,您还可以使用命令来执行 docker 或 terraform 等程序。- bash- -c- "echo greeting=hello ${{ inputs.who }} | tee ${{ output_file }}" # 此步骤运行 echo greeting=hello ${{inputs.who}} 并将输出发送到日志和输出文件 (tee ${{output_file}})。

在这里插入图片描述

spec:outputs:all_greetings: {}
---
steps:- name: hello_worldstep: ./hello- name: hello_stepsstep: ./helloinputs:who: gitlab steps
outputs:all_greetings: "${{ steps.hello_world.outputs.greeting }} and ${{ steps.hello_steps.outputs.greeting }}"

在这里插入图片描述
在这里插入图片描述

7.5 使用远程step

cat .gitlab-ci.yml

hello-world:variables:STEPS:expand: falsevalue: |- name: hello_everybodystep: .- name: all_my_greetingsstep: gitlab.com/gitlab-org/ci-cd/runner-tools/echo-step@masterinputs:echo: "all my greetings say ${{ steps.hello_everybody.outputs.all_greetings }}"image: registry.gitlab.com/gitlab-org/step-runner:v0script:- /step-runner ci

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/66154.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开源数据集成平台白皮书重磅发布《Apache SeaTunnel 2024用户案例合集》!

2025年新年临近&#xff0c;Apache SeaTunnel 社区用户案例精选&#x1f4d8;也跟大家见面啦&#xff01;在过去的时间里&#xff0c;SeaTunnel 社区持续成长&#xff0c;吸引了众多开发者的关注与支持。 为了致谢一路同行的伙伴&#xff0c;也为了激励更多人加入技术共创&…

第六十四章 假脱机设备 - 使用 %SPOOL 打印

文章目录 第六十四章 假脱机设备 - 使用 %SPOOL 打印使用 %SPOOL 打印使用 Print 函数 第六十四章 假脱机设备 - 使用 %SPOOL 打印 使用 %SPOOL 打印 %SPOOL 实用程序菜单的选项 1 Print&#xff08;打印&#xff09;允许您在任何设备上打印 ^SPOOL 全局中的一个或多个文档&a…

Python:交互式物质三态知识讲解小工具

学着物理写着Python 以下是一个使用Python的Tkinter库实现的简单示例程序&#xff0c;通过图形界面展示并讲解固态、液态、气态的一些特点&#xff0c;代码中有详细的注释来帮助你理解各部分功能&#xff1a; 完整代码 import tkinter as tk from tkinter import ttk import …

选择IT驻场外包公司,要找有哪些资质的公司

在当今数字化快速发展的时代&#xff0c;IT驻场外包服务成为众多企业优化运营、提升竞争力的关键选择。无论是初创企业寻求技术起步支持&#xff0c;还是大型企业为降低成本、专注核心业务而将部分 IT 职能外包&#xff0c;IT 外包公司都扮演着至关重要的角色。然而&#xff0c…

多模态论文笔记——CogVLM和CogVLM2(副)

大家好&#xff0c;这里是好评笔记&#xff0c;公主号&#xff1a;Goodnote&#xff0c;专栏文章私信限时Free。本文详细介绍多模态模型的LoRA版本——CogVLM和CogVLM2。在SD 3中使用其作为captioner基准模型的原因和优势。 文章目录 CogVLM论文背景VLMs 的任务与挑战现有方法及…

Scala 访问修饰符

Scala 访问修饰符 在编程语言中&#xff0c;访问修饰符是一种重要的语法元素&#xff0c;它用于控制类、对象、特质、接口、方法和变量的访问级别。Scala作为一种多范式编程语言&#xff0c;也提供了丰富的访问修饰符&#xff0c;以实现封装和隐藏内部实现细节。本文将详细介绍…

网络安全抓包

#知识点&#xff1a; 1、抓包技术应用意义 //有些应用或者目标是看不到的&#xff0c;这时候就要进行抓包 2、抓包技术应用对象 //app,小程序 3、抓包技术应用协议 //http&#xff0c;socket 4、抓包技术应用支持 5、封包技术应用意义 总结点&#xff1a;学会不同对象采用…

Innodisk iSMART V6使用说明_SSD还能用多久?已经读写了多少次数?……

Innodisk iSMART是一款SSD健康数据读取软件。它能轻松获取大部分SSD内部寄存器中的健康数据&#xff0c;并以简洁的图形界面展示给用户。在程序界面的顶部&#xff0c;是页面标签&#xff0c;点击页面标签就能切换到相应的页面。页面标签的下面是磁盘选择栏。点击磁盘编号&…

网络编程原理:回显服务器与客户端通信交互功能

文章目录 路由器及网络概念网络通信基础TCP/IP 五层协议封装和分用封装分用 网络编程&#xff08;网络协议&#xff09;UDP类 API使用实现回显通信程序回显服务器(UDP代码)回显客户端(UDP代码) TCP API使用回显服务器(TCP代码)回显客户端(TCP代码) 路由器及网络概念 网络发展是…

设计模式 创建型 建造者模式(Builder Pattern)与 常见技术框架应用 解析

单例模式&#xff08;Singleton Pattern&#xff09;&#xff0c;又称生成器模式&#xff0c;是一种对象构建模式。它主要用于构建复杂对象&#xff0c;通过将复杂对象的构建过程与其表示分离&#xff0c;使得同样的构建过程可以创建出具有不同表示的对象。该模式的核心思想是将…

【C++】P1428 小鱼比可爱

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目说明题目输入格式题目输出格式样例**输入样例****输出样例** 题目解析 &#x1f4af;解法分析我的做法代码解法说明时间复杂度 老师的做法代码解法说明总结时间复杂度 …

[coredump] 生成管理

在 Linux 系统中&#xff0c;core dump 文件的生成路径和文件名可以通过几个方面来控制&#xff1a; 系统默认路径&#xff1a; 默认情况下&#xff0c;core dump 文件通常生成在程序的工作目录&#xff0c;即程序运行时的当前目录。文件名通常为 core&#xff0c;或者在某些系…

maven之插件调试

当使用maven进行项目管理的时候&#xff0c;可能会碰到一些疑难问题。网上资料很少&#xff0c;可能会想着直接调试定位问题。这里以maven-compiler-plugin为例&#xff1a; &#xff08;1&#xff09;准备maven-compiler-plugin源码 进入maven 官网-》Maven Plugins-》找到对…

CentOS 8 上搭建SFTP服务

安装 在CentOS 8上搭建SFTP服务&#xff0c;可以通过OpenSSH来实现。以下是具体步骤&#xff1a; 1. 安装OpenSSH服务器 在CentOS 8中&#xff0c;通常已经安装了OpenSSH服务器。如果没有&#xff0c;可以通过以下命令安装&#xff1a; sudo dnf install -y openssh-server…

【系统分析师】- 案例 -数据库特训

目录 1、规范化与逆规范化 2、数据库视图 3、数据库索引 4、SQL优化 5、数据库分区 6、分布式数据库 7、NoSql 8、读写分离&#xff08;主从复制&#xff09; 9、缓存一致性 10、云数据库 11、主题数据库 12、数据同步 1、规范化与逆规范化 规范化&#xff1a; 优点…

Redis(基础篇 + 实践篇 )

01 | 基本架构&#xff1a;一个键值数据库包含什么&#xff1f; Redis 作为一个内存数据存储系统&#xff0c;它的架构设计非常简洁&#xff0c;但功能非常强大。理解其核心架构对高效使用 Redis 至关重要。 客户端与服务器架构&#xff1a; 客户端通过 TCP 协议连接到 Redis …

蓝桥杯(Java)(ing)

Java前置知识 输入流&#xff1a; &#xff08;在Java面向对象编程-CSDN博客里面有提过相关知识------IO流&#xff09; // 快读快写 static BufferedReader in new BufferedReader(new InputStreamReader(System.in)); static BufferedWriter out new BufferedWriter(new…

GaussDB逻辑解码技术原理深度解析

GaussDB逻辑解码技术原理深度解析 一、背景介绍 在数字化转型的大潮中&#xff0c;异构数据库之间的数据同步需求日益增长。异构数据库同步指的是将不同类型、不同结构的数据库之间的数据进行同步处理&#xff0c;以确保数据在不同数据库之间的一致性。华为云提供的DRS服务&a…

【C++】深入理解C语言中的特殊字符处理与问题分析优化

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目&#xff1a;B2090 年龄与疾病输入格式输出格式输入输出样例 &#x1f4af;初始代码分析与问题排查问题点分析 &#x1f4af;修正后的代码与优化修正与优化要点 &#…

电商Google广告:2025年提升转化率的5种策略

展望 2025 年&#xff0c;Google 广告领域将迎来一系列显著变化&#xff0c;这些趋势对于提升广告转化率至关重要&#xff0c;值得我们提前关注与布局。 智能化程度持续加深&#xff0c;用户搜索习惯愈发精细&#xff0c;广告格式推陈出新&#xff0c;视频广告势头正猛...那么…