Jenkins: Webhook触发多分支流水线项目构建
总共发现了两种配置方法,分别是通过不同的插件实现
Generic Webhook Trigger
安装插件:Generic Webhook Trigger
在Jenkinsfile中,添加配置:
triggers {
GenericTrigger (
// 构建时的标题
causeString: 'Triggered by $ref',
// 获取POST参数中的变量,key指的是变量名,通过$ref来访问对应的值,value指的是JSON匹配值(参考Jmeter的JSON提取器)
// ref指的是推送的分支,格式如:refs/heads/master
genericVariables: [[key: 'ref', value: '$.ref']],
// 打印获取的变量的key-value,此处会打印如:ref=refs/heads/master
printContributedVariables: true,
// 打印POST传递的参数
printPostContent: true,
// regexpFilterExpression与regexpFilterExpression成对使用
// 当两者相等时,会触发对应分支的构建
regexpFilterExpression: '^refs/heads/(master|production)$',
regexpFilterText: '$ref',
// 与webhook中配置的token参数值一致
token: 'mytoken'
)
}
如:
在gitee中配置webhook,在Url中填入:
https://your_IP/generic-webhook-trigger/invoke?token=mytoken
如:
提交代码后,gitee会触发jenkins的多分支流水线项目扫描分支。当$ref
的值符合正则表达式^refs/heads/(master|production)$
,会触发项目的构建。
注意:当你首次在Jenkinsfile配置triggers后,提交git仓库后不会自动触发构建。原因是:配置触发构建的jenkinsfile未拉取到jenkins项目中。
其他更详细的用法,请参考:https://gitbook.curiouser.top/origin/jenkins-generic-webhook-trigger插件.html
Multibranch Scan Webhook Trigger
安装插件:Multibranch Scan Webhook Trigger
在多分支项目配置中的Scan Multibranch Pipeline Triggers
选择并添加:
在gitee中配置webhook,在Url中填入:
https://your_IP/multibranch-webhook-trigger/invoke?token=mytoken
提交代码后,gitee会触发jenkins的多分支流水线项目构建你提交的对应的分支。
如果想要忽略某些分支,可通过Filter by name (with wildcards)
实现:
总结
Generic Webhook Trigger的配置更灵活,但不太符合常识
Multibranch Scan Webhook Trigger虽然功能简单,但更人性化
作者:南辞、归
本博客所有文章仅用于学习、研究和交流目的,欢迎非商业性质转载。
博主的文章没有高度、深度和广度,只是凑字数。由于博主的水平不高,不足和错误之处在所难免,希望大家能够批评指出。
博主是利用读书、参考、引用、抄袭、复制和粘贴等多种方式打造成自己的文章,请原谅博主成为一个无耻的文档搬运工!