Jenkins-Pipeline简述

一. 什么是Jenkins pipeline:

         pipeline在jenkins中是一套插件,主要功能在于,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂发布流程。Pipeline的实现方式是一套Groovy DSL,任何发布流程都可以表述为一段Groovy脚本(jenkinsfile),并且Jenkins支持从代码库直接读取脚本。

二. 关于pipeline :

1. 相关概念: 

Step
    单一任务,从基础中告诉了Jenkins应该怎么做。例如,要执行shell命令,请make使用以下sh步骤:sh 'make'。当插件扩展Pipeline DSL时,通常意味着插件已经实现了一个新的步骤。

Node
    Pipeline执行中的大部分工作都是在一个或多个声明node步骤的上下文中完成的。将工作限制在Node步骤中有两件事情:
    通过将项目添加到Jenkins队列来调度要运行的块中包含的步骤。一旦执行器在节点上空闲,步骤就会运行。
    创建工作区(特定于该特定Pipeline的目录),可以从源代码控制中检出的文件完成工作。
    根据您的Jenkins配置,某些工作空间在一段时间不活动后可能无法自动清除。

Stage
    stage是定义整个Pipeline的概念上不同子集的一个步骤,例如:“Build”,“Test”和“Deploy”,许多插件用于可视化或呈现Jenkins Pipeline状态/进度。

pipeline 优势:

  通过写代码的形式配置Project,且Jenkins中内置了常用的steps。
  实现构建步骤代码化、构建过程视图化。

三. Jenkinsfile 定义格式(eg):

pipeline {
    agent {              #agent 在哪个node中执行相关任务(默认master),通过label和node上的label进行匹配
         label 'test'
    } 

    stages {             
        stage('Build') {   #stage:组成整个pipeline的阶段(自定义功能切分)
            steps {        #steps: 描述stage中的小步骤,同一个stage中的steps可以并行
                sh 'make'  #sh:执行指定的shell命令(make)
            }
        }
        stage('Sanity check') {
             steps {
                  input "Does the staging environment check?"   #input:手动确认,才会执行后续环节
             }
        }
        stage('Test'){
            steps {
                sh 'make check'
                junit 'reports/**/*.xml' #junit: JUnit plugin插件提供的pipeline步骤,用于汇总测试报告 
            }
        }
        stage('Deploy') {
            steps {
                sh 'make publish'
            }
        }
    }
}

四. pipeline, 流程:

五. pipeline 自动生成代码片段:

      Pipeline配有内置的文档功能,可以更轻松地创建不同复杂性的Pipeline。根据Jenkins实例中安装的插件自动生成和更新内置文档。

     内置的“Snippet Generator”实用程序有助于为单个步骤创建一些代码,发现插件提供的新步骤,或为特定步骤尝试不同的参数。

如下: 自动生成发邮件的stage:

六. pipeline  全局变量:

      除了代码片段生成器之外,Pipeline还提供了一个内置的“ 全局变量引用”。像Snippet Generator一样,它也是由插件动态填充的。与代码段生成器不同的是,全局变量引用仅包含Pipeline提供的变量的文档,这些变量可用于Pipeline。

    pipeline默认变量为:       

ENV
    脚本化Pipeline可访问的环境变量,例如: env.PATH或env.BUILD_ID。请参阅内置的全局变量参考 ,以获取管道中可用的完整和最新的环境变量列表。

PARAMS
    将为Pipeline定义的所有参数公开为只读 地图,例如params.MY_PARAM_NAME。

currentBuild
    可用于发现有关当前正在执行的Pipeline信息,与如属性currentBuild.result,currentBuild.displayName等等请教内置的全局变量引用 了一个完整的,而且是最新的,可用的属性列表currentBuild。

 详细情况可通过自己部署的服务页面查看。

### 使用 Jenkins Pipeline 自动构建 Docker 镜像 为了实现自动化构建 Docker 镜像,可以利用 Jenkins 的强大功能以及特定插件的支持来简化流程。通过配置合适的 Jenkins Pipeline 脚本,能够高效完成这一目标。 #### 插件支持 Jenkins Pipeline Docker 插件扩展了管道的功能,提供了对 Docker 图像和容器的一流支持[^1]。这使得 Jenkins 可以方便地创建/发布 Docker 镜像,并能充分利用 Docker 容器作为可定制化且一致性的代理环境。 #### 实现自动化的具体方法 下面是一个简单的 `Jenkinsfile` 示例,展示了如何定义一个多阶段的流水线用于自动构建并推送 Docker 镜像: ```groovy pipeline { agent any environment { DOCKER_IMAGE_NAME = 'your-docker-image-name' DOCKER_TAG = "latest" } stages { stage('Checkout') { steps { git url: 'https://github.com/user/repo.git', branch: 'main' } } stage('Build Docker Image') { steps { script { docker.build("${env.DOCKER_IMAGE_NAME}:${env.DOCKER_TAG}") } } } stage('Push Docker Image') { when { expression { return env.BRANCH_NAME ==~ /^(master|main)$/ } } steps { script { docker.withRegistry('https://registry.hub.docker.com', 'docker-hub-credentials-id') { docker.image("${env.DOCKER_IMAGE_NAME}:${env.DOCKER_TAG}").push() } } } } } post { always { cleanWs() // 清理工作空间 } } } ``` 此脚本实现了几个重要操作: - **检出源码**:从 Git 仓库拉取最新代码。 - **构建镜像**:基于项目中的 Dockerfile 构建一个新的 Docker 镜像。 - **推送到注册表**:仅当分支为主干(如 master 或 main)时才执行推送动作;这里假设已经设置了相应的凭证 ID 来访问私有的或公共的 Docker 注册中心。 #### 进入指定容器的操作命令 对于某些情况下可能需要直接与运行中的容器交互的情况,可以通过如下命令进入正在运行的容器内部进行调试或其他目的[^3]: ```bash [root@localhost ~]# docker exec -it <container_id> "/bin/bash" ``` 上述过程提供了一种有效的方式,在 CI/CD 流程中集成 Docker 镜像的自动化构建与部署机制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值