远程触发 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 任务的,参考源码如下:
执行上述 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:程序员欣宸
版权声明: 本文为 InfoQ 作者【程序员欣宸】的原创文章。
原文链接:【http://xie.infoq.cn/article/d9f89e622cb4fd4a03bca3bd7】。文章转载请联系作者。
评论