docker如何利用WebHook实现持续集成


这篇文章主要讲解了“docker如何利用WebHook实现持续集成”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“docker如何利用WebHook实现持续集成”吧!git  :我使用的码云 我的主页为:jenkins:jenkins ver. 2.89.2tomcat 8 jdk8 maven3.5配置好环境后,在tomcat中运行jenkins,并设置好用户名密码确保能正常登录使用操作步骤:1.安装插件 generic webhook trigger plugin、deploy to container plugi 香港云主机n、git plugin 由于这里暂时未发布到docker中,通过deploy to container plugin发布到tomcat中的2.上传maven项目到3.jenkins中新建项目ci  3.1 配置提交的代码地址,add有权限的用户名和密码(我的是私有项目),指定分支  3.2:配置maven命令以及发布到的tomcat  注意:发布项目的tomcat需要设置用户信息,即修改conf下的user.xml 具体可以参考我很早之前写的 这样就可以手动构建项目了,请确保手动构建能成功后再进行下列操作  遇见的问题及解决方案:    如果构建时提示权限不对    生成公钥: ssh-keygen -t rsa 一直回车直结束    cat ~/.ssh/id_rsa.pub 将内容增加到码云上    如果还提示没权限    手动先在jenkins运行的机器上clone一次代码 如 git clone 注意输入yes    然后再看.ssh目录,多了一个known_hosts 里面有码云了,然后再手动构建,应该就能成功了  至此,手动打包并部署就已经实现了  ——————————自动部署 ————————————————–  1. 安装上述插件后勾选generic webhook trigger 增加post参数 ref expression值为 $.ref 注意有个点  增加optional filter  其实上面这部分不用设置也行,尤其是只会在jenkins中部署一个项目的一个分支时,只需要勾选上generic webhook trigger就可以的  2. 在码云中增加hook:http://user id:api token@jenkins部署的地址:端口号/jenkins/generic-webhook-trigger/invoke (红色这部分不要变)    (这里不用api token 直接用jenkins的登录密码也可以, api token查看地址为:jenkins-用户-点击用户名-api token)    同时勾选push或者其他你认为需要触发部署的事件  提交后点击测试,如果返回ok,则表示成功,切换到jenkins,查看项目是否能够自动部署  我自己写了一个接口用来获取点击测试后,到底请求了些什么      格式化下内容如下:  其实多建立几个项目然后获取信息后会发现,不同项目间存在差异的就是project.git_ssh_url 和分支 ref  至此,单个项目的自动部署就完了  如果你在jenkins中有多个项目,你触发其中的一个webhook你就会发现,所有的项目都在构建?  这就有点不科学了,本来只想构建a项目,结果abc项目都构建了? 要解决这个就需要用到上面提到的post param 和 filer 了  解析触发自动构建的请求参数,ref和project.git_ssh_url是差异性的东西,那就根据两个来区分项目  有这上面的两个post参数还不行,因为只是获取到了对应的参数值  其实要想区分不同的项目也简单,只要获取到的ref还有url 和需要构建的项目分支和 git地址相同就构建,否则就不构建  optional filter提供的方式就是最简单的正则匹配  expression设置为 ^(refs/heads/master)_( 注意修改为自己的项目地址  text 设置为   $ref_$project.git_ssh_url  保存,再次构建,是不是只触发了一个项目了,而不是所有项目了  测试:    1.提交代码, 提交代码后看到jenkins就自动编译打包了     2.查看编译日志:jenkins收到了webhook请求,并且拉取了代码,提交信息和我们提交代码时输入信息一致          有同学质疑我这里为啥失败了,是不是自动构建不可用,不是哈, 我这里是用的阿里服务器,内存不够导致了自动发布失败    完整编译并正确部署的日志如下:  查看效果
感谢各位的阅读,以上就是“docker如何利用WebHook实现持续集成”的内容了,经过本文的学习后,相信大家对docker如何利用WebHook实现持续集成这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是开发云,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: JavaScript如何对Cookie进行操作

今天小编给大家分享一下JavaScript如何对Cookie进行操作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Cookie 只是存储在计算机…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 07/03 22:13
下一篇 07/03 22:13

相关推荐