- 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.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
文章图片
文章图片
【云原生|DevOps(二) Jenkins实现Pipeline流水线 CI/CD】
文章图片
文章图片
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)])}
}
}
}
推荐阅读
- 负载均衡|nacos 负载均衡ribbon 轮询策略 权重2种方式
- docker|docker基础学习笔记
- 云计算|基于 K8S 构建数据中心操作系统
- #|「SpringCloud」08 Config分布式配置中心
- #|「SpringCloud」07 Gateway服务网关
- #|「SpringCloud」09 Bus消息总线
- 项目|【项目】SpringCloud+Nginx+Redis+RabbitMQ秒杀系统
- kubernetes|Kubernetes权威指南第5版(从Docker到Kubernetes实践全接触)
- 云原生|手写一个Kubernetes CNI网络插件