博客
关于我
远程触发Jenkins的Pipeline任务的并发问题处理
阅读量:400 次
发布时间:2019-03-06

本文共 2085 字,大约阅读时间需要 6 分钟。

前文概述

本文是《远程触发Jenkins的pipeline任务》的续篇,上一篇文章实战了如何通过Http请求远程触发指定的Jenkins任务,并且将参数传递给Jenkins任务去使用,文末提到了有个并发问题待处理,这就是本文的内容:处理上一篇文章提到的遗留问题。

远程触发Jenkins的问题

对Jenkins服务来说,很有可能在某一时刻同时收到多个Http请求,并且这些请求都想触发同一个任务,在实际使用中发现此时Jenkins并不对每个请求都运行一次任务,接下来的实战,我们就来重现并解决此问题;

用Java代码实现多个并发请求

  • 我们用代码来模拟同一时刻多个Http请求到达Jenkins的情况:写个Java程序,一次性发送10个Http请求,都是远程触发上一章的Jenkins任务的,参考源码如下:
package com.bolingcavalry;import com.alibaba.fastjson.JSONObject;import org.apache.http.client.methods.CloseableHttpResponse;import org.apache.http.client.methods.HttpPost;import org.apache.http.entity.StringEntity;import org.apache.http.impl.client.CloseableHttpClient;import org.apache.http.impl.client.HttpClients;public class App {    public static void main( String[] args ) throws Exception {        for(int i=0;i<10;i++) {            JSONObject jsonObject = new JSONObject();            jsonObject.put("ref", "ref-"+i);            jsonObject.put("repositoryURL","https://github.com/zq2599/jenkinsdemo.git");            jsonObject.put("branch", "master");            CloseableHttpClient httpClient = HttpClients.createDefault();            HttpPost httpPost = new HttpPost("http://192.168.133.149:32049/generic-webhook-trigger/invoke?token=token-remote-test");            httpPost.addHeader("Content-Type", "application/json");            httpPost.setEntity(new StringEntity(jsonObject.toJSONString()));            CloseableHttpResponse response = httpClient.execute(httpPost);            response.close();            httpClient.close();            System.out.println("response code : " + response.getStatusLine().getStatusCode() + "\n");        }    }}
  • 执行上述Java代码,控制台输出如下图,返回码都是200,证明这10个请求全部成功了:
  • 去Jenkins网页上却发现只执行了一次任务,但是10此请求的ref参数都被打印出来了,如下图:
  • 10次请求,Jenkins只执行了一次任务,这样的结果显然不是我们想要的,经过摸索和尝试,终于找到了解决此问题的办法;
  • 打开任务remote-test的设置页面,如下图,勾选红框1(This project is parameterized),点击红框2增加一个参数,再点击红框3增加一个字符串类型的参数:
  • 在参数的编辑框中,Name字段填写ref,如下图红框所示,注意这个参数在上一篇文章中在Generic Webhook Trigger的参数中设置过,是个固定参数:
  • 点击底部的Save按钮保存设置;
  • 在此运行前面的Java程序,发起10个请求,这次Jenkins创建了10个任务了,如下图:
  • 点开其中的一个查看日志,如下图,可见参数正确,并且任务执行成功:
    远程触发Jenkins任务的并发问题已经修复,如果您也遇到了类型问题,希望本文能给您一些参考。

转载地址:http://gotkz.baihongyu.com/

你可能感兴趣的文章
shell编程(六)语言编码规范之(变量)
查看>>
vimscript学习笔记(二)预备知识
查看>>
SSM项目中遇到Could not autowire. No beans of ‘XXX‘ type found.错误
查看>>
Android数据库
查看>>
HTML基础,块级元素/行内元素/行内块元素辨析【2分钟掌握】
查看>>
STM8 GPIO模式
查看>>
23种设计模式一:单例模式
查看>>
Qt中的析构函数
查看>>
C语言实现dijkstra(adjacence matrix)
查看>>
三层框架+sql server数据库 实战教学-徐新帅-专题视频课程
查看>>
【单片机开发】智能小车工程(经验总结)
查看>>
【单片机开发】基于stm32的掌上游戏机设计 (项目规划)
查看>>
C++&&STL
查看>>
微信js-sdk使用简述(分享,扫码功能等)
查看>>
c++中ifstream及ofstream超详细说明
查看>>
web项目配置
查看>>
基于单片机简易信号误差分析设计-全套资料
查看>>
基于单片机简易脉搏测量仪系统设计-毕设课设资料
查看>>
Javascript中String支持使用正则表达式的四种方法
查看>>
eclipse引用sun.misc开头的类
查看>>