GitLab CI/CD 的配置详解:从零开始使用 .gitlab-ci.yml 文件
在现代软件开发中,CI/CD(持续集成与持续部署)已成为提高开发效率和代码质量的核心实践。GitLab CI/CD 提供了强大的功能,帮助开发者自动化构建、测试和部署应用程序。而 .gitlab-ci.yml 文件是 GitLab CI/CD 配置的关键所在,本文将详细介绍 .gitlab-ci.yml 文件的基本语法与使用技巧,帮助开发者能够轻松上手。
什么是 .gitlab-ci.yml 文件?
.gitlab-ci.yml 是 GitLab CI/CD 的配置文件,主要用于定义一系列的任务(Jobs)和阶段(Stages),以便自动化执行构建、测试和部署过程。每当你向 GitLab 仓库提交代码时,GitLab 会根据该文件自动触发管道(Pipeline),执行相应的操作。
基本结构与关键概念
.gitlab-ci.yml 文件由几个主要部分构成:
- Stages(阶段)
- Jobs(任务)
- Script(脚本)
- Variables(变量)
- Cache(缓存)
- Artifacts(工件)
1. Stages(阶段)
stages 定义了任务执行的顺序。GitLab CI/CD 会根据 stages 中的顺序依次执行每个阶段。每个阶段中包含一个或多个任务,通常包括构建(build)、测试(test)和部署(deploy)。
stages:- build- test- deploy
在上述配置中,GitLab 会按照 build、test 和 deploy 的顺序执行任务。
2. Jobs(任务)
jobs 是 .gitlab-ci.yml 中最基本的构建单元。每个任务包含一个或多个命令(script),这些命令会在相应的阶段中执行。你可以在任务中定义具体的构建、测试和部署过程。
build:stage: buildscript:- echo "Building the application..."- make
在此示例中,build 任务属于 build 阶段,任务的 script 定义了需要执行的具体命令,make 命令用来构建应用程序。
3. Script(脚本)
script 是任务中执行的命令,通常由一系列 Shell 命令组成。它定义了每个任务执行的具体步骤。
test:stage: testscript:- echo "Running tests..."- ./run_tests.sh
在 test 阶段,GitLab 将会执行 ./run_tests.sh 脚本文件,以运行自动化测试。
4. Variables(变量)
在 .gitlab-ci.yml 文件中,variables 用来定义全局或局部的变量,这些变量可以在任务的 script 部分引用。定义变量有助于简化配置,避免重复代码。
variables:PROJECT_DIR: "/home/user/myproject"JAVA_HOME: "/usr/lib/jvm/java-11-openjdk"
在任务中引用这些变量时,可以像这样:
build:script:- cd $PROJECT_DIR- mvn clean install
5. Cache(缓存)
cache 用于定义需要在不同任务之间共享的目录或文件。缓存可以帮助加速构建过程,避免每次构建时重新下载依赖项。
cache:paths:- .m2/repository/
这个配置会缓存 Maven 构建所使用的 .m2/repository/ 目录,从而加快后续任务的构建速度。
6. Artifacts(工件)
artifacts 用来定义任务完成后需要保存的文件。保存的文件可以在后续阶段使用,或供用户下载。
test:stage: testscript:- ./run_tests.shartifacts:paths:- test-results/*.xmlexpire_in: 1 week
在这个示例中,测试结果将保存为 XML 文件,并且会在一周后自动删除。
高级功能与配置
Job 之间的依赖关系
在 GitLab CI/CD 中,任务默认按照阶段的顺序依次执行,但有时你可能希望明确指定任务之间的依赖关系。可以通过 dependencies 来实现这一点。
test:stage: testscript:- ./run_tests.shdependencies:- build
在这个配置中,test 任务依赖于 build 任务,GitLab 会先执行 build 任务,成功后再执行 test 任务。
条件执行任务
有时你可能希望在特定条件下才执行某些任务,比如仅在特定分支上执行某些部署操作。GitLab CI/CD 支持使用 only 和 except 来限制任务的执行条件。
deploy:stage: deployscript:- echo "Deploying the application..."- scp $PROJECT_DIR/* user@remote:/path/to/deployonly:- master # 仅在master分支执行
在这个配置中,deploy 任务只会在 master 分支上执行,避免其他分支部署到生产环境。
完整的 .gitlab-ci.yml 示例
stages:- build- test- deployvariables:PROJECT_DIR: "/home/user/myproject"DEPLOY_DIR: "/home/user/deploy"before_script:- echo "Setting up environment..."build:stage: buildscript:- echo "Building the application..."- cd $PROJECT_DIR- maketest:stage: testscript:- echo "Running tests..."- cd $PROJECT_DIR- ./run_tests.shartifacts:paths:- test-results/*.xmlexpire_in: 1 weekdeploy:stage: deployscript:- echo "Deploying application..."- scp $PROJECT_DIR/* user@remote:/path/to/deployonly:- master # 只在master分支执行
总结
.gitlab-ci.yml 文件是 GitLab CI/CD 配置的核心,它通过定义任务(jobs)和阶段(stages)来帮助开发者实现自动化构建、测试和部署。通过合理使用 variables、cache、artifacts 等功能,可以大大提高工作效率,减少重复劳动。
希望本文能够帮助你快速理解 .gitlab-ci.yml 的基本语法与使用方法,并顺利地将 CI/CD 集成到你的开发流程中。如果你在使用过程中遇到问题或有更多问题,欢迎在评论区留言讨论。
这篇文章从基础到进阶详细讲解了 .gitlab-ci.yml 文件的用法,既适合 GitLab CI/CD 的新手入门,也能够帮助有一定经验的开发者更好地掌握配置技巧。如果有更复杂的需求,也可以根据实际情况进一步扩展和定制 CI/CD 流程。
相关文章:
GitLab CI/CD 的配置详解:从零开始使用 .gitlab-ci.yml 文件
在现代软件开发中,CI/CD(持续集成与持续部署)已成为提高开发效率和代码质量的核心实践。GitLab CI/CD 提供了强大的功能,帮助开发者自动化构建、测试和部署应用程序。而 .gitlab-ci.yml 文件是 GitLab CI/CD 配置的关键所在&#…...
python语言进阶之函数
目录 前言 函数的创建和调用 函数创建 调用函数 参数传递 形式参数和实际参数 位置参数 数量必须与定义时一致 位置必须与定义时一致 关键字参数 为参数设置默认值 可变参数 **parameter 返回值 变量的作用域 局部变量 全局变量 匿名函数 前言 提到函数&…...
网络安全等级保护基本要求、测评要求、高风险判定指引综合梳理
网络安全等级保护基本要求、测评要求、高风险判定指引综合梳理 等级保护基本要求、测评要求、高风险判定指引综合梳理测评要求思维导图二级三级 花了些时间把网络安全等级保护涉及的以下三份标准文件进行了整理,以表格的形式进行展现,能帮助初学者更加直…...
JSON入门略要
JavaScript对象表示法(JavaScript Object Notation,JSON)已经成为RESTful接口设计中的事实标准。 JSON数据格式使得应用程序可以通过RESTful API等方式在网络上进行数据通信。 REST: 表现层状态转化(REpresentation State Transf…...
Python爬虫抓取数据时,如何设置请求头?
在Python爬虫中设置请求头是确保爬虫能够正常运行并获取目标数据的关键步骤之一。请求头可以帮助我们模拟浏览器行为,避免被目标网站识别为爬虫。以下是如何在Python爬虫中设置请求头的详细指南: 一、使用requests库设置请求头 requests库是Python中最…...
以若依移动端版为基础,实现uniapp的flowable流程管理
1.前言 此代码是若依移动端版为基础,实现flowable流程管理,支持H5、APP和微信小程序三端。其中,APP是在安卓在雷电模拟器环境下完成的,其他环境未测试,此文章中所提及的APP均指上述环境。移动端是需要配合若依前后端分…...
DeepSeek 助力 Vue 开发:打造丝滑的开关切换(Switch)
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 Deep…...
unity学习39:连续动作之间的切换,用按键控制角色的移动
目录 1 不同状态之间的切换模式 1.1 在1个连续状态和一个连续状态之间的transition,使用trigger 1.2 在2个连续状态之间的转换,使用bool值切换转换 2 至少现在有2种角色的移动控制方式 2.1 用CharacterController 控制角色的移动 2.2 用animator…...
C++ ——构造函数
1、作用:创建对象时,给对象的属性进行初始化 2、特点 (1)构造函数与类同名 (2)如果没有显式给出构造函数,编译器会给出默认的构造函数(参数为空,并且函数体也为空&#…...
Python实现语音识别详细教程【2025】最新教程
文章目录 前言一、环境搭建1. 下载 Python2. 安装 Python3 使用 pip 安装必要的库 二、使用 SpeechRecognition 库进行语音识别1.识别本地音频文件2.实时语音识别3. 使用其他语音识别引擎 注意事项 前言 以下是一份较为完整的 Python 语音识别教程,涵盖环境搭建、使…...
【第12章:深度学习与伦理、隐私—12.4 深度学习与伦理、隐私领域的未来挑战与应对策略】
凌晨三点的自动驾驶测试场,AI系统突然在暴雨中做出惊人决策——它选择撞向隔离带而不是紧急变道,因为算法推演发现隔离带后的应急车道站着五个工程师。这个惊悚的伦理困境,揭开了深度学习伦理危机最尖锐的冰山一角。 一、潘多拉魔盒已开:深度学习伦理的四大原罪 1.1 数据原…...
Django中数据库迁移命令
在 Django 中,数据库迁移是确保数据库结构与 Django 模型定义保持一致的重要过程。以下是 Django 中常用的数据库迁移命令: 1. python manage.py makemigrations 功能:此命令用于根据 Django 项目的模型文件(models.pyÿ…...
Win11 远程 连接 Ubuntu20.04(局域网)
Win11 远程 连接 Ubuntu20.04(局域网) 0. Ubuntu 开启共享1. Ubuntu系统中安装RDP服务器2.windows中连接使用方式1:远程桌面连接(winr: mstsc)方式2:mobaXterm 3 问题远程连接后出现黑屏 参考文献: 0. Ubuntu 开启共享 在ubunt设置中&#x…...
安卓手游内存call综合工具/内部call/安卓注入call/数据分析(类人猿学院)
进程分析注入综合工具总界面 模块分析函数分析遍历 函数分析 so汇编分析 汇编call植入器,支持模拟器x86 x64 和手机arm64指令全平台 防ce搜索数据功能 全国首套发布,阿凡老师学院最好的安卓内存逆向老师,几乎行业最强的,有兴趣可以…...
PPT工具集
PPT模版 免费下载 爱PPT优品PPTPPT之家第一PPTOfficePlus部分免费 AI生成PPT Kimi秘塔搜索 可以输入内容生成PPT大纲。...
SpringBoot:使用spring-boot-test对web应用做单元测试时如何测试Filter?
对SpringBoot的Web应用做单元测试时,一般会使用spring-boot-test,pom.xml中会添加如下内容: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><…...
解锁 Java 回调函数:异步编程与事件处理的利器
什么是 Java 回调函数 在 Java 中,回调函数是一种编程模式,允许将一个方法作为参数传递给另一个方法,当某个特定事件发生或某个任务完成时,调用该方法。回调机制可以使代码更加灵活和可扩展,因为它允许在运行时动态地…...
记PasteSpider部署工具的Windows.IIS版本开发过程之草稿-Web.IIS.Administration解读(5)
本文是记录PasteSpider的Windows.IIS开发过程, 在应用开发中,结果很重要,但是开发过程中遇到的问题和思考绝对是更有意义的事情! 经历过不同的需求后,你会发觉案例项目还真的只是案例项目,和实际项目天差地别!!! PasteSpider是开发者专属部署工具, 新版本的支持Windo…...
MySQL Workbench安装教程以及菜单汉化
WorkBench的下载 直接给下载MySql WorkBench的链接,直接进入正题:MySQL :: Download MySQL Workbenchhttps://dev.mysql.com/downloads/workbench/进入了下载界面: (安装路径自己看着办,注意安装路径不能有中文&#…...
【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第十节】
ISO 14229-1:2023 UDS诊断服务测试用例全解析(ClearDiagnosticInformation0x14服务) 作者:车端域控测试工程师 更新日期:2025年02月13日 关键词:UDS协议、0x14服务、DTC清除、ISO 14229-1:2023、ECU测试 一、服务功能…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
Prompt Tuning、P-Tuning、Prefix Tuning的区别
一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...
进程地址空间(比特课总结)
一、进程地址空间 1. 环境变量 1 )⽤户级环境变量与系统级环境变量 全局属性:环境变量具有全局属性,会被⼦进程继承。例如当bash启动⼦进程时,环 境变量会⾃动传递给⼦进程。 本地变量限制:本地变量只在当前进程(ba…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...
ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...
排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...
LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》
这段 Python 代码是一个完整的 知识库数据库操作模块,用于对本地知识库系统中的知识库进行增删改查(CRUD)操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 📘 一、整体功能概述 该模块…...
NPOI操作EXCEL文件 ——CAD C# 二次开发
缺点:dll.版本容易加载错误。CAD加载插件时,没有加载所有类库。插件运行过程中用到某个类库,会从CAD的安装目录找,找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库,就用插件程序加载进…...
