基于Gitlab的CICD流程
本片文章主要初步介绍什么是CICD流程,并且把整个流程进行拆分理解整个流程的跑通过程。
1.CICD概述
- 什么是CICD呢?
简单的说CICD就是持续集成自动构建自动测试自动部署.
从概念上就可以看出,CICD主要由四个部分组成代码集成、打包构建、自动测试、自动部署。我们只需要把代码推送到gitlab远程分支上gitlab自动帮我们做好后面的所有流程,不需要我们手动参与,一看就非常的方便。
- CICD是怎么实现的呢?
要实现CICD得实现以下几个部分:
- 远程仓库功能
- pipeline
- runner
基本的流程如下:
码农将代码推送到远程仓库上, 然后触发pipline流水线通知注册的runner执行pipeline上定义的任务。
2.CI部分
CI就是代码集成也就是阶段性地向代码存库中集成最新的代码,其中gitlab的作用和github等代码托管平台的作用是一模一样的。
3.pipeline
gitlab中pipline翻译过来就是管道,我们知道管道很小水流是顺序流出的,也就是我们定义构建任务,测试任务,部署任务然后任务按照顺序执行,那么如果定义任务呢?
在项目根目录下新建一个 .gitlab-ci.yml 文件,在文件中我们可以定义任务执行阶段,及每个阶段执行的任务等信息,如下代码
before_script:
- bundle install
after_script:
- rm secrets
stages:
- build
- test
- deploy
job1:
stage: build
script:
- execute-script-for-job1
only:
- master
tags:
- docker
job2:
stage: test
script:
- echo zhe shi ce shi jie daun
job3:
stage: deploy
script:
- echo 这是自动部署阶段
那上面的例子举例,我们就在管道中定义了3个阶段,分别为build、test、deploy三个阶段,然后我们定义job1任务为build阶段执行的,script为执行的命令,job2为test阶段执行的任务,job3为deply阶段执行的任务。
当然真实生产时.gitlab-ci.yml文件肯定比这复杂很多,具体复杂的属性可以根据官方文档查看。
我们定义好了pieline,那么任务的执行者是谁呢?这就是接下来的runner角色了。
4.runner
runner一看名字我们就知道他是我们每个阶段任务的真实执行者,那它是怎么工作的呢?
- 首先我们需要在需要部署代码的机器上安装runner(不可以和gitlab服务一个机器)
- 然后启动runner
- 启动runner程序,并注册到gitlab服务器上(建立runner和gitlab服务器的连接)
- 选择一个excutor执行方式(比如是shell的本地执行,还是docker容器内执行,还是k8s等方式,初练选shell会好一点就是本地执行)
- 完成、等待触发
5.总结
我们只需要把整个CICD流程结构化区分一下思路就会瞬间清晰很多了,比如分成提交代码的部分(码农)、远程仓库(gitlab)、定义执行流程(pipeline)、任务执行者(runner)。
然后我们在想一下分成这几个部分以后,整个流程是怎么串起来来的呢?
- 码农提交代码到远程仓库(我们本地)
- 触发pipeline任务通知runner去执行(gitlab服务器)
- runner根据任务阶段顺序执行对应的任务(目标代码部署服务器)
基于上述我们就很快把整个CICD流程给弄清晰了,可以把一些简单的项目执行起来了,
但道路且长,上述只是简单的理解CICD的流程概念,如果需上手真实复杂的项目,还需要阅读官方文档如涉及容器,k8s,不同分支不同runnner,runner分类,excutor分类,等等比较细粒度的规则。
基于Gitlab的CICD流程的更多相关文章
- 基于gitlab的项目管理流程
框架 背景 个人是不太愿意使用用户体验差的软件来做项目管理,行业内,要找到这么一款软件,又要符合自己的需求,着实不容易.要免费,易用性要好,要安全,要有数据统计.而程序员的世界,SVN 之后,可能没有 ...
- 基于GitLab CI搭建Golang自动构建环境
基于GitLab CI搭建Golang自动构建环境 Golang发布遇到的问题 对于golang的发布,之前一直没有一套规范的发布流程,来看看之前发布流程: 方案一 开发者本地环境需要将环境变量文件改 ...
- 部署基于Gitlab+Docker+Rancher+Harbor的前端项目这一篇就够了
部署基于Gitlab+Docker+Rancher+Harbor的前端项目这一篇就够了 安大虎 momenta 中台开发工程师 6 人赞同了该文章 就目前的形势看,一家公司的运维体系不承载在 Do ...
- 大揭秘| 我司项目组Gitlab Flow && DevOps流程
长话短说,本文全景呈现我司项目组gitlab flow && devops Git Flow定义了一个项目发布的分支模型,为管理具有预定发布周期的大型项目提供了一个健壮的框架. Dev ...
- 基于GitLab的Code Review教程
一.前言 1.本文主要内容 GitLab Code Review机制说明 Git Workflow 与 Git Code Review Workflow GitLab Code Review 配置说明 ...
- 为某金融企业的IT技术部人员提供基于TFS的软件研发流程介绍
受莫金融企业IT信息技术部的邀请,为该金融企业的某省分公司.地市分公司的IT技术人员提供了一场基于TFS的软件研发流程的技术培训,希望可以借此提高该企业的软件研发.运维水平,同时推动企业软件研发信息化 ...
- [转] 基于Gitlab CI搭建持续集成环境
[From] https://blog.csdn.net/wGL3k77y9fR1k61T1aS/article/details/78798577 前言 本文是在12月12号迅雷@赵兵在前端早读课第三 ...
- linux中安装gitlab和cicd(断网版)
1:先介绍一下怎么查找所需要的依赖包 #yum install rpmname--downloadonly --downloaddir=/rpmpath 例如:yum install gitlab-r ...
- 基于gitlab 15.1 pages 搭建内部博客一定行版本
背景 基于 gitlab 15.1版 pages 搭建内部博客,参考官方文档,遇到一个又一个坑.之前看到别人吐槽说 gitlab 官方文档很差,我算是理解了.下面一个个说. 开始 按照官方文档的说法, ...
随机推荐
- Bits.java
package java.io; /** * Utility methods for packing/unpacking primitive values in/out of byte arrays ...
- ASP.NET Core中间件初始化探究
前言 在日常使用ASP.NET Core开发的过程中我们多多少少会设计到使用中间件的场景,ASP.NET Core默认也为我们内置了许多的中间件,甚至有时候我们需要自定义中间件来帮我们处理一些请求管道 ...
- python报错:AttributeError: module 'pdb' has no attribute 'set_trace'
在第一次使用python中的pdb模块式,pdb.set_trace()时编译器总是会报错,一开始总是以为是自己的拼写错误,但经过反复检查后发现并不是自己的拼写错误.而是我创建的测试文件的名称是pdb ...
- 060_Cookie/Session
目录 会话 有状态会话 保存会话的两种技术 cookie session 常见场景 Cookie cookie细节 删除cookie Session 什么是session session使用场景 se ...
- 对接快递100&聚水潭API
对接快递100&聚水潭API 入我相思门,知我相思苦. 简介:对接第三方平台快递100&聚水潭API的简要总结. 1.感悟 个人感觉快递100的API更友好一些,比如有SDK可以调用: ...
- 回忆那些年我玩过的ide,看看哪些你也玩过,看图回忆
闲来无聊,回忆一下这些年玩过的ide.看看哪些你也玩过. QBasic 第一个ide,兴奋程度也是最大的,从此进入了码农行列 VisualBasic 可以拖界面了,成就感爆棚 Turbo C c语言, ...
- 围绕 Kubernetes 的 8 大 DevOps 生产关键实践
本文主要介绍 DevOps 的 8 大关键实践在 Kubernetes 平台下如何落地,结合我们目前基于 Kubernetes 平台的 DevOps 实践谈谈是如何贯彻相关理念的,这里不会对其具体实现 ...
- Java性能调优实战,覆盖80%以上调优场景
Java 性能调优对于每一个奋战在开发一线的技术人来说,随着系统访问量的增加.代码的臃肿,各种性能问题便会层出不穷. 日渐复杂的系统,错综复杂的性能调优,都对Java工程师的技术广度和技术深度提出了更 ...
- Spring(一)简介和配置
知识补充: 那么什么是xmlns呢?xmlns其实是XML Namespace的缩写,可译为"XML命名空间",但个人觉得,翻译后的名字反而不好理解,所以我们就叫它为XML Nam ...
- kube-batch 创建的pod 一直是Pending
官网的例子 apiVersion: batch/v1 kind: Job metadata: name: qj-1 spec: backoffLimit: 6 completions: 6 paral ...