设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
大规模项目团队持续集成历程
返回列表
发新帖
大规模项目团队持续集成历程
[复制链接]
11
|
5
|
2015-9-22 15:53:22
|
显示全部楼层
|
阅读模式
来源:letagilefly.com作者:乔 梁 发布于:2011年11月15日
这篇文章是我在两年前写的,记录了一个150+人的软件团队(最多时近200人)如何在一个庞大的遗留系统上,通过逐步建立一个持续交付部署流水线,从而达到频繁发布的状态。最终在该团队的持续交付基础设施中,共有260台服务器用于构建、测试和部署(几乎全部是虚拟机)。而这个产品也可以每六周发布一次。
在大规模项目团队中可能遇到的问题对于小规模、短周期的项目来说,团队与持续集成会相处地非常融洽。而对于大规模、长周期项目的初期来说,也不会有太多的问题。此时常见的也是基本的持续集成模式就是:Build->test->package。然而,只要时间稍长一点儿,持续集成就会发出坏味道了。此时的症状包括:
1. 作为开发人员要等很长时间才能知道是否可以提交代码了。如果你遵守“频繁提交”的原则,那么百人团队不间断的提交,会使集成服务器一直处于繁忙状态,而你不得不等待他人的build过了以后,才能看到自己提交的结果。
要等很长时间才能知道我的提交是否通过了;
如果build失败了,要花很长时间才能知道是否和自己的修改相关;
既使提交了fix,也不知道自己的提交是否真的修复了这次构建;
构建经常处于失败状态。
2. 作为测试人员测试人员不知道到哪里拿哪一次的构建产物来进行测试;
发布经理不知道当前各种各样的测试部署环境中,到底部署了哪个版本,包括哪些新功能或修改的bug;
不确定在同一个构建里,所有组件的版本是否都是正确的;
3. 作为项目经理不确定各个测试部署环境中的配置是否都与其上运行的构建相一致;
不确定测试人员测试的是否在正确的运行环境上运行了正确的版本;
4. 其他方面的问题所有的安装部署都需要手工操作。
以上这些问题会给你的发布管理带来无限的问题和风险。那么,是否因为这种“持续闹心”就放弃持续集成呢?回答当然是否定的。Do it more if it hurts you. 不要因问题的暴露而放弃,相反,应该欢呼。因为这反映了发布过程中的问题与风险,是时候解决它们了。
回复
使用道具
举报
千问
|
2015-9-22 15:53:22
|
显示全部楼层
如何解决大规模项目中的持续交付问题由于大项目本身的复杂性,其解决方案也不能一概而论。下面以某大型项目为例,介绍其中的几个解决方法。
1、项目基本信息描述该项目最初就试图建立一个好的持续集成环境和基础。由于是一个遗留系统,费了很大劲儿,才能够得到可工作的软件。然而,由于队伍不断壮大,而且环境也在不断变化,持续集成很快就无法达不到其预期目标了。怎么办呢?
项目背景:
项目是一个具有可配置性的Web 门户产品,面向不同行业的市场,可自己定制门户。该项目有一个遗留的代码库,而且可以肯定的说,在今后的一年半之内是无法摆脱这个遗留代码库的。而且,很多紧耦合的、不必要的臃肿代码,同时根本不存在有价值的测试代码。现在我们在逐步地重写代码,但还是不能删除它们,因为某些网站还要依赖于旧代码。事实上,这是一个.NET平台上基于SOA的网站。
开发团队情况:
团队是一个敏捷分布开发团队(三地协作,均有开发人员,且有时差)。整个团队有150多人,分成十几个团队,每个团队都有一个完成的结构(BA/DEV/QA),其中有一个是项目持续集成团队(项目之初,大约有五六个人,工作负荷很大,项目运行一段时间后只要两个人就足够了)。使用SVN做版本管理工具,在Windows2003上使用NAT, MSbuild和batch脚本进行构建管理,最初使用CC.NET做为持续集成服务器,后来使用Cruise(Go)。
初始的持续集成环境:
上面所述的持续集成问题在项目一开始就出现了,因为该项目有一个庞大的遗留代码库,而且使用的基本持续集成方式(build->test->package)而且测试人员手工部署进行各类测试。
其初始的持续集成环境如下所示:
init1.jpg (20 KB, 下载次数: 1)
下载附件
2012-12-6 13:35 上传
回复
使用道具
举报
千问
|
2015-9-22 15:53:22
|
显示全部楼层
第一步目标:尽量减少团队之间影响方法:先化整为零,再化零为整 ————根据团队划分代码(或者根据代码划分团队)。
手段:DVCS+私有持续集成服务器+全局持续集成服务器
每个团队都使用GIT做为中间源代码管理工具。这样,团队人员可以先提交到GIT。每个团队有自己的持续集成环境。一但构建成功,触发将代码提交到中心的源代码库,并触发中心源代码的持续集成。有一个专职团队负责全局持续集成的结果跟踪。
益处:
每个团队都可以天天提交代码 (如果这些代码没有让自己的构建失败,就说明至少能够通过初步检验)。任何一个团队的构建坏了,并不影响整个项目,而只是一个团队。有一个专职团队负责全局,不用每个团队都停下来。如果全局持续集成失败了,不用所有的团队停下。
process.jpg (74.6 KB, 下载次数: 3)
下载附件
2012-12-6 13:37 上传
第二步目标:提高反馈速度方法:化整为零,再化零为整————测试分组运行。
手段:并行化与中心仓库(Cruise的并行化与中心仓库)
由于功能多且复杂,测试较多,运行很长。利用Cruise的并行化特点,每个团队将测试分成28组。一旦提交后,Cruise会将其放在28台机器上并行运行。运行后,将所有测试输出和结果上传到同一处(Cruise Server的中心仓库)。
益处:1. 反馈时间大幅度缩短(原来30分钟以上,现在20分钟之内)。
2. 易扩展:如果因测试增多而导致反馈周期长,可通过增加更多的机器解决。
3. 易维护:对于测试分组和构建机器的增减来说,在Cruise中都非常容易,只要在同一处修改配置即可。
4. 易追踪和Debug:所有的信息(包括artifacts)都放在同一处,能过Web访问。
5. Single view (在同一个Web管理页面上,可以监控所有团队的构建状态)。
第三步目标:减少手工操作方法:一键发布————自动化部署
手段:使用持续发布管理工具Cruise (Cruise的dependency + Story Tracker plugin + audit)
由于有很多个团队,每个团队都有多个测试环境。如果全部使用手工部署分花费很多时间。所以,每个团队建立三个构建管道,其目标分别为:(1)得到测试过的 installer;(2)部署到测试环境中;(3)将通过测试的installer部署到演示环境中。前一个构建成功后,就可以触发下一个(自动或手动)。
益处:1. QA可以清晰识别需要测试哪个安装包,该安装包中含有哪些功能
2. QA自己可能很容易地部署测试环境。
3. 易于追踪功能的历史版本(在同一个pipeline中,所有的stage同一版本.而且在使用Pipeline dependency时,版本信息会向下游传递)。
4. 易于掌握对各种部署环境的管理。
deploy1.jpg (71.7 KB, 下载次数: 2)
下载附件
2012-12-6 13:37 上传
使用上述手段后,该项目的持续交付已入佳境。目前可以做到:
所有的构建和部署都是自动化的;开发人员最多在20分钟内就会得到反馈。对于每种环境来说,可以做到每天部署四次。部署无差错:因为是自动化过程,每次的执行步骤都一样。机器资源复用:Cruise自动向165台机器上分发工作进行构建和部署。所有信息都显示在一个屏幕上(Single dashboard view of everything!)开发人员非常高兴:他们可以多次提交而不影响他人。测试人员非常高兴:他们可以很快地得到好的installer,通过自己点一下按钮就完成部署工作。管理人员非常高兴:他们可以马上了解当前的项目状态(哪些版本在测试中,那些版本已经演示了)。很容易了解每个版本里包括哪些功能和修复了哪些缺陷。
回复
使用道具
举报
千问
|
2015-9-22 15:53:22
|
显示全部楼层
作者:乔 梁
个人简介: 持续集成&持续交付领域先行者,敏捷&精益咨询师,致力于帮助企业提高软件交付能力,已为多个大型电信企业、互联网企业、移动设备制造商提供专业的软件交付咨询和培训服务。 现任InfoQ特约编辑,主持《持续集成专栏》,译有《持续交付:发布可靠软件的系统方法》(该书获得2011年Jolt 杰出大奖),《ThoughtWorks 软件开发沉思录》。曾任Thoughtworks资深咨询师,百度项目管理部高级架构师。 新浪微博:http://weibo.com/tony1130
文章出处:qiaoliang’s blog
回复
使用道具
举报
千问
|
2015-9-22 15:53:22
|
显示全部楼层
目前所做的项目采用的就是持续集成!
回复
使用道具
举报
千问
|
2015-9-22 15:53:22
|
显示全部楼层
good job
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行
1
脂肪肝患上了用什么好?
2
哪部剧中有“天火燎原”这个招式,应该是最后几级才有的
3
思铂睿的原厂轮胎好吗
4
和人私了要怎么谈判
5
我们马上要去鹤岗市绥滨县做暑期社会实践,跪求亲们给想一课题!!跪求,跪求!
6
冲过的骏网一卡通100元 2 3张就行 对了给你分
7
急~!毕业后档案怎么处理?
8
我高一化学很差,学完必修一和必修二的有机部分(不全,因为没讲选五)然后选修四讲
9
福州投资移民加拿大的机构有哪些?
10
谁能借我泡泡堂的账号玩几天 要有蓝妹妹 或月野兔的 女的
11
初三物理
12
城固县一中英语书是什么版本?
13
脑筋急转弯,谁能给我答案
14
奥比岛红心短裤换亚麻bob,换的来
15
我的天正建筑8.0安装ID号是:D5RY0PN0K,我的注册码是多少啊?
16
我的中考成绩出来了,但我不相信那个分数,要查科目成绩的话请问怎么查,去哪里查,走怎么过程????
17
贵阳火车站到江苏张家界车费多少?还有需要多长时间才到?
18
怎样将x1乘x2大于m^2化成 x1小于x2小于等于-/m/
19
DNF平民阿修罗和女柔道哪个厉害
20
moto525 打电话的光感问题
21
LM317与LM317BT有区别吗
22
求5d2 拍电影推荐啊
23
家庭安装地暖系统时,要注意哪些原则?
24
成年人上嘴唇里面长泡怎么办?应该叫溃疡的!
25
我想知道那个汽修学校好 请清楚的人回答下
26
现在的百度贴吧无法查自己的回复了吗?
27
深圳能拍微电影的公司推荐一个
28
iPhone4s 拨号音/power锁频时的提示音/输密码开锁时的提示音 一会有 一会没有的纠结呐 设置里面跳过了没有
29
我初中毕业,想找一个三二连读职业学院,你们谁知懂啊好的,推荐我几个!
30
谁知道如何彻底卸载天翼宽带软件?答案最好简单明了!希望各位好心人指点!急!!!
31
金蝶K3物流怎样反结账?
32
梦想世界阴阳怎么能领悟佛的招式
33
最便宜的U盘,哪里有?
34
郭德纲于谦有仇吗
35
梦幻西游2012年7月23号神器任务是什么?
36
山东省烟台市2011-2012学年高二上学期期末考试化学(A)试题答案
37
重庆沙坪坝曾家镇到九龙坡白市驿椒园村怎么坐车?急
38
郑州慢性失眠症怎样治疗??
39
我是2011年3月份审的驾驶证(A2),不知道下次年审是在什么时候,我是连云港人~
40
非直角三角形,如何计算边长? 需要已知几个尺寸? 大概有几种类型?
41
有了注册造价工程师这个证书后还有这个更高一级的证书吗?
42
乐蜂网有假货吗?乐蜂的东西是正品吗?买到不合意的东西乐蜂网可以退货吧?
43
iphone4s 录像和免提没有声音,其他正常,插耳机录像后也有声音。
44
违法建筑的房屋,被政府拆除后,土地的使用权归谁
45
莱芜馨百大地影城7月25日左右演什么电影
46
做艺术设计的,求推荐一本光构成的书,不胜感激!
47
无线防静电手带如何放电?
48
华为c8500s我获取了root后删了一个东西,结果开机后解锁了九宫格后就是黑的。
49
兄弟我也患病了,后来做了手术吗,我也在珠海,希望你帮帮我。
50
《世界有点甜》下载地址 邮箱
[email protected]
51
用3G的手机2G的卡,经常信号不好,去修手机对方说是因为卡和手机不一个网络,是这样吗。
52
求解释:中国政策.jpg ,美国政策.dll 和中国官员.lnk ,美国官员.zip 各是什么意思
53
厦门哪里有办理信用卡的?
54
现在哪个电视台有播爱情公寓1或2?
55
在电脑的itunes里弄了个铃声。 按网上的方法都弄好了。最后按同步。可是一直停留在第二步骤。
56
为什么韩国男星有些要入伍呀??
57
因为高速公路征地,我们家与旁边的一家发生争端(前提地是我们家的,有土地证证明)对强方行说是他的,...
58
哪位亲有甄嬛传1-7完整版发给我谢谢
59
系统这样了怎么调啊==
60
破晓上中长大的贝拉女儿真是合成的吗
61
脸上的擦伤。用完美芦荟胶每天该涂几次
62
你好,请问你收到的红楼之凤还巢还有存档么?能传我一份么?
[email protected]
63
魔域如何用神技卡爆。。还是什么。。在线等你哦。。 大爆有高分!!!
64
纯水机 纯水机
65
如何在超发货币的年代里生存
66
我注册腾讯微博的时候没填身份证,现在在哪填具体的
67
想请问一下怎么选信用卡。
68
梅河口买房子,如果是分期付款可以先付了手付然后在过一年在交另一半吗?明年楼价还会在涨吗?
69
PS怎么做艺术字。
70
DNF第三季哪个平民职业最厉害
71
关于农产品抵税问题
72
59中好吗
73
图片转文本,简单点的方法
74
评职称与所在公司的资质有关吗?评职称过中涉及到公司的内容有哪些?
75
威刚SSD硬盘接映泰TA750+主板,鲁大师测试显示SATA2.5接口,传输速率150MB/S,无法识别SATA3.0。
76
DNF 关于强化武器问题
77
求教路由器冲突问题!
78
《凤凰错:替嫁弃妃》全本还有吗?是全本的吗,可以给我发一份吗?邮箱
[email protected]
谢谢!
79
锐志炫装版2378 , 优惠28000, 什么都没送。这样的价格贵吗
80
考质量专业技术人员职业资格考试作用大吗?
81
想弄台组装电脑台式机的。你们看看这个配置怎么样吖。价格能告诉我么QQ197156可以发邮!!!
82
贵州网站建设公司
83
急求……把下面的中文翻译成英文::我叫…来自…今年十六岁,我的爱好是听歌,看书,还有运动,但是我...
84
有没有学医的或者当医生的啊?想请教一些血常规的一些指标。
85
请问台湾哪家平面磨床好?做模具的要精度高一点.
86
在月经周期内那几天是安全期?
87
中耳炎怎么治疗e
88
嘴巴起泡什么原因,疼的要死,都不能张嘴说话!怎么办?
89
LM339 out口接电容是咋回事
90
各位给推荐哈好方法啊,焦虑症怎么治疗
91
a的3/2与b的和是186,a的8/5与b相等,a是()b是()
92
谁知道扬州茂业百货7.27员工日具体细则和活动的?有会员卡就可以入场么?还有折扣怎样?
93
潘玮柏第九张专辑名字叫什么
94
lol怎么降低惩罚等级?我都已经5级惩罚了,有没有好办法
95
4hn3+5o2=4x+6h20 求x值 A N2 BNO CNO2 DN203 这题没错吗?
96
下雪时,兔子吃什么?
97
qq飞车冰霜巧克力怎么过?
98
帮忙啊···急需一篇英语范文,道歉信,题目在下面,
99
求完整版《天珠变》TXT,谢谢
100
上海市浦光中学和金陵中学对比起来哪个学校好