`
cutecoot
  • 浏览: 120579 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

转:异地分布式敏捷软件开发 (Distributed Agile Software Development)

 
阅读更多

异地分布式敏捷软件开发 (Distributed Agile Software Development)

异地分布式软件开发(Distributed Software Development)是指由多个位于不同地理位置的团队进行同一个软件项目的开发过程。这个词越来越频繁的出现在各种技术媒体中。

异地分布式软件开发不同于外包,它建立在平等关系的两个团队之间。通常是一个公司的不同分公司或办公室间的协作,他们之间大多不存在博弈的合同关系。而外包是指一个公司将其软件系统的开发委托给另一个公司或组织完成。二者之间是合同的甲乙方关系。

但无论是异地分布式软件开发或是外包,可以接触到实际客户的一端一般称为on-site,另一端可相应的称为off-site,他们可以根据地理位 置分为三类:on-shore(在岸,指在同一个国家或同一个时区内),near-Shore(近岸,在接近的国家和地区中)和off-Shore(离 岸,通常在时差8小时以上)。如下表。

offsite on shore near shore off shore
Distributed Development 北京办公室 - 西安办公室之间 印度分公司 - 中国分公司 硅谷总公司 - 中国或印度分公司
Outsourcing
Development
北京某公司 – 广州另一公司 东京某公司 - 大连另一公司 欧洲某公司 - 中国另一公司

异地分布式开发的组织方式

异地分布开发的组织方式有很多种。最常见的一种是公司将完整的团队组织结构分布在两地,每个团队都有本地项目经理,需求分析师,开发者以及测试。同时公司设定项目总负责人角色,负责两地的沟通与协调。

 

有的公司将需求分析人员放在on-site一端,开发者、测试人员和项目经理在off-site一方,同时在本地也保持常规的需求分析师。也有公司将测试人员和开发人员分放在不同地方,一方面开发,另一方面利用时差,在夜间测试并在第二天及时反馈测试结果。

 

各种组织方式都有其不同的适用场合。然而他们的共同点在于,都是注重micro-management,即加强在本地团队中项目管理和协调,而不是由一个人同时直接管理两地的活动。同时,也尽量保证团队两边都具有项目协调人、本地项目经理、需求分析师等辅助角色。

基本原则:极尽交流之能事

异地分布软件开发面临的最大问题是交流问题。随着人员距离的增加,交流效率将大大降低(参见Alistair Cockburn的文章),同时交流成本将极大提高。很多时候on-site一端团队不能把正确的需求传递到off-site一端,这直接造成产品质量的下降。

为了使避免这种情况,应尽量采用一切手段来提高交流的效果。例如,项目经理和团队成员都需要了解其他人的工作状态,一个技巧是可以将你的MSN或Y!名称后缀写上你在做哪一块的需求。并可以随时和同事通过IM进行交流。

 

每天的定时会议将成为很重要的一个很重要的交流方式。如果团队的人数较少,大家可以按照站立会议的方式在电话会议系统中说明自己的情况和遇到的问 题。如果人数较多,一种可替代的方式是每个团队自己进行每日例会,并由个项目的项目经理和需求分析人员进行另外的会议以便协调工作。

如果两个团队时差较大,例如中国北京时间和美国东部时间时差12-3小时,想要进行直接的电话会议交流很困难。如果遇到3个处于不同时区的团队,更 是经常不可能找到一个合适的时间来进行任何的会议。在国际化的公司中,起早贪黑的进行几地的电话会议很常见,但这却不适用于整个开发团队。对这种情况,每 日的开发状态邮件是很有用的。每日开发结束后由项目经理或成员来根据团队的情况来撰写一天的总结,并发送给远端的团队。

交流的障碍经常发生在陌生人之中,如果两地的开发人员互不熟悉,可以考虑将双方人员的照片贴在墙上,以增加熟悉感。可行的话,进行可视会议和当面的会谈。尽量减少陌生感,使交流效果提升。

任何交流方式都比不上面对面的交流。异地开发时,off-site一端很容易丢失on-site一端与客户交流的语义上下文和环境。如果情况允许, 公司应该设立常规的出差和轮换制度。让一部分的团队成员到另一端,见一见一起工作的同事,了解一下客户的需求和感受一下不同的环境。

敏捷开发过程的改进

般的敏捷过程中,都会有一个初始阶段,在这个阶段了解开发需求和制定发布计划。要进行这样的活动,最理想的办法是让所有人都出差到on-site一 端,一起了解需求和建立共识。这将会对后面的开发有很大帮助。如果由于人数或成本不可行,至少要派遣所有的需求分析师和项目经理、协调人以及部分测试人员 到场参与。对于迭代一级的计划,应该由两地的项目经理和需求分析师提前进行计划会议并做出决定。

日常的项目管理工作中,采用卡片墙的方式只适用in-house的开发。在异地开发中,为了使得每个团队都可以了解到团队任务,至少需要在两边开发室都设立卡片墙,并保持同步。可以采用在线工具帮助进行项目跟踪,例如MingleTrac,都是适用的在线工具,同时也是在线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小时开发。然而,异地开发带来了高昂的交流和管理成本,如果处理不当将直接导致项目或产品的失败。

近年来随着国内软件公司业务的发展,异地开发项目将会越来越多。全球化的进程也会使得外国公司开展更多类似的开发。异地开发项目将会逐渐发展和普遍。可以想像,多年以后,如果一个公司没有异地开发的团队,将会是多么的令人诧异。

分享到:
评论

相关推荐

    异地分布式敏捷软件开发

    异地分布式软件开发(Distributed Software Development)是指多个位于不同地理位置的团队合作开发同一个软件项目的过程。这种方式越来越多地被提及和应用在当今的技术领域。 **区别于外包**: - **平等关系**:...

    MATLAB代码:基于分布式ADMM算法的考虑碳排放交易的电力系统优化调度研究 关键词:分布式调度 ADMM算法 交替方向乘子法

    MATLAB代码:基于分布式ADMM算法的考虑碳排放交易的电力系统优化调度研究 关键词:分布式调度 ADMM算法 交替方向乘子法 碳排放 最优潮流 参考文档:《A Distributed Dual Consensus ADMM Based on Partition for DC...

    Go-分布式定时任务库distributed-cron

    分布式定时任务库 `distributed-cron` 是一个专为 Go 语言设计的高级工具,用于构建可扩展、可靠的分布式系统中的定时任务。它充分利用了 Go 的并发特性,提供了一种高效的方式来管理和执行周期性的任务,同时支持在...

    EasiDARM:基于分布式的物联网设备自适应注册方法.pdf

    从标签“分布式”、“分布式系统”、“分布式开发”、“参考文献”、“专业指导”可以推断,文档内容可能会涉及到分布式系统的设计原则、开发方法,以及与物联网设备自适应注册相关的最新研究文献和实践指南。...

    Distributed_agile_development_at_microsoft_patterns_and_practices.pdf

    分布式敏捷开发是指在不同的地理位置上的团队协作进行软件开发的一种方式。这种方式能够充分利用全球资源的优势,提高工作效率并降低开发成本。但同时也带来了一系列挑战,例如沟通障碍、文化差异、时区差异等。 ##...

    推荐阅读:分布式系统架构经典资料

    - **Making Reliable Distributed Systems in the Presence of Software Errors**:这篇论文探讨了如何在软件错误普遍存在的情况下构建可靠的分布式系统。 - **Designing Data-Intensive Applications**:这本书...

    分布式 Java文档(Distributed Java).pdf

    分布式 Java(Distributed Java)

    DistributedLock:redis分布式锁

    分布式锁是一种在分布式系统中实现锁机制的技术,用于在多节点之间协调对共享资源的访问。Redis 是一种广泛使用的内存数据...在实际开发中,应充分考虑系统的性能、可用性和安全性,以确保分布式锁的正确性和高效性。

    Distributed Algorithms (中文名:分布式算法)

    Distributed Algorithms (中文名:分布式算法)

    Visual Basic6.0分布式应用程序开发

    《Visual Basic6.0分布式应用程序开发》是一本深入探讨如何使用Visual Basic6.0进行分布式系统构建的专业教程。分布式应用程序是指由多个独立组件通过网络进行通信和协作来完成任务的软件系统。在VB6.0中,开发者...

    DistributedLock:用于分布式同步的.NET库

    分布式锁DistributedLock是一个.NET库,它基于各种基础技术提供了健壮且易于使用的分布式互斥锁,读写器锁和信号灯。 使用DistributedLock,跨多个应用程序/机器同步对代码区域的访问非常简单: using ( await ...

    分布式系统Distributed Systems: Concepts and Design 第五版 习题答案

    分布式系统是计算机科学中的一个重要领域,它涉及到多个独立计算实体通过网络进行通信和协作,以完成共同的任务。《Distributed Systems: ...这将为从事分布式系统开发、运维或研究工作的专业人士打下坚实的基础。

    一种基于Internet的分布式软件生产线框架.pdf

    2. 组件共享与复用:利用Internet上共享的软件工具,建立标准化的软件组件,使得在分布式开发过程中可以复用这些组件,从而减少重复开发,提高效率。 3. 分布式协同:在分布式软件生产线中,各个参与者,无论地理...

    2007年东北大学博士入学考试试题-分布式操作系统

    4. **分布式文件系统**:研究GFS(Google File System)、HDFS(Hadoop Distributed File System)等分布式文件系统的工作原理,包括数据的分块存储、副本管理、故障恢复和数据一致性策略。 5. **命名与定位服务**...

    快速分布式数据挖掘 fast distributed data mining

    本项目"快速分布式数据挖掘(fast distributed data mining)"是基于MPI(Message Passing Interface)在Linux平台上实现的C++程序,旨在解决海量数据集上的挖掘任务。 MPI是一种用于分布式内存系统间进程间通信的...

    分布式数据库课后习题答案整理

    "分布式数据库课后习题答案整理" 分布式数据库系统概述: 分布式数据库系统是一个物理上分散而逻辑上集中的系统,它使用计算机网络将地理位置分散而管理和控制又需要不同程度集中的多个逻辑单位(通常是集中式...

    java课程系统源码-CS465--Distributed-Systems:为分布式系统课程开发的Java源代码

    【标题】"java课程系统源码-CS465--Distributed-Systems" 是一个与Java编程语言相关的项目,专门用于教学分布式系统课程。这个源码库可能是为了帮助学生和教师理解分布式系统的概念、设计和实现而创建的。分布式系统...

    并行与分布式系统概论ppt

    * DSM(Distributed Shared Memory)的概念:在分布式系统中,多个节点之间共享的内存空间 * DSM 的应用:分布式数据库系统、分布式文件系统等 七、分布式事务处理 * 分布式事务处理的概念:在分布式系统中,多个...

Global site tag (gtag.js) - Google Analytics