9.Devops实战篇之——流水线pipeline
Jenkins-pipeline实践
目录
1. 认识pipeline
#想要快速定位出现的问题,上面的这种自定义风格的项目是很难做到的,因为日志都打印在一个面上。所以需要流水线。
#体验流水线
#可以很清晰的看到每个流程执行的时间和结果。
#我们要做的就是把我们 第1-第8 之前实现的每一个步骤,都按照流水线的形式来完成。
2. 流水线语法
#想要构建流水线,就需要先了解它的语法
//所有脚本命令都放在pipeline中
pipeline {
//jenkins可以做集群,这里是选择哪个jenkins节点来构建任务
agent any
//声明全局变量,方便后面使用
environment {
key = 'value'
}
//主体。具体每个阶段的任务定义
stages {
stage('拉取gitlab仓库代码') {
steps {
echo '拉取gitlab仓库代码 - 成功'
}
}
stage('maven构建项目') {
steps {
echo 'maven构建项目 - 成功'
}
}
stage('sonarqube代码检测') {
steps {
echo 'sonarqube代码检测 - 成功'
}
}
stage('jenkins制作自定义镜像并推送到harbor') {
steps {
echo 'jenkins制作自定义镜像并推送到harbor - 成功'
}
}
stage('jenkins通知服务器拉取镜像并运行') {
steps {
echo 'jenkins通知服务器拉取镜像并运行 - 成功'
}
}
}
}
#写在pipeline script中,立即构建
3. 流水线语法生成
#例如”拉取gitlab仓库代码“步骤
##
#把生成的语法放到具体的stage.steps里面即可。
4. jenkins脚本语法维护
#在jenkins端的脚本维护是比较麻烦的。这里我们选用流水线每次构建的时候,从git拉取jenkinsfile文件进行构建。
#在git仓库中追加一个名为Jenkinsfile的文件
#把流水线脚本放到里面即可。这样每次构建会先拉取这个文件,根据此文件进行构建。
#再次构建即可看到
5.pipeline具体实现
5.1 pipeline拉取gitlab代码
#这里我们还是要根据标签来拉取代码
#在我们之前生成的git拉取代码流水线语法中复制,写到到giltlab仓库的Jenkinsfile中。
#写入,注意我们使用了变量tag,来拉取对应代码。
#再次build,就会根据版本。
5.2 pipeline-maven构建项目
#构建项目无非就是执行shell命令
#生成pipeline脚本,再放到gitlab上的Jenkinsfile文件里。
sh '/var/jenkins_home/maven/bin/mvn clean package -DskipTests'
#构建如果出现这样的问题
#我们也可以手动去容器内部执行mvn clean package -DskipTests命令测试构建,也会失败。
#mvn -v出来显示java的版本是17那肯定是构建不了的,因为我们的IDEA是2024的最新版本,用的是jdk22。
#所以最后是因为jenkins容器内部JAVA_HOME指定的位置不是我们安装的jdk-22版本。在容器内部改过来即可。或者在docker-compose.yml就写好这个环境变量。
export JAVA_HOME=/var/jenkins_home/jdk
#再次构建即可
jenkins@dbab3d17884d:~/workspace/pipeline$ ls target/*.jar
target/mytest1.jar
5.3 pipeline-sonarqube代码测试
#基于sonar-scanner
#生成脚本,放到Jenkinsfile中
##
#再次构建即可
5.4 pipeline-jenkins构建镜像
#推送镜像这边,如果仓库地址写固定的,后期修改会很麻烦。所以在Jenkinsfile去定义环境变量,进行调用即可。
environment {
harborUser = 'admin'
harborPasswd = 'Harbor12345'
harborAddress = '192.168.64.21:80'
harborRepo = 'repo'
}
#生成构建和推送脚本写到Jenkinsfile
mv ./target/*.jar ./docker/
docker build -t ${JOB_NAME}:${tag} ./docker/
docker login -u ${harborUser} -p ${harborPasswd} ${harborAddress}
docker tag ${JOB_NAME}:${tag} ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}
docker push ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}
docker image prune -f
#构建之后。验证一下
5.5 pipeline-通知服务器拉取镜像并运行
#publish over ssh
#先声明一下字符参数,等下引用
#生成流水线脚本,添加到Jenkinsfile
#生成脚本
sshPublisher(publishers: [sshPublisherDesc(configName: 'node1', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: "deploy.sh $harborAddress $harborRepo $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)])
#改为双引号!!!
#开始构建。最后我们就完成了从自由风格转变到pipeline的配置。
#其实都是差不多的一套东西,但流水线更清晰
##
5.6 jinkins发送外部通知
#下载钉钉插件
#钉钉群添加自定义机器人,关键字:部署
#Jenkins——系统管理——钉钉配置
#有了机器人以后就就可以写pipeline脚本了,因为自动生成是出不来的。
#每个插件不同版本有不同的使用方式,详细看文档
##
post {
success {
dingtalk(
robot: 'jenkins-ding',
type: 'MARKDOWN',
title: 'success: ${JOB_NAME}',
text: [ "- 构建成功: ${JOB_NAME} \n- 版本号: ${tag} \n- 构建持续时间: ${currentBuild.durationString}" ]
)
}
failure {
dingtalk(
robot: 'jenkins-ding',
type: 'MARKDOWN',
title: 'failure: ${JOB_NAME}',
text: [ "- 构建成功: ${JOB_NAME} \n- 版本号: ${tag} \n- 构建持续时间: ${currentBuild.durationString}" ]
)
}
}
#再次构建,如果失败显示语法错误,重启jenkins即可。
#Jenkinsfile全部内容如下
//所有脚本命令都放在pipeline中
pipeline {
//jenkins可以做集群,这里是选择哪个jenkins节点来构建任务
agent any
//声明全局变量,方便后面使用
environment {
harborUser = 'admin'
harborPasswd = 'Harbor12345'
harborAddress = '192.168.64.21:80'
harborRepo = 'repo'
}
//主体。具体每个阶段的任务定义
stages {
stage('拉取gitlab仓库代码') {
steps {
checkout scmGit(branches: [[name: '${tag}']], extensions: [], userRemoteConfigs: [[url: 'http://192.168.64.20:8929/root/test2.git']])
echo '拉取gitlab仓库代码 - 成功'
}
}
stage('maven构建项目') {
steps {
sh '/var/jenkins_home/maven/bin/mvn clean package -DskipTests'
echo 'maven构建项目 - 成功'
}
}
stage('sonarqube代码检测') {
steps {
sh '/var/jenkins_home/sonar-scanner/bin/sonar-scanner -Dsonar.sources=./ -Dsonar.projectname=${JOB_NAME} -Dsonar.java.binaries=./target/ -Dsonar.projectKey=${JOB_NAME} -Dsonar.login=sqa_8ad59a82479f82e3b9068e7bee530fc8e01f04e5'
echo 'sonarqube代码检测 - 成功'
}
}
stage('jenkins制作自定义镜像并推送到harbor') {
steps {
sh '''mv ./target/*.jar ./docker/
docker build -t ${JOB_NAME}:${tag} ./docker/
docker login -u ${harborUser} -p ${harborPasswd} ${harborAddress}
docker tag ${JOB_NAME}:${tag} ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}
docker push ${harborAddress}/${harborRepo}/${JOB_NAME}:${tag}'''
echo 'jenkins制作自定义镜像并推送到harbor - 成功'
}
}
stage('jenkins通知服务器拉取镜像并运行') {
steps {
sshPublisher(publishers: [sshPublisherDesc(configName: 'node1', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: "deploy.sh $harborAddress $harborRepo $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)])
echo 'jenkins通知服务器拉取镜像并运行 - 成功'
}
}
}
post {
success {
dingtalk(
robot: 'jenkins-ding',
type: 'MARKDOWN',
title: 'success: ${JOB_NAME}',
text: [ "- 构建成功: ${JOB_NAME} \n- 版本号: ${tag} \n- 构建持续时间: ${currentBuild.durationString}" ]
)
}
failure {
dingtalk(
robot: 'jenkins-ding',
type: 'MARKDOWN',
title: 'failure: ${JOB_NAME}',
text: [ "- 构建失败: ${JOB_NAME} \n- 版本号: ${tag} \n- 构建持续时间: ${currentBuild.durationString}" ]
)
}
}
}
更多推荐
所有评论(0)