使用 Jenkins 构建 CI/CD 之多分支流水线_Multibranch ?

介绍


由于公司的 Jenkins 配置没有部署成功的通知,在我学了几天的 Jenkins 后终于是对公司的 Jenkins 配置下手了,结果我刚装完 dingtalk 插件自动重启后,发现之前主管配置的构建项目数据都丢失了,正好给了我练手的机会,于是就有了以下从0到1的辛酸历程。

在 Docker 中安装并运行 Jenkins


这里假设你的服务器已经装好了docker

使用的镜像是 jenkinsci/blueocean,这是一个 Jenkins 的稳定及持续维护的镜像源,本身就集成了 Blue Ocean 等使用插件,非常方便。

拉取镜像

docker pull jenkinsci/blueocean
运行 Jenkins

docker run -idt --name kmywjenkins -p 9090:8080 -p 60000:50000 -v jenkins-data:/var/jenkins_home -v /data/web-data/docker.sock:/var/run/docker.sock jenkinsci/blueocean
参数解释:

  • -idt 以交互的方式、新建一个模拟终端运行容器
  • –name 容器的别名
  • -p 指定容器映射宿主机的端口 -> 宿主机端口:容器端口
  • -v jenkins-data:/var/jenkins_home Jenkins容器在工作的时候,如果要执行Docker的命令(例如 docker ps、docker run等),需要有个途径能连接到宿主机的docker服务,此参数就是用来建立容器和宿主机docker服务的连接的
  • -v /data/web-data/docker.sock:/var/run/docker.sock 将该容器的数据保留在宿主机的目录,这样即使容器崩溃了,里面的配置和任务都不会丢失

需要注意的是,docker 中默认是以 Jenkins 用户运行的 Jenkins,如需以 root 用户可以加参数 -u root,本示例未指定 root。

访问 Jenkins Docker 容器


有时候需要进入 Jenkins 容器执行一些命令,可以通过 docker exec 命令访问,例如:

docker exec -it [containerid] bash

若要手动重启 Jenkins,可以执行以下命令:

docker restart [containerid]

Jenkins 基本配置


通过以上步骤,如果正常走到这里,可以通过以下地址访问http://xxx.xxx.xx.xx:9090/,IP 地址为服务器的地址。

解锁 Jenkins

输入一下命令获取解锁的 token,

docker exec kmywjenkins cat /var/jenkins_home/secrets/initialAdminPassword

在浏览器中输入对应的 token 以解锁:

在这里插入图片描述

创建凭据

连接 git 仓库,ssh 连接服务器均需要相应的凭据,可以在凭据管理中先创建好,然后需要使用的地方直接选择凭据即可。这里以连接git、ssh需要的凭据为例:

我司用得版本管理工具是 gitte,以 gitte 为例,其它版本管理工具配置也一样
类型选择 Username with password,用户名密码为登录 gitte 的账号密码,ID 是凭据的唯一标识,可自定义,后面在 JenkinsFile 中通过 ID 去引用凭据。
在这里插入图片描述

SSH 连接服务器时需要密钥,我们先在服务器生成一对公私钥,然后复制私钥,填入即可。类型选择 SSH Username with private key,Username 是连接服务器的用户名,如 Jenkins 在 Private Key 项选中 Enter directly,点击 Add,粘贴刚复制的私钥。
在这里插入图片描述

创建一个多分支流水线


之前的 Jenkins 任务是 FreeStyle 的方式创建的,这种方式不够灵活,界面也不够清爽,这里选择使用声明式流水线方式(Declarative Pipeline)创建,可以多分支独立构建,便于以后的扩展。
我们这里使用 BlueOcean 这种方式来完成此处 CI/CD 的工作,BlueOcean 是 Jenkins 团队从用户体验角度出发,专为 Jenkins Pipeline 重新设计的一套 UI 界面,仍然兼容以前的 fressstyle 类型的 job,BlueOcean 具有以下的一些特性:

  • 连续交付(CD)Pipeline 的复杂可视化,允许快速直观的了解 Pipeline 的状态
  • 可以通过 Pipeline 编辑器直观的创建 Pipeline
  • 需要干预或者出现问题时快速定位,BlueOcean 显示了 Pipeline 需要注意的地方,便于异常处理和提高生产力
  • 用于分支和拉取请求的本地集成可以在 GitHub 或者 Bitbucket 中与其他人进行代码协作时最大限度提高开发人员的生产力。

如果安装的是 Jenkinsci/blueocean 镜像,默认是已经集成了 BlueOcean,没有的可前往插件管理安装对应的插件。

在这里插入图片描述

点击打开Blue Ocean,可以看到已经创建好的两个流水线,分别是前端和后台,需要用到不同的工具,在后面会提到,如何创建流水线。
在这里插入图片描述

点击创建流水线


我司用的是gitte,所以选择Git,然后填入要连接的仓库地址,需要连接到Git仓库的凭据,我们之前已经创建好了,直接选中即可,如果未创建,在下面的表单直接编辑即可,最后点击创建流水线。
在这里插入图片描述

到这里我们就创建了一个多分支流水线,Jenkins 会扫描仓库,带有 JenkinsFile 的分支会被检测出来,JenkinFile 是多分支流水线的配置文件,使用的是 Groovy 语法,可以直接点击创建流水线,Jenkins 会自动为你的项目创建一个 JenkinsFile。
在这里插入图片描述
在这里插入图片描述

现在可以可视化地编辑想要执行的阶段及步骤,这里加了一个打包的阶段,里面有个步骤是提示开始打包,点击保存。

在这里插入图片描述

填入提交信息,点击 Save & Run,会讲 JenkinsFile 上传到 git,并根据 JenkinsFile 执行一个构建任务,目前的构建步骤只有一个,是提示开始打包。

在这里插入图片描述

我这里不知道为什么会卡在这个地方不动,所以我在 vscode 直接创建并编辑 JenkinsFile,这种方式更灵活,我更推荐这种方式,下面我会先简单介绍下 JeninsFile 的基础语法,仅包含本项目用到的,对于中小企业的构建需求,基本够用了。

JenkinsFile 基础语法


只需先了解大致的语法,具体的用法会在后面说明:

// 前端项目JenkinsFile配置,后端项目配置稍有不同,后面会区分说明
pipeline {
  agent any
  environment {
    HOST_TEST = 'root@121.41.16.183'
    HOST_ONLINE = 'jenkins@39.101.219.110'
    SOURCE_DIR = 'dist/*'
    TARGET_DIR = '/data/www/kuaimen-yunying-front'
  }
  parameters {
    choice(
      description: '你需要选择哪个环境进行部署 ?',
      name: 'env',
      choices: ['测试环境', '线上环境']
    )
    string(name: 'update', defaultValue: '', description: '本次更新内容?')
  }
  triggers {
    GenericTrigger(
     genericVariables: [
      [key: 'ref', value: '$.ref']
     ],
     causeString: 'Triggered on $ref',
     token: 'runcenter-front-q1w2e3r4t5',
     tokenCredentialId: '',
     printContributedVariables: true,
     printPostContent: true,
     silentResponse: false,
     regexpFilterText: '$ref',
     regexpFilterExpression: 'refs/heads/' + BRANCH_NAME
    )
  }
  stages {
    stage('获取git commit message') {
     steps {
       script {
         env.GIT_COMMIT_MSG = sh (script: 'git log -1 --pretty=%B ${GIT_COMMIT}', returnStdout: true).trim()
       }
     }
  }

    stage('打包') {
      steps {
        nodejs('nodejs-12.16') {
          echo '开始安装依赖'
          sh 'yarn'
          echo '开始打包'
          sh 'yarn run build'
        }
      }
    }

    stage('部署') {
      when {
        expression {
          params.env == '测试环境'
        }
      }
      steps {
        sshagent(credentials: ['km-test2']) {
          sh "ssh -o StrictHostKeyChecking=no ${HOST_TEST} uname -a"
          sh "scp -r ${SOURCE_DIR} ${HOST_TEST}:${TARGET_DIR}"
          sh 'echo "部署成功~"'
        }
      }
    }

    stage('发布') {
      when {
        expression {
          params.env == '线上环境'
        }
      }
      steps {
        sshagent(credentials: ['km-online']) {
          sh "ssh -o StrictHostKeyChecking=no ${HOST_ONLINE} uname -a"
          sh "scp -r ${SOURCE_DIR} ${HOST_ONLINE}:${TARGET_DIR}"
          sh 'echo "发布成功~"'
        }
      }
    }
  }

  post {
    success {
      dingtalk (
        robot: '77d4c82d-3794-4583-bc7f-556902fee6b0',
        type: 'MARKDOWN',
        atAll: true,
        title: '你有新的消息,请注意查收',
        text:[
          '# 运营管理系统发布通知',
          '---',
          '#### **所属:前端**',
          "#### **构建任务:${env.BUILD_DISPLAY_NAME}**",
          "#### **Git commit:${env.GIT_COMMIT_MSG}**",
          "#### **本次更新内容:${params.update}**",
          "#### **部署环境:${params.env}**",
          '#### **构建结果:成功**'
        ]
      )
    }
  }
}

  • pipeline 必须在最外层
  • agent 定义了在哪个环境里执行,默认any
  • stages 阶段,标识构建流程的标签块,子节点是stage
  • steps 执行步骤
  • post 所有阶段执行完成后执行一些逻辑
  • when 可以控制该阶段是否执行
  • environment 环境变量,在这里定义的变量,JenkinsFile的任何地方都可以访问
  • tools 项目使用到的构建工具,声明系统配置中已经定义好的工具,如maven
  • parameters 定义参数,可以提供用户输入或者选择
  • post 构建结束后会执行这里,有success、failure、success,本示例将在success(构建成功时)发起钉钉通知

https://www.code404.icu/1336.html
CSDN_码404:使用 Jenkins 构建 CI/CD 之多分支流水线_Multibranch ?

  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值