版本库里代码提交后,如何触发jenkins自动构建?这是一个面试题,感受本身回答的并很差,由于并无用过这个功能,以前公司实际项目用的是svn版本管理,通常都用马上构建,和定时任务构建(无论代码是否有提交,都到代码库里拉取最新的代码,而后构建)。而且我也是这样告诉面试官的,显然面试官对我很困惑,最终,我告诉他咱们的源码管理工具用的是SVN,而后,可能把面试官也弄懵了,由于面试公司用的是gitlab. 哈哈,面试官本身没有尝试过“SVN+触发构建插件”吧。html
通过查询,网上针对Gitlab源码管理+jenkins是有解决方案的: Gitlab利用Webhook实现Push代码后的jenkins自动构建java
下面是个人实践过程:git
已经准备好以下环境:github
Gitlab内网服务器地址:http://192.168.1.50:8090web
jenkins内网服务器地址:http://192.168.1.40:8080面试
步骤从这里开始:tomcat
1. jenkins,分别点击"系统管理"->"插件管理"->"可选插件",选择Gitlab和Gitlab Hook Plugin 安全
2.192.168.1.50服务器上,须要创建git用户服务器
useradd git passwd git
3(这个步骤,请跳过,后面jenkins里,凭据我并无选择免密登录). 将Jenkins的公钥key添加到Gitlab上, 这样就能够实现jenkins访问gitlab免密码 微信
在 Docker:pipeline编写基本技巧- jenkins配置经过密钥拉取git源码管理仓库的代码 中,已经有使用公钥私钥的经验了
如今登录 192.168.1.40
#192.168.1.40(jenkins)机器上,已经存在公钥
[root@192 ~]# ls .ssh/ id_rsa id_rsa.pub known_hosts #将192.168.1.40机器的公钥Copy到192.168.1.50(Gitlab)服务器上
[root@192 ~]# ssh-copy-id git@192.168.1.50
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" /usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed /usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys root@192.168.1.50's password: Number of key(s) added: 1 Now try logging into the machine, with: "ssh 'root@192.168.1.50'" and check to make sure that only the key(s) you wanted were added.
[root@192 ~]# ssh 'git@192.168.1.50'
Last login: Sat Apr 6 02:01:01 2019 from mei-pc
[root@192 ~]# exit
logout Connection to 192.168.1.50 closed.
[root@192 ~]#
4. Gitlab服务器上,若是没有项目,能够参考 Github: 从github上拉取别人的源码,并推送到本身的github仓库 找一个项目放上去
步骤以下:
[root@192 tomcat-java-demo]# vi .git/config
[root@192 tomcat-java-demo]# git remote add origin http://192.168.1.50:8090/root/tomcat-java-demo-gitlab.git fatal: remote origin already exists.
#若是遇到上面这个错误提示,就按照接下来的操做
[root@192 tomcat-java-demo]# git remote rm origin [root@192 tomcat-java-demo]# git remote add origin http://192.168.1.50:8090/root/tomcat-java-demo.git [root@192 tomcat-java-demo]# git push -u origin master Username for 'http://192.168.1.50:8090': root Password for 'http://root@192.168.1.50:8090': Counting objects: 229, done. Compressing objects: 100% (185/185), done. Writing objects: 100% (229/229), 4.52 MiB | 1.15 MiB/s, done. Total 229 (delta 25), reused 229 (delta 25) remote: Resolving deltas: 100% (25/25), done. remote: remote: The private project root/tomcat-java-demo was successfully created. remote: remote: To configure the remote, run: remote: git remote add origin http://192.168.1.50:8090/root/tomcat-java-demo.git remote: remote: To view the project, visit: remote: http://192.168.1.50:8090/root/tomcat-java-demo remote: To http://192.168.1.50:8090/root/tomcat-java-demo.git * [new branch] master -> master Branch master set up to track remote branch master from origin.
上传代码到gitlab成功, 到gitlab管理界面验证一下
4. jenkins上新建项目,这里项目名:testgitlabhook
设置jenkins拉 gitlab上代码地址和对应的凭据
保存
5. 到gitlab管理页面进行配置
点 Add Webhook后,
出现以下错误
解决参考地址:gitlab使用webhook向jenkins发送请求,报错 Requests to the local network are not allowed
大体意思 gitlab 10.6 版本之后为了安全,不容许向本地网络发送webhook请求,若是想向本地网络发送webhook请求,则须要使用管理员账号登陆, 作以下修改
如今再回到上一个步骤
点[Add webhook],不报错了,在下面出现 标签 1所示,
按照上图标签操做,点2,3
会出现以下错误
这是没有权限,须要把Jenkins-->Jenkins Manages-->Configure System,找到GitLab配置,去掉勾选。
参考解决地址:https://www.jianshu.com/p/156de44a44c2
再回去点 Test-> push event
出现 Hook executed successfully: HTTP 200 说明配置成功了
你会发现,每点一次 Test-> push event,就会触发一次jenkins马上构建
或者:
到gitlab管理界面,
做者: 梅梅~
出处: https://www.cnblogs.com/keeptesting
关于做者:专一软件测试,测试运维相关工做,请多多赐教!
本文版权归做者和博客园共有,欢迎转载,但未经做者赞成必须保留此段声明,且在文章页面明显位置给出, 原文连接 欢迎沟通交流加微信联系。 微信:yangguangkg20140901 暗号:博客园.