使用Gitlab构建简单流水线CI/CD

11 篇文章 1 订阅

什么是Gitlab

Gitlab实质上是一套DevOps工具

在这里插入图片描述

目前看起来,Gitlab属于是内嵌了一套CI/CD的框架,并且可以提供软件开发中的版本管理、项目管理等等其他功能。

这里需要辨别一下Gitlab和Github Gitee的区别。

GIthub大家都很熟悉了,一般大家都会去里面淘一些开源项目或工具代码,来快速实现一些功能。Gitee与之类似。我觉得属于是开源项目托管平台。

Gitlab不一样,他本质上是工具软件,虽然我注册的免费账号,也可以给每个库2G的存储空间,开源多人协作软件项目,但不是像Github那样的大市场。除了注册云服务账号,也可以在本地安装Gitlab的框架,或者在公司内网搭建Gitlab。 自己搭建一套Gitlab, 对企业而言,就非常诱人。

另外,值得一提的是,Gitlab自己内嵌了一套CI/CD工具

我早就听说过CI/CD。但是干汽车电子和软件的大家都知道,面向嵌入式开发,特别是在Adaptive Platform 和SOC兴起之前,DevOps往往Dev都没实现自动化,根本Ops不起来。以前虽然接触过Jenkins的概念,但是没有深入研究。这次终于有机会接触Gitlab,就跳过Jekings这个老头直接来摆弄一下Gitlab的流水线。

GitLab Runner

Runner 是CI/CD中的打工人,也就是在CI/CD过程中每个Job的执行者。

在实现上,可以是云端共享的docker, 也可以是公司内搭建的服务器,甚至可以是自己PC上运行的虚拟机。

我这边就是在自己的虚拟机里安装了Runner。来实现自动编译。Runner在Linux系统中的表现为,下载一套Runner的程序并安装成为系统服务,,新建一个Linux账号供Runner使用,然后在CI/CD中的的git工程会load到Runner的文件系统中,然后执行配置文件中的指令。在安装Runner的过程中,会选择执行器,我选择的Shell. 那么应该就是调用了bash来执行传递给Runner的指令。

除了自己安装Runner来注册到项目给项目使用,像我注册的带云服务的账号,可以使用公用Runner。目前免费账户好像是一个月给免费400分钟编译,但是我编译了个Helloworld.cpp就用了差不多1分钟。可能真的用于开发还是需要自己搭建本地的Runner.

在这里插入图片描述

具体安装Runner的方式可以参照Gitlab工程网页中的指导或者官方文档。

.gitlab-ci.yml 文件

这个文件是CI的配置文件,在项目没有新建流水线的时候,可以从流水线设置那里进入,直接套用模板,新建一个配置文件,
C++模板文件如下:

# This file is a template, and might need editing before it works on your project.
# You can copy and paste this template into a new `.gitlab-ci.yml` file.
# You should not add this template to an existing `.gitlab-ci.yml` file by using the `include:` keyword.
#
# To contribute improvements to CI/CD templates, please follow the Development guide at:
# https://docs.gitlab.com/ee/development/cicd/templates.html
# This specific template is located at:
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/C++.gitlab-ci.yml
# use the official gcc image, based on debian
# can use versions as well, like gcc:5.2
# see https://hub.docker.com/_/gcc/
image: gcc
build:
  stage: build
  # instead of calling g++ directly you can also use some build toolkit like make
  # install the necessary build tools when needed
  # before_script:
  #   - apt update && apt -y install make autoconf
  script:
    - g++ helloworld.cpp -o mybinary
  artifacts:
    paths:
      - mybinary
      # depending on your build setup it's most likely a good idea to cache outputs to reduce the build time
      # cache:
      #   paths:
      #     - "*.o"
# run tests using the binary built before
test:
  stage: test
  script:
    - ./runmytests.sh
deploy:
  stage: deploy
  script: echo "Define your deployment script!"
  environment: production

上述文件有官方文档描述语法,这里简要记录一下解析:

image: gcc 

表示启动这个Docker Runner,当然是里面包含GCC编译套件的。

如果是本地安装的Runner,不是使用Docker, 可以不需要这一句。

build:
  stage: build

表示定义一个job,名字叫build, 另外这个job处于stage build中。
stage会按照定义的先后顺序执行,在一个stage内部,如果没有needs这样的关键字来约束,
job会并行执行。

在这里插入图片描述

script:
   - g++ helloworld.cpp -o mybinary

表示在这个job内会传递给Runner的指令脚本。
可以看出,前面我配置Runner的执行器为Shell,这里就直接传递shell指令就行了,就跟在本机Linux上一步一步编译一样。

  artifacts:
    paths:
      - mybinary

这个是表示流水线产物,也就是可以在每一个job后下载的内容。
这里通过指定路径,可以把满足路径(正则匹配也可以)的内容收集上传附在流水线后,作为流水线产物。

我觉得这个产物可以附上编译的可执行文件或者运行测试生成的测试报告。

流水线触发

默认在每次git提交的时候,就会触发流水线执行。

也可以修改配置文件,让满足不同条件触发。

当然也可以手动触发执行。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Jenkins、GitLab和Kubernetes是三个常用的开源工具。它们能够相互协作形成一个完整的构建自动化CI/CD发布流水线。 首先,开发者在GitLab的代码仓库中提交代码,触发GitLab的Webhook,告知Jenkins需要进行构建。 接下来,Jenkins开始执行构建任务,它会拉取GitLab中的代码仓库,并在Kubernetes集群中创建一个构建环境。在构建环境中,Jenkins会进行一些构建工作,如编译代码、运行测试、打包程序等。 当Jenkins构建成功后,它会将构建好的程序镜像推送到Kubernetes上,Kubernetes将在自己的集群中创建一个新的Pod,并将新的程序部署到这个Pod中。当程序运行成功后,Kubernetes自动更新负载均衡器路由。 这样,整个构建自动化CI/CD发布流水线就完成了,从代码仓库提交到程序部署,全部都是自动完成的,可以大大提高开发效率,减少出错的可能性。同时,由于使用了Kubernetes,可以实现水平扩展和高可用性,保证了程序稳定运行。 ### 回答2: Jenkins、GitLab和Kubernetes(k8s)是如今广泛应用于软件开发和部署的热门工具。这三个工具的结合,为软件开发的自动化构建、持续集成和持续交付(CI/CD)提供了更加高效、可靠的方法。 当我们考虑如何将这三个工具集成到一起时,以下是一种建议的CI/CD发布流水线: 1. GitLab仓库维护代码版本控制 GitLab是一个代码托管平台,它提供了完整的Git存储库管理工具,包括代码审查、问题跟踪和持续集成。我们可以在GitLab中设置一个仓库,用于维护我们的应用程序代码。我们的代码将被存储在该仓库中,可以利用GitLab提供的版本控制和分支管理功能方便地进行协作和开发。 2. Jenkins构建应用程序 Jenkins是一个流行的自动化构建工具,它可以与GitLab集成,以便在GitLab存储库的变更上触发自动化构建。Jenkins从GitLab仓库中获取代码并自动构建我们的应用程序。如果构建成功,则可以将构建后的应用程序存储在构建存储库或者将其部署到Kubernetes集群中,否则通知开发者维护代码。 3. 部署到Kubernetes集群 Kubernetes (k8s)是一个开源容器编排管理器,它可以帮助我们管理和部署容器化的应用程序。我们可以将我们的应用程序容器化,并将其部署到Kubernetes集群上,这将为我们提供高可用性、可伸缩性和自动化容器调度等好处。 我们可以使用Kubernetes的K8s自动化部署工具,以通过各种环境阶段(测试、预生产和生产)自动部署容器化应用程序的不同副本,从而完成全面部署。 4. 自动化测试应用程序 在部署应用程序部署之前,应使用不同的测试阶段对其进行测试,包括单元测试、集成测试和端到端测试。在一个CI/CD管道中,我们可以添加多个虚拟机代表不同的测试阶段,来自动化测试应用程序。如果某种类型的测试失败,则将在构建次数的下面进行记录和报警,以便修复应用程序中的问题。 通过使用上述流程,我们可以实现一个自动化构建和部署的CI/CD流水线,从而形成一个协调的工具链集成,使软件开发活动化和规范化。这将为我们提供更高效、可靠的开发和部署环境,从而缩短开发周期、减少对人力的依赖,以及提高应用程序质量和交付速度。同时,我们的代码将始终被版本控制,让我们随时翻查历史,充分发掘之前的知识和经验。 ### 回答3: 现代软件开发过程中,持续集成、持续交付和持续部署成为了不可或缺的重要环节,对于构建自动化 CI/CD 发布流水线使用 Jenkins、GitLab 和 Kubernetes 是目前主流的选择。 Jenkins 是最经典的自动化构建工具之一,它可以无缝集成 GitLab,实现代码检出、运行测试、打包构建、发布部署等操作。此外,Jenkins 也支持插件化的扩展,可以方便的与第三方工具进行集成并自动化构建。对于 Jenkins,我们需要建立一个 Jenkins 服务器,配置好 GitLab 仓库的访问权限,并在 Jenkins 中配置 WebHook,使其能够接收 GitLab 代码提交的通知触发自动化构建GitLab 是一款完整的 CI/CD 工具链,除了支持源码管理、合并请求和协作功能外,还内置了 CI/CD 功能,可以集成测试、构建、发布等自动化流程。与 Jenkins 集成,可以实现更强大的自动化构建和交付流程。我们需要在 GitLab 项目中配置自动化构建流水线,并在相对应的流程中配置 Jenkins 以触发相关的构建、测试和发布操作。 Kubernetes 是一款流行的容器编排及部署工具,可以极大地简化应用程序的部署和扩展。对于自动化构建和交付,Kubernetes 的作用在于将应用程序打包为 Docker 镜像,然后自动部署到云端集群环境中,完成持续部署的流程。我们需要在 Kubernetes 中配置相应的应用程序部署文件,并将其注册到 Kubernetes 集群中,以便实现自动化部署和发布。通常我们需要部署 Kubernetes 应用程序的一个运行环境,如 Harbor 仓库,容器运行时等。 在应用程序的构建和交付过程中,最重要的是持续监测和优化,我们需要使用可视化和统一的工具来监测应用程序的性能和健康状况。对于这个目的,我们可以选择一些可视化的 APM 工具,如 New Relic,将其集成到我们的 CI/CD 流程中,以监测和优化应用程序的性能。此外,我们也可以使用一些 CI/CD 管理平台,例如 Jenkins X,来简化整个流程,并提供一个更全面的工具来监测和管理应用程序的构建和交付流程。 总之,构建自动化 CI/CD 发布流水线是现代软件开发的必要环节,使用 Jenkins、GitLab 和 Kubernetes 可以大大简化这个过程,提高开发流程的自动化和效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小羊苏C

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值