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能有下图提示即可。
下载jenkins.war
切换到jenkins.war存放的目录,输入如下命令:
$ java -jar jenkins.war
看到红框就说明Jenkins已经正常动作了。
在浏览器里输入:http://localhost:8080/ 进入Jenkins主界面
新建个项目
选构建一个自由风格的软件项目,后面还有个MAVEN,网上倒是很多说怎么去运用Jenkins + Maven + Svn来进行自动构建的,不过我没怎么搞明白,可能是之前的工作也没有涉及Java工程,只能在Liunx下编译,里面有个pom.xml文件,一直不知道是干什么用的,但无此配置文件自动构建便无法成功,后来还是选择第一个,通过bat文件来进行执行步骤。
配置项目,Jenkins集成svn管理,在红框里填入svn代码源地址。没有看到Git,不知道如果是Git管理的代码是用什么东西去做自动构建。
触发器,就是在什么条件上进行自动构建,第二个是定时,如可以每个小时自动构建一次。但就如第五要素里说的,每一次上传代码都触发一次构建,如此可以保证代码的持续与稳定,第一时间能发现代码问题并进行修复。这里就可以使用SVN里的POST-COMMIT HOOK。
关于SVN HOOK,即SVN钩子,在执行一些动作时可以绑定另一些动作来辅助SVN管理,属于对SVN的二次开发。如图,Post-Commit Hook,就是在完成SVN上传动作后要启动这个。在这里绑定启动自动构建,即可实现上传代码后触发自动构建。还有一些Pre-Commit Hook,则可以在上传前做一些动作,如上传的Log进行规范。
找到jenkins-cli.jar文件所在位置,build后面改为工程名子Test,即可。关于为什么是这句就直接去查找下Jenkins下的命令行指令了。
构建,即使自定义对代码进行的动作。
这里可以看到,可执行bat命令,也可以执行shell,这就可这个持续构建部署在windows下还是linux下了。选上第一个,输入相关命令。
构建后操作,就是在完成构建后会执行的动作,一般来说,就是邮件通知相关人员,告知代码状况,当然,应该是可以进行分组及权限管理的,不过暂时这个我没怎么看。
设置好Jenkins,如下图
立即构建
就可以对配置好的代码进行一次自动构建。
如此,Jenkins + SVN简单的持续构建就部署好了,当每一次代码上传,Jenkins都会进行一次构建,从SVN URL上UPDATE代码,根据配置的执行指令都代码进行编译,有错将会邮件提示相关人员。在主界面上就能看到如下。
写得相对简单,有一些具体细节还是要去试下才能了解。而且真正的服务器也是在linux下部署的,但里面的东西是相通的,Jenkins也是可以直接在linux下安装。SVN的服务器里部署,也是使用SVN SERVER,但相关的HOOK也是一致的。
以上,小小总结,以便日后查阅。