写点什么

远程触发 Jenkins 的 Pipeline 任务的并发问题处理

作者:程序员欣宸
  • 2022-11-26
    广东
  • 本文字数:1421 字

    阅读完需:约 5 分钟

远程触发Jenkins的Pipeline任务的并发问题处理

欢迎访问我的 GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos

前文概述

  • 本文是《远程触发Jenkins的Pipeline任务》的续篇,上一篇实战了通过 Http 请求远程触发指定的 Jenkins 任务,并且将参数传递给 Jenkins 任务的 Pipeline 脚本使用,文末提到有个并发问题留待本文来处理;

远程触发 Jenkins 的问题

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

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

  • 用 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 任务的并发问题已经修复,如果您也遇到了类型问题,希望本文能给您一些参考。

欢迎关注 InfoQ:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...


发布于: 2022-11-26阅读数: 29
用户头像

搜索"程序员欣宸",一起畅游Java宇宙 2018-04-19 加入

前腾讯、前阿里员工,从事Java后台工作,对Docker和Kubernetes充满热爱,所有文章均为作者原创,个人Github:https://github.com/zq2599/blog_demos

评论

发布
暂无评论
远程触发Jenkins的Pipeline任务的并发问题处理_Java_程序员欣宸_InfoQ写作社区