jenkins中使用pipeline发布项目

1,新建项目,需要预先安装pipeline插件
插件下载问题 jenkins中发布java项目
在这里插入图片描述
2,pipeline语法
可以使用代码仓库中的Jenkinsfile也可以使用web界面直接填入内容
在这里插入图片描述
这里把Jenkinsfile放在代码仓库中,并指定名称
在这里插入图片描述

pipeline两种语法,区别是声明式在执行前校验语法格式,脚本式不会

声明式pipeline
pipeline {
    agent {
        label "10.144.100.211"
    } // 
    parameters {
  gitParameter branch: '', branchFilter: '.*', defaultValue: 'origin/master', description: '选择部署代码分支', name: 'branch', quickFilterEnabled: false, selectedValue: 'DEFAULT', sortMode: 'NONE', tagFilter: '*', type: 'GitParameterDefinition'
}
    stages {
        stage('拉取代码') { 
            steps {
            git changelog: false, credentialsId: 'db1befc3-e0f7-4bc3-bb89-fa7c482d6f47', poll: false, url: 'git@xxx.git'
                // 
            }
        }
        stage('构建项目') { 
            steps {
            sh 'mvn clean package -Dmaven.test.skip=true'
                // 
            }
        }
        stage('部署项目') { 
            steps {
            sshPublisher(publishers: [sshPublisherDesc(configName: '10.144.100.211', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'bash -x /root/shell/gx.sh', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '/var/lib/jenkins', remoteDirectorySDF: false, removePrefix: '/var/lib/jenkins', sourceFiles: '/var/lib/jenkins')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
                // 
            }
        }
        stage('构建结果邮件发送') {
            steps {
            emailext body: '''<!DOCTYPE html>  
<html>  
<head>  
<meta charset="UTF-8">  
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>  
</head>  
  
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4"  
    offset="0">  
    <table width="95%" cellpadding="0" cellspacing="0"  style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">  
        <tr>  
            <td>各位同事,大家好,以下为${PROJECT_NAME }项目构建信息</td>  
        </tr>  
        <tr>  
            <td><br />  
            <b><font color="#0B610B">构建信息</font></b>  
            <hr size="2" width="100%" align="center" /></td>  
        </tr>  
        <tr>  
            <td>  
                <ul>  
                    <li>项目名称 : ${PROJECT_NAME}</li>  
                    <li>构建编号 : 第${BUILD_NUMBER}次构建</li>  
                    <li>触发原因: ${CAUSE}</li>  
                    <li>构建状态: ${BUILD_STATUS}</li>  
                    <li>构建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li>  
                    <li>构建  Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li>  
                    <li>工作目录 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>  
                    <li>项目  Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li>  
                </ul>  
            </td>  
        </tr>  
        <tr>
            <td><b><font color="#0B610B">历史变更记录:</font></b>
            <hr size="2" width="100%" align="center" /></td>
        </tr>
        <tr>
            <td>
                ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br />%m</pre>",pathFormat="&nbsp;&nbsp;&nbsp;&nbsp;%p"}
            </td>
        </tr>
    </table>  
</body>  
</html>''', recipientProviders: [buildUser()], subject: '构建结果', to: 'zhaotianhe@pci-china.com'
                // 
            }
        }
    }
}
#脚本式语法
node{"10.144.100.211"} {  
    stage('Build') { 
        // 
    }
    stage('Test') { 
        // 
    }
    stage('Deploy') { 
        // 
    }
}

3,pipeline使用pipeline语法生成器,用法与普通项目一样
pipeline项目中点击流水线语法
在这里插入图片描述
参数化构建在Declarative Directive Generator中,填好之后点击Generate Pipeline Script生成,copy到拉取代码的前面
在这里插入图片描述
git进行拉取代码
在这里插入图片描述
sh进行代码构建
在这里插入图片描述
ssh到远程主机使用脚本进行更新部署
在这里插入图片描述
4,构建测试
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

背锅攻城师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值