• 【jenkins】pipeline控制多job顺序执行,进行定时持续集成


    1.jenkins下新建一个流水线项目

    2. 编写pipeline流水线脚本 

     

    完整脚本:

    pipeline {

        agent any

        stages {
            stage("build console all") {
                steps {
                    script {
                        def starting = 'pipeline-'
                        def ending = ""
                        def job_list = [
                          "清空blackduck平台上传的历史bdio文件",
                          "安全扫描flux依赖包安装",
                          "Coverity安全扫描多job同时运行-mvn编译方式",
                          "BlackDuck安全扫描多job同时运行",
                          "BlackDuck_BinaryScan安全扫描多job同时运行"

                        ]

                        def branches = [:]
                        MAX_CONCURRENT = 1

                        //创建fifo
                        latch = new java.util.concurrent.LinkedBlockingDeque(MAX_CONCURRENT)

                        //往fifo中,填入最大个数元素
                        for(int i=0; i<MAX_CONCURRENT; i++)
                            latch.offer("$i")

                        for(int i=0; i<job_list.size(); i++) {
                            def name = starting + job_list[i] + ending
                            branches[name] = {
                                def thing = null
                                waitUntil {
                                    //获取一个资源
                                    thing = latch.pollFirst();
                                    return thing != null;
                                }

                                try {
                                    //执行job
                                    build(job: name, propagate: false)
                                }

                                finally {
                                    //释放一个资源
                                    latch.offer(thing)
                                }
                            }
                        }

                        timestamps {
                            parallel branches
                        }
                    }
                }
            }
        }
    }

     

    3.定时构建,添加触发器

     

     

    运行效果:

     

     

  • 相关阅读:
    Jira使用浅谈篇一
    DDos攻击如何被高防服务器有效防范?
    D. Minimal Height Tree(如何BFS遍历序列使树的高度最小)
    金融业数字化聚焦容器云,全闪存为什么是点睛之笔?
    线性代数
    资深测试面试-参考一下
    linux centos7 docker 安装xxl-job-admin
    使用Kubectl管理kubernetes集群
    了解服务级别协议(SLA)在 ITSM 中的重要性
    知识点滴 - 什么是YAML文件
  • 原文地址:https://blog.csdn.net/baidu_31295661/article/details/125467477