jenkins pipline 和 jenkinsfile

Jenkins Pipeline(或简称为 "Pipeline")是一套插件,将持续交付的实现和实施集成到 Jenkins 中。
Jenkins Pipeline 提供了一套可扩展的工具,用于将“简单到复杂”的交付流程实现为“持续交付即代码”。Jenkins Pipeline 的定义通常被写入到一个文本文件(称为Jenkinsfile)中,该文件可以被放入项目的源代码控制库中。
Jenkinsfile 是 Jenkins 2.x 核心特性 Pipeline 的脚本,由Groovy语言实现。
jenkinsfile 能使用两种语法进行编写 - 声明式和脚本化。
声明式和脚本化的流水线从根本上是不同的。 声明式流水线的是 Jenkins 流水线更近的特性:

  • 相比脚本化的流水线语法,它提供更丰富的语法特性,
  • 是为了使编写和读取流水线代码更容易而设计的。
pipeline {
    agent any
    stages {
        stage('Build') {
            steps {
                //
            }
        }
        stage('Test') {
            steps {
                //
            }
        }
        stage('Deploy') {
            steps {
                //
            }
        }
    }
}
node { 
    stage('Build') {
        //
    }
    stage('Test') {
        //
    }
    stage('Deploy') {
        //
    }
}

下面将以声明式脚本为例,介绍jenkinsfile:
#设置运行的agent

pipeline {
agent {label 'jenkins-slave'} // 配置构建项目在标签为jenkins-slave的机器上运行
.....
使用多个agent

pipeline {
    agent none
    stages {
        stage('Build') {
            agent any
            steps {
               echo "build..."
            }
        }
        stage('Test on Linux') {
            agent {
                label 'linux'
            }
            steps {
               echo "test..."
            }

#配置可选参数
agent any
options{
       disableConcurrentBuilds() //不允许同时执行流水线
       skipDefaultCheckout() //在`agent` 指令中,跳过从源代码控制中检出代码的默认情况
       timeout(time: 10, unit: 'MINUTES') //设置流水线运行的超时时间
       timestamps() //预定义由Pipeline生成的所有控制台输出时间
}
.....

#配置全局变量
environment {
      service="java"
}
.....
#配置局部变量
stage('Deploy'){
   steps {
       withEnv(['service=java']){
       echo '$service'
}}}

#配置可选参数
parameters{
     string(name: 'branch', defaultValue: 'dev', description: 'which branch do you want to build?')
     choice(name: 'service',choices:"java\nnodejs",description: "服务名")
     choice(name: 'gitrepo',choices:"java\nnodejs",description: "仓库地址")
}

#配置机密文本、用户名和密码
stage('Deploy'){
steps {
     withCredentials([usernamePassword(credentialsId: 'aliyun_oss_upload', passwordVariable: 'aliyun_sceret', usernameVariable: 'aliyun_key')]) {
     sh '~/ossutil config -e ${endpoint} -i ${aliyun_key} -k ${aliyun_sceret};~/ossutil cp -r -f dist "oss://${name}"'
}}}
注:需先在jenkins添加用户凭据

#拉取代码
stage('Checkout') {
steps {
         checkout([$class: 'GitSCM', branches: [[name: '*/${branch}']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: '3', url: 'ssh://git@giturl/javacode.git']]])
}
}
#在job中点击Pipline Syntax ,选择checkout out from version control ,选择git输入仓库地址,生成拉取代码配置

#定义构建完成后执行动作

 

post {
       success {
           echo '构建成功'
       }
       failure {
           echo '构建失败'
       }
       unstable {
           echo '该任务被标记为不稳定任务'
       }
       aborted {
           echo '该任务被终止'
       }
   }

#条件判断

 

stage('Build'){
  steps {
    script {
      if ("${gitrepo}" == "java") {
                         echo "java"
      }        
      else if ("${gitrepo}" == "python"){
         echo "python"
      } else {
         echo "nodejs"
       }
      }           
  }
}

#if 需定义在script{}内

 

#获取命令返回值

stage('Push'){
  steps {
    script{
    def pid = sh returnStatus: true, script: " ps -ef|grep tomcat|awk '{print \$2}'"
    echo '$pid'
  }  
  }
}

 

posted @ 2023-10-12 14:10  imcati  阅读(24)  评论(0编辑  收藏  举报