pipeline jetty app持续部署

jenkinsfile脚本

node(NODE) {
    try{
        String ENV="" //pro,uat,fat,dev
        String haproxyPre=""
        String backup_dir="/data1/gprp/${JOB_NAME}"
        String file=""
        /*
        选择回退到哪个tag版本,TAG值:
        0:正常发布新版本
        1:不打包,直接进行远程服务重启
        2:不打包,发送上一个版本到服务器,并重启
        其他,则回退到该tag版本git checkout tag,并发布
        */
        echo "TAG: ${TAG}"
        //本轮发布计数
        DeployCurNum=0
        //总共需要发布的节点
        DeployAllNum=SERVER.tokenize(',').size()
        SERVER=SERVER.split('"')[1].split(',')
        //总共剩余未发布的节点
        DeployLeftNum=DeployAllNum
        node_ip_list=""
        int DeployNum= env.DeployNum
        if (isSubproject){
            file = "./${APP_NAME}/target/${filename}"
        }else {
            file = "./target/${filename}"
        }
        if(TAG == "0"){
            compile(file, backup_dir)
        }else if(TAG != "2" && TAG != "1" && TAG != "0"){
            sh "git checkout ${TAG}"
            compile(file, backup_dir)
        }
        for (int i = 0; i < DeployAllNum; i++){
            //构造本轮的发布列表
            node_ip_list=SERVER[i] + "," + node_ip_list
            DeployCurNum=DeployCurNum + 1
            DeployLeftNum=DeployLeftNum - 1
            //如果本轮当前已下线节点数量少于每一轮需要发布的数量,并且仍有未下线的节点,则继续构造本轮的发布列表
            if ( DeployCurNum < DeployNum && DeployLeftNum != 0 ){
                continue
            }
            if(HAPROXY != ""){
                haproxyPre=HAPROXY.split(',')[2]
                offlineServices(node_ip_list, haproxyPre)
            }
            if(TAG != "2"){
                sendPackage(node_ip_list)
            }
            restartService(node_ip_list)
            if(HAPROXY != ""){
                onlineServices(node_ip_list, haproxyPre)
            }
            DeployCurNum=0
            node_ip_list=""
        }
        stage('通知负责人'){
            emailext body: "构建项目:${BUILD_URL}\r\n构建完成", subject: "构建项目${JOB_NAME}【成功】", to: "${EMAIL}"
        }
    } catch (e) {
        echo "${e.toString()}"
        emailext body: "构建项目:${BUILD_URL}\r\n构建失败,\r\n错误消息:${e.toString()}", subject: "构建项目${JOB_NAME}【失败】", to: "${EMAIL}"
    } finally{
        // 清空工作空间
  //     cleanWs notFailBuild: true
    }
}
def compile(String file,String backup_dir){
    stage('检出代码'){
        git branch: "${BRANCH}",credentialsId: "${credentialsId}", url: "${REPO_URL}"
        echo "检测若为master分支时,不可拉取snapshot包或取名包含snapshot的包名"
        if (BRANCH == 'master') {
            sh '''
                if [[ `grep 'SNAPSHOT' pom.xml` ]];then
                    exit 1
                fi
            '''
        }
    }
    stage('编译'){
        if (BRANCH == "master"){
            ENV = "pro"
        }else if(BRANCH == "develop"){
            ENV = "fat"
        }else if(BRANCH == "release"){
            ENV = "uat"
        }else if(BRANCH == "patch-3"){
            ENV = "pro"
        }
        if(isSubproject){
            sh "/usr/local/maven/bin/mvn -Dmaven.test.skip=true -P ${ENV}  -pl ${APP_NAME} -am clean package -U"
        }else {
            sh "/usr/local/maven/bin/mvn -Dmaven.test.skip=true -P ${ENV} clean package -U"
        }
    }

    stage('备份'){
        sh "if [[ ! -d ${backup_dir} ]];then mkdir ${backup_dir};fi"
        //suf=`date \'+%s\'`
        sh "/bin/cp -a ${file} ${backup_dir}/${filename}-`date \'+%s\'`"

    }

}

def sendPackage(String node_ip_list){
    stage("发包: ${node_ip_list}"){
        //echo "/usr/bin/rsync  --delete   -avz --password-file=/etc/rsync_jenkins_gprp_test.pass ${file}  root@${SERVER}::${APP_NAME}/webapps"
        String APP_dir=""
        if(APP_NAME == 'gprp_cg_app'){
            APP_dir = 'gprp_cg'
        }else if(APP_NAME == 'gprp_cg_pc'){
            APP_dir = 'gprp_cg'
        }else {
            APP_dir = APP_NAME
        }
        sh "sudo  salt  -L \"${node_ip_list}\" cp.get_file  salt://${JOB_NAME}/${APP_NAME}/target/$filename  /workspace/gprp/${APP_dir}/webapps/${filename}"
    }
}

def restartService(String node_ip_list){
    stage("重启服务${node_ip_list}"){
        //echo "sudo  salt  ${SERVER}  --async   cmd.run  \"sudo supervisorctl restart ${APP_NAME}\""
        String APP_dir=""
        if(APP_NAME == 'gprp_cg_app'){
            APP_dir = 'gprp_cg'
        }else{
            APP_dir = APP_NAME
        }
        sh "sudo  salt -L \"${node_ip_list}\"  --async   cmd.run  \"sudo supervisorctl restart ${APP_dir}\""
    }
}

def offlineServices(String node_ip_list, String haproxyPre){
    stage("下线${node_ip_list}节点"){
        List l_node_ip_list = node_ip_list.split(',')
        haproxy_place=HAPROXY.split(',')[1]
        haproxy_ip=HAPROXY.split(',')[0]
        for (node_ip in l_node_ip_list){
            haproxySuf=node_ip.split('\\.')[-1]
            //sh "haproxySuf=`echo ${node_ip} |cut  -d '.' -f 4`;/var/lib/jenkins/4399scripts/gprp/gprp_haproxy45.sh 'maint' '#6' ${haproxyPre}${haproxySuf}"
            sh "/var/lib/jenkins/4399scripts/gprp/gprp_haproxy.sh 'maint' \"${haproxy_place}\" \"${haproxyPre}${haproxySuf}\" \"${haproxy_ip}\""
        }
    }
}

def onlineServices(String node_ip_list, String haproxyPre){
    stage("检测节点${node_ip_list}服务,正常则上线"){
        List l_node_ip_list = node_ip_list.split(',')
        haproxy_place=HAPROXY.split(',')[1]
        haproxy_ip=HAPROXY.split(',')[0]
        for (String node_ip : l_node_ip_list){
            sh "/var/lib/jenkins/4399scripts/gprp/check_url.sh \"http://${node_ip}:${URL_CHECK}\""
            haproxySuf=node_ip.split('\\.')[-1]
            sh "/var/lib/jenkins/4399scripts/gprp/gprp_haproxy.sh 'ready' \"${haproxy_place}\" \"${haproxyPre}${haproxySuf}\" \"${haproxy_ip}\""
        }
    }
}

gprp_haproxy.sh

#!/bin/bash
# 简化脚本
# USER PASS IP PORT已隐藏

curl -u ${USER}:${PASS}  '${IP}:${PORT}/admin?stats/' -d  "action=$1&b=$2&s=$3"

check_url.sh

#!/bin/bash
#xujingbin 20180816
# 传入参数
# $0 url
# $1 timeout
# $2 app_name
signal=1
if [[ $2 != "" ]];then
  timeout=$2
else
  timeout=40
fi
node_ip=`echo $1 | awk -F '://' '{print $2}' |awk -F ':' '{print $1}'`
log_file="console.`date +%Y_%m_%d`.jetty.log"
app_name=$3
while [[ "$signal" -ne "$timeout" ]];do
  sleep 5
  curl -s --connect-time 4 -I $1 |grep HTTP |grep 200 > /dev/null && break || echo "wait for server starting ....   5*${signal} 秒" && let signal++
done
if [[ "$signal" -eq "$timeout" ]];then
  echo "服务没起来..."
  sudo salt ${node_ip} --async cmd.run "tail -200 /workspace/gprp/${app_name}/logs/${log_file}"
  exit 1
fi
echo "service start success"
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容