- Pipeline是什么
Pipeline,简单来说,就是一套运行在 Jenkins 上的工作流框架,将原来独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排和可视化的工作。
- 使用Pipeline的好处
代码:Pipeline以代码的形式实现,通常被检入源代码控制,使团队能够编辑,审查和迭代其传送流程。
持久:无论是计划内的还是计划外的服务器重启,Pipeline都是可恢复的。
可停止:Pipeline可接收交互式输入,以确定是否继续执行Pipeline。
多功能:Pipeline支持现实世界中复杂的持续交付要求。它支持fork/join、循环执行,并行执行任务的功能。
可扩展:Pipeline插件支持其DSL的自定义扩展 ,以及与其他插件集成的多个选项。
- 创建 Jenkins Pipeline
- Pipeline 脚本是由 Groovy 语言实现的,但是我们没必要单独去学习 Groovy。
- Pipeline 支持两种语法:Declarative(声明式)和 Scripted Pipeline(脚本式)语法。
- Pipeline 也有两种创建方法:
- 可以直接在 Jenkins 的 Web UI 界面中输入脚本。
- 也可以通过创建一个 Jenkinsfile 脚本文件放入项目源码库中(一般我们都推荐在 Jenkins 中直接从源代码控制(SCM)中直接载入 Jenkinsfile Pipeline 这种方法)。
3.1 新建流水线任务
3.2 添加流水线脚本
3.2.1 生成脚本
生成流水线脚本
指定位置选择对应的步奏生成流水线语法就可以了. 但是由于不通的项目需要经常调整pipeline脚本.所以我们推荐使用jenkinsfile的方式来维护脚本文件.这样的话每个项目就各自有一份了
放在项目的根目录下面
选择git的方式拉取jenkinsfile文件进行流水线构建.
再次构建发现了流水线流程
3.2.2 Git参数化构建
修改git拉去的pipeline脚本
checkout(
[$class: 'GitSCM', branches: [[name: '${tag}']], extensions: [],
userRemoteConfigs:
[[url: 'https://github.com/wornxiao/springboot-hello.git']]])
3.2.3 maven 构建
3.2.4 制作镜像
3.2.5 自定义对象推送到harbor仓库
3.2.6 通知目标服务器执行
添加两个参数化构建参数 host_port & container_port
3.3 构建任务
由于中途有一些构建失败对脚本做了一些调整最终脚本如下
pipeline{
//指定用集群中的哪个节点
agent any
//声明全局变量
environment {
harbor_name = 'admin'
harbor_pass ='Harbor12345'
harbor_addr = '192.168.189.129:8081'
harbor_repo = 'wornxiao'
}
stages{
stage('拉取git仓库代码'){
steps{
checkout([$class: 'GitSCM', branches: [[name: '${tag}']], extensions: [], userRemoteConfigs: [[url: 'https://github.com/wornxiao/springboot-hello.git']]])
}
}
stage('通过maven构建项目'){
steps{
sh 'mvn clean package -DskipTest'
}
}
stage('通过sonarQuebe做质量检测'){
steps{
echo '通过sonarQuebe做质量检查'
}
}
stage('通过docker制作自定义镜像'){
steps{
sh '''mv target/*.jar ./docker
docker build -t ${JOB_NAME}:$tag docker '''
}
}
stage('将自定义对象推送到harbor仓库中'){
steps{
sh '''docker login -u ${harbor_name} -p ${harbor_pass} ${harbor_addr}
docker tag ${JOB_NAME}:${tag} ${harbor_addr}/${harbor_repo}/${JOB_NAME}:${tag}
docker push ${harbor_addr}/${harbor_repo}/${JOB_NAME}:${tag}'''
}
}
stage('通过Publish Over SSH 通知目标主机'){
steps{
sshPublisher(publishers: [sshPublisherDesc(configName: 'app_host', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '''cd /data/app
./deploy.sh 192.168.189.129:8081 wornxiao $JOB_NAME $tag $host_port $container_port''', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)]) }
}
}
}