HarmonyOS开发者限时福利来啦!最高10w+现金激励等你拿~ 了解详情
写点什么

如何实现分布式开发

  • 2017-04-09
  • 本文字数:2359 字

    阅读完需:约 8 分钟

良好的分布式开发依赖于有效的沟通:Abby Bangser 和 Bhagya Perera 解释说, 在各式各样的沟通过程中,需要寻找到正确的方法实现高效和可靠。要建立相互之间的共鸣,鼓励及时地反馈,并关注大家的积极性。让团队成员更有参与感和创造性,从最初的想法到完整交付出产品的过程中,都要让分布式团队共同承担所有权和责任。

ThoughtWorks 的质量分析师 Abby Bangser 和里德商业信息公司的高级分析师 Bhagya Perera,在 2017 年欧洲测试会议中谈到了洞察分布式开发。InfoQ 工作之一就是负责推荐会议问答、内容总结和文章汇总。

InfoQ 采访了 Abby Bangser 和 Bhagya Perera,邀请他们谈谈分布式开发中的一些问题,例如有哪些主要挑战,组织应该如何应对这些挑战,如何提高分布式团队之间协作和沟通,分布式工作是如何影响团队的,以及如何利用现场和远程测试各自带来的好处等等。

InfoQ:分布式开发的主要挑战是什么?

Bhagya Perera:沟通绝对是首要的。在需要讨论时,团队往往会“忘记”或“忽视”沟通,这可能会导致工作混淆,甚至失去动力。文化差异、时区不同、工具不同很大程度也会导致这个问题发生。举一个典型的例子,出于对安全规则的考虑,在关联不同特定领域的过程中,我们也会碰到这样的挑战。

Abby Bangser : 我同意沟通是其他挑战的基础。不能面对面建立互信关系,确实是真正的挑战,会带来合作的不便。还要补充一点,关注那些和业务不在一起的团队的动力是重要的。给他们指派“容易的”工作(往往并不容易)其实是一个陷阱,最后可能真的导致失去动力。

InfoQ:组织如何应对这些挑战?

Bangser:像其他事物一样,意识到挑战并进行公开讨论是第一步。我发现,从最初想法到最后产出的过程中,如果每个团队成员都拥有完整交付产品的所有权和责任,在解决沟通问题时,他们会更投入并更有创造性。要做到这一点,简便的方法就是用特征而不是活动来拆分工作。

Perera:分布式的成功主要取决于团队间是否愿意进行更多的沟通。不仅沟通日常工作,还需要检查基本的需求,比如连通性、沟通明晰、甚至需求讨论以及不同团队之间的工作评估。要建立相互之间的共鸣,这能鼓励远距离的团队积极进行反馈,也意味着能指出问题同时积极解决问题。

InfoQ:对分布式团队有什么可以提高沟通和协作的建议?

Perera:识别团队的沟通问题是一个好的开始。用开放的心态,并带着解决它的意图来讨论问题。更好地了解团队,了解他们的文化和背景。不管是负面的还是正面的反馈,要学习如何传达。建立共鸣、分享利益,建立工作以外的关系,这有助于树立信任。如果你开始听进去这些建议,其实有很多事情可以做。

Bangser:首先,我会从明确你的现场团队成员之间有什么不同的沟通类型开始。可能有正式的围绕预期的会议,有非正式的头脑风暴、白板会议,或者昨天晚上你做了什么之类的社交性玩笑,也许还有别的什么。然后我会建议考虑下如何不在同一个办公室与团队成员沟通。你可能会发现,所使用的沟通方式都已被包括其中,而他们几乎都围绕在正式的会议类型中(也许还有一些非正式的在线聊天)。增加其他沟通方式的方法是找到支持它们的工具,也许在视频会议中用额外的相机对着白板,也许在“喝咖啡的休息时间”用聊天工具说说每天的笑话或搞个小测验。总之要寻找各种方法,就像在现场一样,在跨越不同的地点进行高效可靠和多样化的沟通。

InfoQ:对于分布式团队来说,哪些开发活动最受影响?

Perera:我个人认为,任何移交到分布式团队的活动(不仅仅是测试),都会带来额外的复杂性。在第一个问题中讨论的所有挑战都将升级,分布式团队会感觉到受冷落。分布式团队要求主动分享信息,但如果项目只发生在一个地方,信息的可用性会让团队运行得更加顺畅。特别对于团队内的隐性知识,成功的分布式团队会鼓励更多的文档工作、更多的讨论和更多的依赖。而这一切,都取决于有效沟通。

Bangser:虽然跨时区、口音和文化的沟通很具挑战性,但我个人并不总是觉得它有多么困难。我所参与的一些分布式团队已经做得很完美,通过很多直观的事例、经常使用并保持更新的文档,以及非常积极的意识来分享每天的成功和挑战,他们能识别和纠正沟通的差距。“走廊谈话”是深受分布式协作负面影响的沟通方式,通过随机的交谈(尤里卡时刻)或许能够让人豁然开朗,但这种效果难以复制。所以我希望有一个更好的解决方案,来支持上面那些良好的习惯。

InfoQ:我们如何能够利用现场和远程测试各自的好处?

Perera:我希望看到分布式团队成员成为一个整体,它本该如此。复杂性随着现场和分布式团队的分离就开始了,而多样性总是带来不同的经验和想法,这会让产品成功。时区的差异和语言的差异会让大家都觉得沮丧,还会影响整体的质量。我个人很喜欢分布式测试,因为远程团队往往有丰富的经验。他们可以在不同的客户之间轮换工作,这意味着他们接触到的问题、技术和流程,我们都可以借鉴。现场测试人员也有优势,他们能与那些间接为产品做贡献的人,以及与带来不同测试理念的人建立良好的对话。

Bangser:如果我们把测试定义为对一个产品新的理解,显然有利于重视现场和分布式团队成员的投入。我更喜欢看到一群能容易沟通的人可以对整体特征进行分析、设计、实施和验证,就像在同一个地方工作的团队那样。如果你发现自己处于一个根据活动来拆分(在一个地方开发,在另一个地方测试)的团队中,我会建议先明确团队看重哪些基于质量的活动并打算利用它们,根据谁会在这些活动中取得最大的成功来进行划分。分布式团队成员也许没有参与过新功能的所有决定,让他们来进行“黑盒”风格的测试,将会非常有价值。

查看英文原文 Making Distributed Development Work


感谢薛命灯对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-04-09 19:003746
用户头像

发布了 43 篇内容, 共 34.2 次阅读, 收获喜欢 136 次。

关注

评论

发布
暂无评论
发现更多内容

东汉末年,他们把「服务雪崩」玩到了极致

悟空聊架构

熔断 28天写作 服务雪崩 悟空聊架构 12月日更

资讯|WebRTC M95 更新

网易云信

WebRTC

【漫画】数据云,真香在哪?

星环科技

大数据

元气部落盲盒系统开发元气部落app开发

风行无疆

未来企业如何应对人才之争

WorkPlus

一文讲述数仓组件SysCache

华为云开发者联盟

事务 存储 GaussDB(DWS) SysCache 缓存信息

给弟弟的信第15封|情绪控制的重要性

大菠萝

28天写作

手写清除console的loader

编程江湖

前端开发

5G专网+区块链:构筑智慧政务“安全信任基石”

CECBC

Java 集合框架面试问题集锦

编程江湖

面试题 JAVA开发 java编程

简述移动端IM开发的那些坑:架构设计、通信协议和客户端

WorkPlus

解决rabbitmq消息队列的顺序及重复消费问题

编程江湖

大数据

Java Web开发之API Boy的进阶之路

@零度

Java web API boy

Android aapt 在 Mac 和 Windows 上使用方法小结

阿策小和尚

28天写作 Android 小菜鸟 12月日更

华为硬件配置命令,建议收藏

Ethereal

网络工程师 网络技术 华为设备 厂商设备 运维技术

超细!细说Zookeeper选举的一个案例(上)

恒生LIGHT云社区

golang zookeeper Go 语言

Nebula Graph 源码解读系列 | Vol.06 MATCH 中变长 Pattern 的实现

NebulaGraph

图数据库 知识图谱 分布式图数据库

PingCAP 入选 CB Insights 中国「数据链路安全领航者」榜单,保障全球用户存储安全

PingCAP

WAVE SUMMIT+2021深度学习开发者峰会举办,开源共建助力飞桨生态发展

科技热闻

AI 收藏夹 Vol.004:虚拟爱豆出道!

Zilliz

人工智能 神经网络 AI

神器来袭,手把手教你使用 Milvus_cli

Zilliz

数据库 命令行

从前端到全栈 -- 最全面向对象总结

程序员海军

Java 面向对象

今夜无眠

Tiger

28天写作

“十四五”规划,开源重塑软件发展新生态,获国家重点扶持

腾源会

开源

中石化信息化数字化首席专家李剑峰:数字化转型中关键基础软件的国产化应用

OceanBase 数据库

开源 国产化 oceanbase 中石化

跟着动画学Go数据结构之插入排序

宇宙之一粟

golang 数据结构 插入排序 12月日更

前端开发之Vue框架的优势

@零度

前端开发 Vue优势

Linux 基金会发布 2021 年度报告,预测今年收入为 1.77 亿美元

腾源会

Linux 开源

明道云荣获2021亚洲最佳职场“最佳创新奖”荣誉!

明道云

联邦学习在光大科技的落地应用

博文视点Broadview

重磅|腾讯云开源业界首个 etcd 一站式治理平台 Kstone

腾源会

开源 cncf Kstone

如何实现分布式开发_软件工程_Ben Linders_InfoQ精选文章