前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Generic Webhook Trigger插件实现Jenkins+WebHooks(码云)持续集成

使用Generic Webhook Trigger插件实现Jenkins+WebHooks(码云)持续集成

作者头像
Java后端技术
发布2018-08-09 11:55:54
1.7K0
发布2018-08-09 11:55:54
举报
文章被收录于专栏:Java后端技术栈Java后端技术栈

业务背景

我们在开发的时候,特别是前后端分离的时候,前端需要我们后端提供的API接口,可能需要每次有一个接口的变动都需要重新部署到dev环境上,例如:最常见的Git工作流的方式,develop和master是分开的,在开发过程中提交的代码首先合并到develop上,如下图:

如果,使用Jenkins做集成工具,每次有代码合并的时候,也需要手动的去构建:

这是一件很繁琐的事情,如何实现当代码自动提交到develop分支的时候自动触发构建功能,目前,有效的解决方案是使用“钩子”。

钩子功能(callback),是帮助用户push了代码后,自动回调一个您设定的http地址。 这是一个通用的解决方案,用户可以自己根据不同的需求,来编写自己的脚本程序(比如发邮件,自动部署等)。

这里就学习一下代码托管在“码云 Git@OSC”平台上,使用通用的“Generic Webhook Trigger” 插件实现。

关于“码云”WebHooks的介绍及使用请参考:http://git.mydoc.io/?t=154711

准备工作

1、这里假设你已经对Jenkins有一定的了解和使用,如果是新手的话,可以参考文章:

使用Jenkins配置Git+Maven的自动化构建:http://blog.csdn.net/xlgen157387/article/details/50353317

2、“码云 Git@OSC”项目托管地址,这里假设我自己的项目:https://git.oschina.net/xuliugen/dlt-server.git(私有项目)

3、安装Generic Webhook Trigger插件

在“系统设置–插件管理–可选插件”界面搜索:Generic Webhook Trigger,可以看到,点击安装,然后重启。

这里是我已经装过,所以在“已安装”界面给大家看一下!

插件地址:https://wiki.jenkins-ci.org/display/JENKINS/Generic+Webhook+Trigger+Plugin

搭建工作

一、创建Job

这里我的是Maven项目,所以直接使用下图中红色步骤1和2

二、配置Job

下边依次配置是:General–>源码管理–>构建触发器–>Optional filter–>构建环境–>Pre Steps–>Build–>Post Steps–>构建设置–>构建后操作 的配置。

(1)General

(2)源码管理

注意:这里指定 Build的分支为develop,只是为了在开发的时候部署开发的代码,如果没有直接就是master

关于账户密码的设置,如有问题请参考:

使用Jenkins配置Git+Maven的自动化构建:http://blog.csdn.net/xlgen157387/article/details/50353317

(3)构建触发器

直接勾选使用插件即可!

(4)Optional filter、构建环境、Pre Steps这三个部分没有进行配置,如下:

(5)Build、Post Steps、E-mail Notification

a、指定根pom文件; b、这里由于我的项目是多环境的,如下:

我需要编译的是dev环境并且跳过测试 ,所以填入命令:

clean install -Pdev -Dmaven.test.skip=true -e

如果没有环境配置的话,直接忽略就可以!

c、选中:Run only if build succeeds

(6)构建后操作

我这里是部署到Tomcat容器中,关于过程不再多说,可以参考:

使用Jenkins配置Git+Maven的自动化构建:http://blog.csdn.net/xlgen157387/article/details/50353317

(7)点击Apply 保存,到此Job配置完成!

三、配置用户和Security

(1)在“系统管理–用户管理”设置用户API Token!找到等会会用!

可以进行Change!

(2)然后在“系统设置->Configure Global Security”,去掉防止跨站点请求伪造的勾,这样我们就可以在浏览器和码云的webhook访问到api的地址了,不然我们把用户名和密码放到url 中,还是不能访问。

四、配置码云WebHooks

找到WebHooks配置界面,在POST地址框中输入如下格式内容:

具体如下:

a、User ID:既是“三(1)”中的User ID,我的是admin; b、API Token:既是“三(1)”中的API Token,例如我的是8c1d11114ab111111111fdf21111a6a97; c、Jenkins IP地址:就是你的Jenkins的服务器IP地址,这个必须是公网IP地址,例如我的是210.41.223.54; d、端口:就是Jenkins服务器的端口; e、后边的内容就是Generic Webhook Trigger 插件的地址,无需改变;

例如我的配置为:

点击提交之后,界面如下:

然后点击“测试” 看一下Jenkins是否开始运行!

至此!全部配置已经完成,如有疑问欢迎留言!共同学习!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-06-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java后端技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 业务背景
  • 准备工作
  • 搭建工作
相关产品与服务
代码托管
CODING 代码托管(CODING Code Repositories,CODING-CR)是为开发者打造的云端便捷代码管理工具,旨在为更多的开发者带去便捷、高效的开发体验,全面支持 Git/SVN 代码托管,包括代码评审、分支管理、超大仓库等功能。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档