jenkins pipeline 发布 jar并运行

废话不多说,上教程

一,配置publish ssh

二,配置 ssh server

记住Name

三 设置发布选项

1 设置模块多选(请安装多选插件:Active Choices Plug-in)

四 编写pipeline

说明:

1 modules.split(',')中的modules就是上面多选框的Name

2 详细解说:

execCommand: 'cd /java ; ps -ef | grep '+module_list[i].trim()+' | grep -v grep | awk \'{print $2}\' | xargs --no-run-if-empty kill -9 ; source /etc/profile ; nohup java -jar '+module_list[i].trim()+'.jar > '+module_list[i].trim()+'.log 2>&1 & '

// 转到目录

cd /java

//通过进程名查找PID

ps -ef | grep '+module_list[i].trim()+' | grep -v grep | awk \'{print $2}\'

//删除此进程(如果为空则不运行kill)

xargs --no-run-if-empty kill -9

//此命令配合nohup,不然Jenkins中无法通过nohup运行Jar

source /etc/profile ;

//后台运行nohup

nohup java -jar '+module_list[i].trim()+'.jar > '+module_list[i].trim()+'.log 2>&1 &

完整代码:

pipeline {
    agent any
        // 设置工具
    tools {
        maven "Maven3"
        jdk "JDK17"
    }
    
    //动态参数
    environment{
         source_dir="${WORKSPACE}"
    }
    
    options {
        timestamps() // 设置在项目打印日志时带上时间戳
        disableConcurrentBuilds() // 不允许同时执行流水线,被用来防止同时访问公共资源等
        timeout(time: 40, unit: 'MINUTES') // 设置流水线运行超时时间,Jenkins自动终止流水线
        buildDiscarder(logRotator(numToKeepStr: '10')) // 保留n次构建历史
    }
    
    // 存放所有任务的合集
    stages {
        stage('clone') {
            steps {
                // 拉取代码
                git credentialsId: 'xxxx-xxxx-xxxx-xxx-xxxxxxxx', 
                url: 'http://localhost:xxxx/xxxxx/kintech-cloud',
                branch: 'dev'
            }
            
        }
        // 打包
        stage('install') {
            steps {
              script {
                //服务名称数组
                module_list = modules.split(',')
                
                for (int i = 0; i < module_list.size(); i++) {
                        echo "=================package ${module_list[i]} "
                        // 打对应的项目以及依赖包
                        bat 'mvn -Dmaven.test.failure.ignore=true -pl kintech-modules/' + module_list[i].trim() + ' -am clean package '
                    }
                echo 'Install success'
               }
            }
    }
        
        // 部署
        stage('deploy') {
            steps {
                script {
                    for (int i = 0; i < module_list.size(); i++) {
                        echo "=================sshPublisher ${module_list[i]} "
                        // scp 免密传输
                        sshPublisher(publishers: [sshPublisherDesc(configName: 'kintech-cloud测试服务', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'ls', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: 'kintech-modules/'+module_list[i].trim()+'/target/', sourceFiles:  'kintech-modules/'+module_list[i].trim()+ '/target/' +module_list[i].trim()+'.jar')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: true)])    
            
                    }
                    echo 'Deploy success'
                }
            }
        }

        // 启动
        stage('start') {
            steps {
                script {
                    for (int i = 0; i < module_list.size(); i++) {
                        //启动 (cd到java目录,杀掉进程,启动jar)
                        sshPublisher(publishers: [sshPublisherDesc(configName: 'kintech-cloud测试服务', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'cd /java ; ps -ef | grep '+module_list[i].trim()+' | grep -v grep | awk \'{print $2}\' | xargs --no-run-if-empty kill -9 ; source /etc/profile ; nohup java -jar '+module_list[i].trim()+'.jar > '+module_list[i].trim()+'.log 2>&1 & ', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '/java', sourceFiles: '/java')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: true)])

                    }
                    echo 'Start success'
                }
            }
        }
    }
}

五 效果

六 题外话

我的模块层级,略有不同,所以打包路径也不一样。

如下图:

gateway就是一个模块,而kintech-bo模块在总的kintech-modules模块下。

所以发布jar时,打包路径会有所不同。

而我的解决方案是,增加一个选项框,用Referenced parameters 来记录。

最后在pipeline中拼接:modulesPath.trim()+module_list[i]

我的选项

注意,modulesPath带上/

kintech-modules:

kintech-gateway:

相关推荐
冰 河26 分钟前
《Nginx核心技术》第16章:实现Nginx的高可用负载均衡
运维·nginx·程序员·负载均衡·高可用
人工智障调包侠4 小时前
Linux 目录介绍
linux·运维·服务器
Java小白白同学5 小时前
Linux 硬盘扩容操作手册
linux·运维·服务器
大白菜和MySQL6 小时前
keepalived和lvs高可用集群
linux·运维·lvs
学习向前冲7 小时前
高效诊断Linux性能问题
linux·运维·服务器
wd5205217 小时前
常用环境部署(十七)——Docker安装pritunl+openvpn
运维·docker·容器
威迪斯特7 小时前
视频监控接入平台web客户端有时无法登录,有时打开实时视频出现黑屏的问题解决
linux·运维·服务器·视频监控·df命令·磁盘空间·接入平台
数据安全小盾8 小时前
2024办公文件怎么加密?常用的8款加密软件排行榜
运维·服务器·网络·安全·web安全
素年槿夏9 小时前
600 条最强 Linux 命令总结
linux·运维·服务器
雨声不在9 小时前
在jenkins中获取git的修改记录的方法
git·jenkins