异地分布式软件<nobr><strong style="border: 0px none ; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = true;isShowAds2 = true;KeyGate_ads.Move(this,"","","-100835","开发","ROR%u5E94%u7528%u63A2%u7D22","http%3A//www.sd2china.cn/track1.html", event)' onmouseout="isShowAds = false;isShowAds2 = false" onclick='javascript:window.open("http://s4.17luntan.com/ClickPortal/WebClick.aspx?id=-100835&k=%u5F00%u53D1&siteid=0098295a-e262-40f7-ae50-7a6fbbdb678b&url=http%3A//news.csdn.net/n/20070615/105398.html&gourl=http%3A//www.sd2china.cn/track1.html&parm=F58A86EAFE939BCE134840E1821F971EE4107205577AD497&alliedsiteid=0");' class="kgb">开发</strong></nobr>(Distributed Software Development)是指由多个位于不同地理位置的团队进行同一个软件<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u9879_u76EE";KeyGate_ads.ShowGgAds(this,"_u9879_u76EE",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u9879_u76EE"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=ByQbY4fatR5PgJI666wP5kYH_C6qU703iz77_A8CNtwHgmBcQEhgSIK2F0A0oFDgAUOvh_9L______wFgndnhgfAFqgEKMjAwMDAzNjEyN7IBDW5ld3MuY3Nkbi5uZXTIAQHaAStodHRwOi8vbmV3cy5jc2RuLm5ldC9uLzIwMDcwNjE1LzEwNTM5OC5odG1sqQJVTVCaSK2CPsgCup70BKgDAegD_wLoA9IC9QMCBAAA&num=18&adurl=http://www.lionspd.com&client=ca-pub-5186439242807756");GgKwClickStat("项目","www.lionspd.com","afc","2000036127");' class="kgb">项目</strong></nobr>的开发过程。这个词越来越频繁的出现在各种技术媒体中。
异地分布式软件开发不同于外包,它建立在平等关系的两个团队之间。通常是一个<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u516C_u53F8";KeyGate_ads.ShowGgAds(this,"_u516C_u53F8",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u516C_u53F8"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=BNyIK4fatR5PgJI666wP5kYH_C8zbxSTcz6DvA8CNtwGA6jAQARgBIK2F0A0oFDgAUJHE-Kj4_____wFgndnhgfAFqgEKMjAwMDAzNjEyN7IBDW5ld3MuY3Nkbi5uZXTIAQHaAStodHRwOi8vbmV3cy5jc2RuLm5ldC9uLzIwMDcwNjE1LzEwNTM5OC5odG1sqQJVTVCaSK2CPsgCoLN2qAMB6AP_AugD0gL1AwIEAAA&num=1&adurl=http://www.city-hot.cn&client=ca-pub-5186439242807756");GgKwClickStat("公司","www.city-hot.cn","afc","2000036127");' class="kgb">公司</strong></nobr>的不同分公司或办公室间的协作,他们之间大多不存在博弈的合同关系。而外包是指一个公司将其软件系统的开发委托给另一个公司或组织完成。二者之间是合同的甲乙方关系。
但无论是异地分布式软件开发或是外包,可以接触到实际客户的一端一般称为on-site,另一端可相应的称 为off-site,他们可以根据地理位置分为三类:on-shore(在岸,指在同一个国家或同一个时区内),near-Shore(近岸,在接近的国 家和地区中)和off-Shore(离岸,通常在时差8小时以上)。如下表。
offsite
|
on shore
|
near shore
|
off shore
|
Distributed Development
|
北京办公室 - 西安办公室之间
|
印度分公司 - 中国分公司
|
硅谷总公司 - 中国或印度分公司
|
Outsourcing Development
|
北京某公司 – 广州另一公司
|
东京某公司 - 大连另一公司
|
欧洲某公司 - 中国另一公司
|
异地分布式开发的组织方式
异地分布开发的组织方式有很多种。最常见的一种是公司将完整的团队组织结构分布在两地,每个团队都有本地<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u9879_u76EE_u7ECF_u7406";KeyGate_ads.ShowGgAds(this,"_u9879_u76EE_u7ECF_u7406",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u9879_u76EE_u7ECF_u7406"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=ByQbY4fatR5PgJI666wP5kYH_C6qU703iz77_A8CNtwHgmBcQEhgSIK2F0A0oFDgAUOvh_9L______wFgndnhgfAFqgEKMjAwMDAzNjEyN7IBDW5ld3MuY3Nkbi5uZXTIAQHaAStodHRwOi8vbmV3cy5jc2RuLm5ldC9uLzIwMDcwNjE1LzEwNTM5OC5odG1sqQJVTVCaSK2CPsgCup70BKgDAegD_wLoA9IC9QMCBAAA&num=18&adurl=http://www.lionspd.com&client=ca-pub-5186439242807756");GgKwClickStat("项目经理","www.lionspd.com","afc","2000036127");' class="kgb">项目经理</strong></nobr>,需求分析师,开发者以及测试。同时公司设定项目总负责人角色,负责两地的沟通与协调。
有的公司将需求分析人员放在on-site一端,开发者、测试人员和项目经理在off-site一方,同时在本地也保持常规的需求分析师。也有公司将测试人员和<nobr><strong style="border: 0px none ; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = true;isShowAds2 = true;KeyGate_ads.Move(this,"","","-100847","开发人员","%u8BBE%u8BA1%u53EF%u91CD%u7528SWT%20%u6784%u4EF6","http%3A//ibm.csdn.net/ISN_J.aspx%3Faction%3DJMP%26pointid%3D2486", event)' onmouseout="isShowAds = false;isShowAds2 = false" onclick='javascript:window.open("http://s4.17luntan.com/ClickPortal/WebClick.aspx?id=-100847&k=%u5F00%u53D1%u4EBA%u5458&siteid=0098295a-e262-40f7-ae50-7a6fbbdb678b&url=http%3A//news.csdn.net/n/20070615/105398.html&gourl=http%3A//ibm.csdn.net/ISN_J.aspx%3Faction%3DJMP%26pointid%3D2486&parm=F58A86EAFE939BCE134840E1821F971EE4107205577AD497&alliedsiteid=0");' class="kgb">开发人员</strong></nobr>分放在不同地方,一方面开发,另一方面利用时差,在夜间测试并在第二天及时反馈测试结果。
各种组织方式都有其不同的适用场合。然而他们的共同点在于,都是注重micro-management,即加强在本地团队中<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u9879_u76EE_u7BA1_u7406";KeyGate_ads.ShowGgAds(this,"_u9879_u76EE_u7BA1_u7406",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u9879_u76EE_u7BA1_u7406"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=ByQbY4fatR5PgJI666wP5kYH_C6qU703iz77_A8CNtwHgmBcQEhgSIK2F0A0oFDgAUOvh_9L______wFgndnhgfAFqgEKMjAwMDAzNjEyN7IBDW5ld3MuY3Nkbi5uZXTIAQHaAStodHRwOi8vbmV3cy5jc2RuLm5ldC9uLzIwMDcwNjE1LzEwNTM5OC5odG1sqQJVTVCaSK2CPsgCup70BKgDAegD_wLoA9IC9QMCBAAA&num=18&adurl=http://www.lionspd.com&client=ca-pub-5186439242807756");GgKwClickStat("项目管理","www.lionspd.com","afc","2000036127");' class="kgb">项目管理</strong></nobr>和协调,而不是由一个人同时直接管理两地的活动。同时,也尽量保证团队两边都具有项目协调人、本地项目经理、需求分析师等辅助角色。
基本原则:极尽交流之能事
异地分布软件开发面临的最大问题是交流问题。随着人员距离的增加,交流效率将大大降低(参见Alistair Cockburn的文章),同时交流成本将极大提高。很多时候on-site一端团队不能把正确的需求传递到off-site一端,这直接造成产品质量的下降。
为了使避免这种情况,应尽量采用一切手段来提高交流的效果。例如,项目经理和团队成员都需要了解其他人的工作状态,一个技巧是可以将你的MSN或Y!名称后缀写上你在做哪一块的需求。并可以随时和同事通过IM进行交流。
交流频度和价值图,Vincent Massol,2004
每天的定时会议将成为很重要的一个很重要的交流方式。如果团队的人数较少,大家可以按照站立会议的方式在<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u7535_u8BDD_u4F1A_u8BAE_u7CFB_u7EDF";KeyGate_ads.ShowGgAds(this,"_u7535_u8BDD_u4F1A_u8BAE_u7CFB_u7EDF",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u7535_u8BDD_u4F1A_u8BAE_u7CFB_u7EDF"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=Bb0OR4fatR5PgJI666wP5kYH_C5LAtxjG9tiUB8CNtwGQ9B0QDRgNIK2F0A0oFDgAUObBtOMHYJ3Z4YHwBaABxKik_gOqAQoyMDAwMDM2MTI3sgENbmV3cy5jc2RuLm5ldMgBAdoBK2h0dHA6Ly9uZXdzLmNzZG4ubmV0L24vMjAwNzA2MTUvMTA1Mzk4Lmh0bWypAlVNUJpIrYI-qAMB6AP_AugD0gL1AwIEAAA&num=13&adurl=http://www.rd-bodyguard.com&client=ca-pub-5186439242807756");GgKwClickStat("电话会议系统","www.rd-bodyguard.com","afc","2000036127");' class="kgb">电话会议系统</strong></nobr>中说明自己的情况和遇到的问题。如果人数较多,一种可替代的方式是每个团队自己进行每日例会,并由个项目的项目经理和需求分析人员进行另外的会议以便协调工作。
如果两个团队时差较大,例如中国北京时间和美国东部时间时差12-3小时,想要进行直接的<nobr><strong style="border: 0px none ; margin: 0px; padding: 0px; color: rgb(0, 0, 255); font-weight: normal; text-decoration: underline;" onmouseover='isShowAds = false;isShowAds2 = false;isShowGg = true;InTextAds_GgLayer="_u7535_u8BDD_u4F1A_u8BAE";KeyGate_ads.ShowGgAds(this,"_u7535_u8BDD_u4F1A_u8BAE",event)' onmouseout='isShowGg = false;InTextAds_GgLayer="_u7535_u8BDD_u4F1A_u8BAE"' onclick='javascript:window.open("http://pagead2.googlesyndication.com/pagead/iclk?sa=l&ai=Bb0OR4fatR5PgJI666wP5kYH_C5LAtxjG9tiUB8CNtwGQ9B0QDRgNIK2F0A0oFDgAUObBtOMHYJ3Z4YHwBaABxKik_gOqAQoyMDAwMDM2MTI3sgENbmV3cy5jc2RuLm5ldMgBAdoBK2h0dHA6Ly9uZXdzLmNzZG4ubmV0L24vMjAwNzA2MTUvMTA1Mzk4Lmh0bWypAlVNUJpIrYI-qAMB6AP_AugD0gL1AwIEAAA&num=13&adurl=http://www.rd-bodyguard.com&client=ca-pub-5186439242807756");GgKwClickStat("电话会议","www.rd-bodyguard.com","afc","2000036127");' class="kgb">电话会议</strong></nobr>交 流很困难。如果遇到3个处于不同时区的团队,更是经常不可能找到一个合适的时间来进行任何的会议。在国际化的公司中,起早贪黑的进行几地的电话会议很常 见,但这却不适用于整个开发团队。对这种情况,每日的开发状态邮件是很有用的。每日开发结束后由项目经理或成员来根据团队的情况来撰写一天的总结,并发送 给远端的团队。
交流的障碍经常发生在陌生人之中,如果两地的开发人员互不熟悉,可以考虑将双方人员的照片贴在墙上,以增加熟悉感。可行的话,进行可视会议和当面的会谈。尽量减少陌生感,使交流效果提升。
任何交流方式都比不上面对面的交流。异地开发时,off-site一端很容易丢失on-site一端与客户 交流的语义上下文和环境。如果情况允许,公司应该设立常规的出差和轮换制度。让一部分的团队成员到另一端,见一见一起工作的同事,了解一下客户的需求和感 受一下不同的环境。
敏捷开发过程的改进
般的敏捷过程中,都会有一个初始阶段,在这个阶段了解开发需求和制定发布计划。要进行这样的活动,最理想的 办法是让所有人都出差到on-site一端,一起了解需求和建立共识。这将会对后面的开发有很大帮助。如果由于人数或成本不可行,至少要派遣所有的需求分 析师和项目经理、协调人以及部分测试人员到场参与。对于迭代一级的计划,应该由两地的项目经理和需求分析师提前进行计划会议并做出决定。
日常的项目管理工作中,采用卡片墙的方式只适用in-house的开发。在异地开发中,为了使得每个团队都 可以了解到团队任务,至少需要在两边开发室都设立卡片墙,并保持同步。可以采用在线工具帮助进行项目跟踪,例如Mingle或Trac,都是适用的在线工 具,同时也是在线Wiki或共享知识库。
项目协调人,应当制定完善的交流计划和交流机制。例如前文提到的每日的例会和每日开发状态邮件,每周的需求交流计划,问题的提出和反应机制等等。这些应当制定成为团队守则来遵循,并随着实际情况的变化修订。交流不怕多,只怕不充分。
一个共享的代码版本控制系统是必须的。例如在公司内网建立一个SVN并通过VPN来使用。On-site和 off-site团队可建立自己单独的持续集成环境,但需要保持系统环境的一致。两方的开发人员都应该保证每日离开办公室前的提交通过集成。这样可以避免 异地团队开始开发不至于被失败的集成所耽搁。
基本的敏捷时间必不可缺,例如测试,尤其是功能测试。On-site的QA应当在需求确定的时候制定好验收条件。一个描写良好的验收条件会对开发人员有所帮助。尤其是在On-site一端不能及时解答问题的时候,会起到很大的作用。
每个迭代结束时,应尽量安排一个两地同步的演示会议。让所有人都在电话会议上看到这个迭代的成果。迭代后的总结与回顾也应当两地一起进行,如果人数和条件不允许,可以分别进行,并互相通报回顾结果和改进方法。
离岸团队的参与度
多团队中,处于on-site的成员由于可以接触到客户,他们的话语权可能会被放大,使得on-site一 边的人倾向于命令式的消息传递,直接指派需求和开发进度,而忽视了对需求背景情况和上下文进行介绍。这种情况可能造成off-site一端团队产生抵触心 里,从而导致项目的失败。
解决方法是提高off-site团队的参与度。如制度性的进行人员轮换,让两端的团队成员有所接触,并互相 熟识。定期组织两个团队的共同活动。如果都处于一个时区,可以考虑进行每周的Learning Lunch,大家在互相能看到视频的情况下一起吃饭和听讲座。讲座内容可以是任何话题,例如一些项目相关的技术决策等等。
不要忽视offsite团队的任何意见和建议,他们在很多时候能从另一个侧面对项目提出见解。鼓励offsite团队决策和发起讨论,这样可以提高他们的参与度。
实施异地开发的最初目的是为了降低人力成本和运营成本,一些跨时区的异地开发还可以提高时间利用效率,实现全球24小时开发。然而,异地开发带来了高昂的交流和管理成本,如果处理不当将直接导致项目或产品的失败。
近年来随着国内软件公司业务的发展,异地开发项目将会越来越多。全球化的进程也会使得外国公司开展更多类似的开发。异地开发项目将会逐渐发展和普遍。可以想像,多年以后,如果一个公司没有异地开发的团队,将会是多么的令人诧异。
分享到:
相关推荐
本文将介绍在异地分布式敏捷软件开发中进行时间成本估算的研究方法,并对COCOMOII模型进行分析和改进。 ### 异地分布式敏捷开发的特点 异地分布式敏捷软件开发允许开发团队成员在物理位置上分散,可以是不同城市、...
本文围绕异地分布式敏捷开发团队的协作问题,通过合作博弈理论,提出了一个适用于异地分布式团队的适应性协作框架,并对该框架进行详细分析。 合作博弈理论是一种研究具有共同目标的参与者之间的互动关系的理论,它...
本文基于SIS模型,探讨了如何促进异地分布式敏捷软件开发团队中的知识共享,旨在通过模拟传染病的传播模式来解析团队成员间的知识传递和共享过程。 首先,从敏捷软件开发角度出发,敏捷方法强调适应性和响应性,...
### 异地分布式敏捷软件开发概述 #### 一、异地分布式软件开发定义及特点 异地分布式软件开发(Distributed Software Development)是指多个位于不同地理位置的团队合作开发同一个软件项目的过程。这种方式越来越...
基于 Spring + SpringMVC + Mybatis 分布式敏捷开发系统架构,提供整套公共微服务服务模块:集中权限管理(单点登录)、内容管理、支付中心、用户管理(支持第三方登录)、微信平台、存储系统、配置中心、日志分析、...
#资源达人分享计划#
总体而言,该文献探讨了异地分布式协同开发中任务分配优化的问题,通过采用改进的混合蛙跳算法建立任务分配模型,并结合Scrum开发框架进行任务分解,以期提升敏捷性,并通过模拟实验验证了算法的有效性。这些研究...
姜继娇和王宗宇在其研究论文《异地分布式多SCRUM项目产品Backlog分解过程影响因素分析》中,深入探讨了影响产品Backlog分解过程的几个重要因素。通过问卷调查和数据分析的方式,他们研究了优先级设置、团队地理位置...
基于Spring+SpringMVC+Mybatis分布式敏捷开发系统架构,提供整套公共微服务服务模块:集中权限管理(单点登录)、内容管理、支付中心、用户管理(支持第三方登录)、微信平台、存储.zip基于Spring+SpringMVC+Mybatis...
本项目是基于Spring和SpringMVC开发的分布式敏捷开发系统架构设计源码,主要使用Java进行开发。项目共包含1251个文件,其中Java源代码文件379个,XML配置文件198个,Properties配置文件159个,JavaScript源代码文件...
基于Spring+SpringMVC+Mybatis分布式敏捷开发系统架构,提供整套公共微服务服务模块:集中权限管理(单点登录)、内容管理、支付中心、用户管理(支持第三方登录)、微信平台、存储系统、配置中心、日志分析、任务和...
本文主要探讨了基于面向对象技术的复用机制在分布式Web软件开发中的应用。 首先,面向对象技术(OOP)是软件开发中的一种核心范式,它以客观世界中的实体作为设计对象的参考,通过类和对象的概念来构建软件系统。...
《敏捷软件开发方法与实践》第1章阐述了敏捷软件开发方法出现的历史背景、敏捷宣言、敏捷原则及最新动态;第2章介绍了常见的敏捷软件开发方法及其相互间的简单比较;在第3章至第5章中,作者结合自己的敏捷项目开发...
基于Spring+SpringMVC+Mybatis分布式敏捷开发系统架构,提供整套公共微服务服务模块:集中权限管理(单点登录)、内容管理、支付中心、用户管理(支持第三方登录)、微信平台、存储系统、配置中心、日志分析、任务和...
该项目是一款基于Spring+SpringMVC+Mybatis的J2EE企业级分布式敏捷开发系统架构设计源码,包含1173个文件,涵盖355个Java源文件、195个XML配置文件、142个属性文件、114个JSP文件、110个JavaScript文件、51个PNG图片...