百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

一文学会jenkins pipline自动化构建

yuyutoo 2025-03-20 20:53 6 浏览 0 评论

中文在线文档:https://www.jenkins.io/zh/doc/book/pipeline/

还有一个:https://www.w3cschool.cn/jenkins/jenkins-qc8a28op.html



01 Pipeline流水线基本语法


  • 首先创建 在jenkins上创建一个pipeline的流水线任务新建ITEM-->选择流水线

  • 基本pipeline脚本结构
pipeline {    //agent 表示要执行的节点,any表示任意节点   
   agent any   
   //stages表示任务执行时的所有步骤集合   
   stages {       
         //stage就表示一个步骤,括号里是步骤名称       
         stage('拉取项目源码'){           
               //每一个stage都可以定义自己执行的节点,如果没定义,则用最上方的           
     agent {                // label 后跟的是节点的标签名称                label 'mall-server'       }            steps {                echo '这是拉取代码这一步'                echo "Running ${env.BUILD_ID} on ${env.JENKINS_URL} ${env.JOB_NAME}"                echo "${currentBuild.result} sdsdd"                sh 'pwd'                //如果当前节点是windows,我想执行windows下的命令                //bat 'dir'             }                     }                stage('静态代码扫描'){            steps {                echo '这是静态代码扫描'            }                            }                stage('单元测试'){            steps {                echo '执行jacoco单元测试'            }                   }                stage('打包依赖服务'){            steps {                echo '打包依赖服务'            }                   }                stage('打包当前服务'){            steps {                echo '打包当前服务'            }                   }                stage('部署环境'){            steps {                echo '部署环境'            }                   }                stage('接口自动化测试'){            agent {                label 'auto_test'                        }            steps {                echo '接口自动化测试'            }      
        }        stage('ui自动化'){            steps {                echo 'ui自动化'            }                           }    }}



02 针对mall微服务项目编写pipeline脚本


对于pipeline脚本来说我们不用去记那么多的东西,可以打开自己的pipeline任务,点击流水线语法后,使用下面两个菜单帮我们生成部分脚本


  • 对于一个项目来说可能具备多服务多环境的现象所以我们要创建环境节点参数、服务名称参数
    在pipeline脚本的最上方增加如下://定义了两组选项参数
    parameters {
    choice choices: ['mall-admin', 'mall-demo', 'mall-auth', 'mall-serach'], name:'servername'
    choice choices: ['mall-server', 'mall-dev', 'mall-prod'], name: 'node_env'
    }
    配好后先执行一次任务


  • 选择项目部署的节点因为部署的节点环境根据上一步的参数来的,用户选什么我们就执行什么,所以label的值是一个变量agent {
    label "${node_env}"}


  • 拉取项目代码
    拷贝生成的脚本,放在拉代码的阶段的steps下stage('拉取项目源码'){
    steps {
    echo '这是拉取代码这一步'
    git credentialsId: '4c1003ef-ac70-4271-8649-1759e79d430a', url: 'http://192.168.0.109/shamo/mall-swarm-master.git'
    }
    }


  • 单元测试覆盖率由于mall这个项目原本没有集成jacoco相关的覆盖率统计,因此我们先对项目做些修改

① 修改整个项目最根的pom.xml文件

false


② 修改各个子模块服务的pom.xml


      org.jacoco

      jacoco-maven-plugin     

      0.8.6

   

     org.jacoco   

     jacoco-maven-plugin  

     0.8.6   

            

           target/coverage-reports/jacoco-unit.exec

           target/coverage-reports/jacoco-unit.exec

        

             
 

                     

              jacoco-initialize    

                             

                   prepare-agent                      

                    

          
            
                     

             jacoco-site        

               
               
           
            test           

                           

                report           

                    

             

      

③ 编写pipeline


复制生成的jacoco指令,填入相应的steps里

stage('单元测试'){       steps {           
            echo '执行jacoco单元测试'           
            sh '''           
            cd "${servername}"           
            mvn test            
            '''           
            jacoco changeBuildStatus: true,
            maximumBranchCoverage: '100',
            maximumClassCoverage: '100',
            maximumComplexityCoverage: '100',
            maximumInstructionCoverage: '100',
            maximumLineCoverage: '100',
            maximumMethodCoverage: '100',
            minimumBranchCoverage: '90',
            minimumClassCoverage: '90',
            minimumComplexityCoverage: '90',
            minimumInstructionCoverage: '90',
            minimumLineCoverage: '90',
            minimumMethodCoverage: '90'       
        }              
}


  • 静态代码扫描
    拷贝生成的到静态扫描的stage的steps里,再补充sonar扫描的指令
stage('静态代码扫描'){    steps { 
         echo '这是静态代码扫描'  
         withSonarQubeEnv(credentialsId: '1d74c7e8-5b27-4772-9a21-41e17eb87b7d', installationName: 'sonar') {
              // 执行sonar扫描的指令   
              sh '''   
              cd "${servername}"   
              mvn sonar:sonar \   
              -Dsonar.projectKey=${JOB_NAME}-${servername}$BUILD_NUMBER \   
              -Dsonar.projectName=mall \   
              -Dsonar.language=java \   
              -Dsonar.sourceEncoding=UTF-8 \   
              '''  
           } 
     }
}


  • 打包并部署
stage('服务打包并部署'){

      steps {   

           echo '打包依赖服务'   

           //打包每个服务都依赖的模块   

           sh 'mvn clean install -pl mall-common,mall-mbg -am'   

           //打包我要部署的这个服务模块   

           sh '''   

           cd "${servername}"   

           mvn clean package   

           '''    

           //执行部署脚本文件  

           sh '/mydata/sh/${servername}.sh'  

      }    

}


  • 钉钉通知钉钉通知在每个阶段其实都可以加的,我们把他加载部署里
stage('服务打包并部署'){ 

    steps {  

        echo '打包依赖服务'  

        //打包每个服务都依赖的模块  

        sh 'mvn clean install -pl mall-common,mall-mbg -am'  

        //打包我要部署的这个服务模块  

        sh '''  

        cd "${servername}"  

        mvn clean package  

        '''   

        //执行部署脚本文件  

        sh '/mydata/sh/${servername}.sh'  

        //部署完成后钉钉通知项目组  

       dingtalk(   

           robot:'dd001',//robot指的是你在系统配置中配的钉钉机器人的id   

           type:'MARKDOWN',   

           atAll: false,   

           title: "${servername} 部署成功",   

           text: ["#### '${JOB_NAME}'项目扫描部署  \n - 任务:第'${BUILD_NUMBER}'次\n - 状态:'${currentBuild.result}' \n - 执行人: '${user}' \n \n[查看控制台]('${BUILD_URL}')"]  

        ) 

   }   

}


  • 配置自动化任务allure插件的脚本生成如下:
    邮件的脚本生成如下:
stage('接口自动化测试'){

         //如果之前的步骤执行时失败了改动了当前任务的结果,那么自动化测试没有必要执行  

         //下面的判断指的是没结果时或者结果是成功时
         when {       

             expression {      

               currentBuild.result==null||currentBuild.result == 'SUCCESS'        

             }     

          }  

          //使用自动化执行的节点  

          agent {   

              label 'auto_test'     

          }  

          steps {   

             echo '接口自动化测试'   

             //拉取自动化脚本   

             git credentialsId:'4c1003efac70-4271-8649-1759e79d430a', url: 'http://192.168.0.109/shamo/mallapitest1.git'   

             //执行自动化测试,由于这个节点是windows的,所以采用bat xxx来执行命令操作   

             bat 'python run.py'  

             //生成测试报告   

             allure includeProperties: false, jdk: '', results: [[path: 'report/shop']]   

             //发送结果邮件   

           emailext body: '''  
    

                 

                 

            

           $PROJECT_NAME-第$BUILD_NUMBER次构建日志      

                 

          

           

           

构建信息

''', subject: '$PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS!', to: '2879897713@qq.com' } }


  • 最后执行

相关推荐

ETCD 故障恢复(etc常见故障)

概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...

在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法

FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...

如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)

---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》

服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...

聊聊Spring AI Alibaba的YuQueDocumentReader

序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...

Mac Docker环境,利用Canal实现MySQL同步ES

Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...

RustDesk:开源远程控制工具的技术架构与全场景部署实战

一、开源远程控制领域的革新者1.1行业痛点与解决方案...

长安汽车一代CS75Plus2020款安装高德地图7.5

不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...

Zookeeper使用详解之常见操作篇(zookeeper ui)

一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...

zk源码—4.会话的实现原理一(会话层的基本功能是什么)

大纲1.创建会话...

Zookeeper 可观测性最佳实践(zookeeper能够确保)

Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...

服务器密码错误被锁定怎么解决(服务器密码错几次锁)

#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...

zk基础—4.zk实现分布式功能(分布式zk的使用)

大纲1.zk实现数据发布订阅...

《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析

在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...

取消回复欢迎 发表评论: