今天本身看着插件文档摸索了一下,实现了git push后Webhook自动触发Jenkins进行代码构建,可通用gitlab、github等平台,中文关于这方面自动部署的文档比较少,因此把个人学习过程记录下来,让其余人少走点弯路。git
模拟场景:开发人员在dev分支提交代码后,Jenkins自动构建和部署,非dev分支提交代码不会触发。github
实战环境:码云(git.oschina.net)、Jenkins(可在公网访问)、插件Generic Webhook Triggerweb
步骤1:bash
码云新增一个项目,新增两个分支(uat、dev),放一些文件ide
步骤2:gitlab
Jenkins安装Generic Webhook Trigger插件,插件的文档在这里(https://plugins.jenkins.io/generic-webhook-trigger)学习
步骤3:测试
新建一个自由任务,Geneal留空不影响本次实验;源码管理填入码云的项目地址,添加码云的登录用户和密码;本次实验是构建dev分支,因此我填了 */devui
步骤4:url
构建触发器这一步比较关键,卡了很久,首先咱们先去看看码云关于Webhook文档(http://git.mydoc.io/?t=154711 ),咱们要抓取研发push这个Webhook POST过来的数据,而后根据里面内容关键字ref判断是否为开发分支,若是是开发分支,则让Jenkins拉开发分支最新的代码下来构建。因此图四,勾选插件触发器,给抓出来的数据起个变量名ref,抓取内容为$.ref(看码云的文档)。
好,稍微下来一点,咱们只须要获取POST数据,header和request不用理。接下来也很关键,定义过滤出来什么字串才触发这个任务。因此使用正则匹配,text为匹配出什么结果就触发这个任务,因而咱们填入刚才抓取临时存放的变量$ref,注意这里不是原始数据的$.ref。
步骤5:剩下就是告诉拉完代码下来以后作什么操做了,后面的文章会讲到,这里我就随便输出点东西了。
步骤6:点击保存以后,回到码云的项目管理页面,填入URL
URL格式为 http://有读权限的用户名:该用户名密码@jenkis地址/generic-webhook-trigger/invoke
密码可不填(看了文档还没明白是包含在哪里,还得研究)
点击测试,返回ok就说明接口能用了,若是返回以下,则用户名密码可能没填或者没对。
{"status":"ok","data":{"triggerResults":{"ANY":"Did not find any jobs to trigger! The user invoking /generic-webhook-trigger/invoke must have read permission to any jobs that should be triggered. You may try adding http://user:passw@url... or configuring and passing an authentication token like ...trigger/invoke?token=TOKENHERE"}}}
最后,在dev分支提交代码,就会触发任务了,至此需求完成。
ps:码云点测试按钮默认是触发master push,实验过程有问题,能够只勾选一项,不做判断,就能够测试触发了,以下图。