Jenkins +svn(学习笔记三十)

  1. 云栖社区>
  2. 博客>
  3. 正文

Jenkins +svn(学习笔记三十)

sktj 2018-05-11 14:29:00 浏览1533
展开阅读全文

Jenkins + SVN 持续集成

 无事在家,闲得发慌,上周六面试华为的配置管理工程师,让我明白了在社会大行业里配置管理其实是个更为专业的岗位,涉及到软件开发的各个流程,数据的产生,规范的定义,代码的持续集成,基线管理,当然也涉及到供应链的一些东西,在工作中发现问题,解决问题,推动一些流程规范的制订,对流程中出现的问题进行修正等等。而我在原公司的配置管理更多是个兼职,是为软件工程师+配置管理工程师,特别是在软件部改革后,配置方向更多的边缘化,更多是DD会议召开,BUG发布及合并,代码审核数据汇总。也难怪配置管理会是一个兼职,软件上做的工作仅仅是配置管理(CM)这个岗位很小的一部分,也不可能花大价钱养一个人在这个岗位上了。

 原来廖师傅整了个自动构建,当时觉得好牛X,也是因为太闲了,在面试中也不断提到持续集成这个概念,便萌发出自已搞搞,看能不能在实践中有所了解。

 先百度个概念。

 持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽快地发现集成错误。

 要素:

 1.统一的代码库

2.自动构建

3.自动测试

4.每个人每天都要向代码库主干提交代码

5.每次代码递交后都会在持续集成服务器上触发一次构建

6.保证快速构建

7.模拟生产环境的自动测试

8.每个人都可以很容易的获取最新可执行的应用程序

9.每个人都清楚正在发生的状况

10.自动化的部署

百度百科:http://baike.baidu.com/view/5253255.htm

从这十点要素出发,原公司的自动构建,除了第3,第7,第10三个点,其它都是已经具备了。听说IT那边在做虚拟U盘,完成后,估计离自动测试这几个要素的完善也不远了。好了,废话说完,下面一点步骤记录,以供参考吧。

Jenkins

百度百科:http://baike.baidu.com/view/6190216.htm?fr=aladdin

确保系统安装了JDK,怎么安装就不说了。保证在cmd里运行$ java -version能有下图提示即可。

img_1e8b784012a85c7335012fababa41dea.png

下载jenkins.war

切换到jenkins.war存放的目录,输入如下命令:

$ java -jar jenkins.war

img_1d138e15a413788837f95b30f919a632.jpe

看到红框就说明Jenkins已经正常动作了。

在浏览器里输入:http://localhost:8080/ 进入Jenkins主界面

img_bf003c85cc3478406bea0c16e9617a89.jpe

新建个项目

img_040b7203f7b9605802344a2b04dc33ae.jpe

选构建一个自由风格的软件项目,后面还有个MAVEN,网上倒是很多说怎么去运用Jenkins + Maven + Svn来进行自动构建的,不过我没怎么搞明白,可能是之前的工作也没有涉及Java工程,只能在Liunx下编译,里面有个pom.xml文件,一直不知道是干什么用的,但无此配置文件自动构建便无法成功,后来还是选择第一个,通过bat文件来进行执行步骤。

img_4d9ebbcefc6f0732c65051e25028c442.jpe

配置项目,Jenkins集成svn管理,在红框里填入svn代码源地址。没有看到Git,不知道如果是Git管理的代码是用什么东西去做自动构建。

img_10f40af8e42dcd3e2ebcb77326d39f07.jpe

触发器,就是在什么条件上进行自动构建,第二个是定时,如可以每个小时自动构建一次。但就如第五要素里说的,每一次上传代码都触发一次构建,如此可以保证代码的持续与稳定,第一时间能发现代码问题并进行修复。这里就可以使用SVN里的POST-COMMIT HOOK。

img_78603b9ff7399b171508a1d78f8569f1.jpe

关于SVN HOOK,即SVN钩子,在执行一些动作时可以绑定另一些动作来辅助SVN管理,属于对SVN的二次开发。如图,Post-Commit Hook,就是在完成SVN上传动作后要启动这个。在这里绑定启动自动构建,即可实现上传代码后触发自动构建。还有一些Pre-Commit Hook,则可以在上传前做一些动作,如上传的Log进行规范。

img_96ec78239bddf49543cb025fb1203673.jpe

找到jenkins-cli.jar文件所在位置,build后面改为工程名子Test,即可。关于为什么是这句就直接去查找下Jenkins下的命令行指令了。

构建,即使自定义对代码进行的动作。

img_009599996fedc4cf7829a40edbb1381a.png

这里可以看到,可执行bat命令,也可以执行shell,这就可这个持续构建部署在windows下还是linux下了。选上第一个,输入相关命令。

img_d81b0bdf8adccdf6d2782d33dafa8270.png

构建后操作,就是在完成构建后会执行的动作,一般来说,就是邮件通知相关人员,告知代码状况,当然,应该是可以进行分组及权限管理的,不过暂时这个我没怎么看。

img_859538410a9074783bf6cb8ae12e10b9.png
img_b87693af03fd164d49dfd2aa7de580b2.png

设置好Jenkins,如下图

img_f03a322180037eee2a87f67e2fc923ba.jpe

立即构建

就可以对配置好的代码进行一次自动构建。

如此,Jenkins + SVN简单的持续构建就部署好了,当每一次代码上传,Jenkins都会进行一次构建,从SVN URL上UPDATE代码,根据配置的执行指令都代码进行编译,有错将会邮件提示相关人员。在主界面上就能看到如下。

img_98a0d073ce759a135530213bd022fe2e.jpe

写得相对简单,有一些具体细节还是要去试下才能了解。而且真正的服务器也是在linux下部署的,但里面的东西是相通的,Jenkins也是可以直接在linux下安装。SVN的服务器里部署,也是使用SVN SERVER,但相关的HOOK也是一致的。

以上,小小总结,以便日后查阅。

网友评论

登录后评论
0/500
评论
sktj
+ 关注