1986年,IBM大型电脑之父Fred Brooks发表了他的著名论文《没有银弹》中断言:“在10年内无法找到解决软件危机的银弹”。如今20年过去了,有可能成为银弹的东西诞生了,那就是agile——敏捷。
何为敏捷?
1968年软件工程提出至今已经30余年了,传统的开发方法所存在的一些不足也逐渐的显露:软件的工期不可控,软件过程中的文档越来越复杂,客户与开发人员间面对面的沟通逐渐减少,开发人员面对文档做开发而不是面向客户,严格的流程控制及文档契约与不断变化的需求间的矛盾越来越强烈,这些问题在需求变化频繁的互联网应用中尤为明显。在这样的背景下,2001年17位软件开发领域的领军人物聚集在美国犹他州的滑雪胜地snow bird雪场,经过两天的讨论,“敏捷”(Agile)这个词为全体聚会者所接受,用以概括一套全新的软件开发价值观。这套价值观,通过一份简明扼要的《敏捷宣言》来诠释,这份敏捷宣言是“敏捷软件开发”价值和目标的浓缩定义,并通过许多共同的原则进行了细化传递给世界,宣告了敏捷开发运动的开始。敏捷宣言如下:
1:个体和交互胜过过程和工具。
2:运作的软件胜过面面俱到的文档。
3:客户合作胜过合同谈判。
4:响应变化胜过遵循计划。
虽然敏捷的概念提出已经有了8年,但是究竟什么是敏捷,什么样的开发才是敏捷开发至今也是众说纷纭。Fred曾经用盲人摸象来表达大家对敏捷的认识,个人认为是非常贴切的,大家看到的都是某几个面,但是就是这些面已经对我们的软件开发产生了巨大的影响。
敏捷在中国
敏捷为中国的开发人员所接受及推崇是这几年的事情。2006年首届敏捷中国大会在北京举行,大会的主题是敏捷软件开发,人们逐渐开始了解敏捷开发这个新生事物,同时用各种的眼光来看待它。从曾经大热的极限编程,RUP到如今被大家广泛认可的Scrum,随着各种敏捷开发方法的提出,敏捷开发也逐步的被大家所认识与接受。时至今日,据一份调查统计透露,在国内有90%以上的开发团队或多或少的运用敏捷开发的方法,国内敏捷开发的培训咨询机构与组织日益增长。现在大家关注的焦点不再是是否使用敏捷,而是如何更好的敏捷,以及如何评判一个团队的敏捷程度。
与敏捷的第一次亲密接触
说起自己什么时候接触敏捷的?那大约是在冬季。今年初,沈总在部门内部引入了敏捷的概念,我们团队非常有幸的成为了实验田,在新近的项目中尝试使用敏捷开发。敏捷半年有余,感受良多,在我看来敏捷开发最大的特点就是以人为本,与CMMI等关于与流程不同,敏捷开发更关注人,也就是交互的个体。这些特点在我们的项目管理中可以很清晰的体现,我们团队的项目管理基于Scrum,在此我需要简单的介绍一下什么是Scrum:Scrum是 软件开发模型是敏捷开发的一种,在最近的一两年内逐渐流行起来,我们团队内部称之为屎壳郎。Scrum采用周期式的开发,客户在每个周期的开始阶段提出最急需的需求,团发团队则在三周的开发周期内完成需求并交付成果。在这样的开发模式下,我们关注与客户面对面的沟通,客户可以随时访问我们的开发成果,与开发人员进行直接的沟通。我们关注开发人员每日的成果与阻碍,项目的可视性大大提高。我们响应变化,我们总是尽早的与客户沟通,让客户直接感受真实的系统,降低项目需求偏离乃至失败的风险。我们的团队成员自我组织,在每日立会(1)上开发人员自己选择要完成的任务,在sprint(2)计划会上开发人员与客户一起估算功能的开发量,充分调动了团队开发成员的积极性,我们团队还借鉴了极限编程中的一些概念,比如持续集成等来保证项目的质量与项目的敏捷性。半年来我们感受到了敏捷开发所带来的新动力,但是在实施过程中还是遇到了许多问题,同时也对自己团队的开发方式的敏捷度存在疑问。带着这样的疑问,我开始了我的朝圣之旅。
朝圣之旅——敏捷中国2009
九月中旬,我前往首都北京,参加敏捷界的盛会——敏捷中国2009。这是我首次参加敏捷中国大会,前几届大家还在谈论:“什么是敏捷?我们是否应该敏捷?”之类的话题,而到了这一届大家的口径已经完全一致,我们更加关注的是“如何更好的实施敏捷?”,于是乎“实效敏捷”这个主题应运而生。此次会议参会人数达到550人左右,涵盖了各行业的开发人员与高级主管。国内几家大型软件公司如百度,腾讯,支付宝,阿里巴巴等更是大规模出席,以百度为例,除了一些高级主管外,百度公司整个流程改进部门的核心人员20余人全员出席,可见业内对于敏捷开发的重视程度。相较于北京,上海这些软件行业发达地区,福州对于敏捷开发的重视程度似乎还存在的一些滞后性。
在会议的最开始,中国软件行业协会系统与过程改进分会(CSPIN)的王钧为大会致辞,充分肯定了敏捷对于系统过程改进所将扮演的重要地位,提出敏捷开发中的一些主要原则(比如对人的关注)将是对CMMI等传统开发模式的有效补充。行业协会中的老科学家们目前也正在积极的了解敏捷开发,日后也会出台相关的政策来推动敏捷开发在中国软件行业中的发展,政府的支持与肯定让与会者都对敏捷的发展充满了信心与期待。
此番带着问题前来,目的明确时间也过得充实,白天听着大师为我们勾勒的宏伟蓝图,休息时间和晚上便于其他参会者交流着实施中遇到的细节问题。此次大会请到了敏捷界的几只大牛:XP极限编程的创始人,敏捷宣言创始人之一KenBack,敏捷宣言创始人之一Dave Thomas, 敏捷界大师级专家Fred George。大师们的演讲多是思想性的,虽然离实施还有一定的距离,但是往往其中的一到两句话,就可以扫清我眼前的某团迷雾。比如Dave的演讲对一个熟练工来说是很有启示作用的,他引导大家关注于软件开发中不变的东西,那些思想与原则就算过了10年也不会过时。Fred的主题演讲更是有一个牛逼的名字“那是鸟,还是飞机?不,那是超人!”,在这个演讲中他特别强调了人在软件开发过程中的作用。他提出“要做好软件,人是最大的可挖掘潜力。”和与会者的交流则是此行我另一大的收获:首先,清楚了自己的定位,在与其他公司的交流过程中,我发现在敏捷成熟度上,我们团队还是走在了行业的前列跟上了大部队。其次,解决了细节问题,在实施过程中的我们团队遇到了许多细节问题,比如如何调动团队成员的主动性,如何更好引导客户融入开发团队,在与大家的交流中我也找到了一些解决问题的思路。三,拓宽了思路,对于敏捷的认识,就如同fred所说盲人摸象,但是大家并不较真与敏捷这个字眼,更关注的还是对于公司内部开发流程的改进。针对同一个场景或者问题,各个公司的处理方式也是五花八门,就以CMMI与敏捷开发的冲突问题来说,Ebay的顾先生就认为,这两个东西不能共存,强行的将敏捷的一些概念映射到传统的开发流程中去,搞所谓的公司特色,最后得到的将是一个古怪的四不象;有的人则认为两个并不冲突,CMMI2与敏捷的很多想法都是统一的,更有甚者提出(此君杭州人士,屡出惊人之语,甚是实在,印象深刻),他们公司一直都是按敏捷那套做,结果过了CMMI3,真可谓众说纷纭。在我看来,其实敏捷就是实践者,根据自己的公司实际实施,能够改善我们的项目管理流程的就是真正的敏捷。
再见北京,再见Agile2009, 再见Dave,在敏捷的道路上,我和我的团队会继续勇敢的走下去,a love all,make it fun.
分享到:
相关推荐
5. 软件开发是一个创造性的过程:Brooks 认为,软件开发是一个创造性的过程,它需要不断的挑战和创新。可能软件开发真的没有所谓银弹,也可能会在未来的 10 年、20 年里会真的探索出银弹! 《人月神话--没有银弹》...
没有银弹《没有银弹》是Fred Brooks在1987年所发表的一篇关于软件工程的经典论文。该论述中强调真正的银弹并不存在,而所谓的银弹则是指没有任何一项技术或方法可以能让软件工程的生产力在十年内提高十倍。Brooks...
《没有银弹:软件工程的本质性与附属性工作》(英语:No Silver Bullet — Essence and Accidents of Software Engineering)是IBM大型机之父佛瑞德·布鲁克斯所发表一篇关于软件工程的经典论文
软件工程中的根本和次要问题是软件开发领域中的一个关键概念。软件工程的目标是开发高质量、可靠、可维护的软件系统,而软件工程中的根本和次要问题则是软件开发过程中的主要挑战。 软件工程中的根本问题是指软件...
《没有银弹》主张并断言在未来的十年之内(从1986年文章发表后开始计算),不会有任何单一软件工程上的突破,能够让程序开发的生产力得到一个数量级(10倍)的提升。我们讨论或推广一项软件实践或技术的时候,实际上是...
文章的核心观点在于,不存在一种能够彻底解决所有软件工程问题的“银弹”或单一解决方案。Brooks认为,软件工程的独特性使得它与物质产品截然不同,因为软件由比特(bits)而非原子(atoms)组成,这导致了它无法像...
在软件开发中,复杂度是一个非常重要的问题。软件实体是人类创造出的最复杂的东西,为了保证实现软件重用,不会出现两个完全相同的部分(组件)。这导致了许多技术困难(函数复杂度、结构性复杂度)以及管理上的问题...
SkyWalking作为一个分布式追踪系统,也提供了原生概念,包括Span、Segment、Trace Id、Parent Segment Id、Parent Span Id、Parent service and instance、Parent endpoint等。 分布式追踪可以应用于RPC调用和MQ...
然而,敏捷并非银弹,实施时需要克服文化变革、沟通挑战和持续学习等难题。 总结来说,敏捷项目管理模式以灵活、迭代和以人为本的方式管理项目,鼓励团队自我组织和适应变化,以实现更高的项目成功率和客户价值。...
《没有银弹》是弗雷德里克·布鲁克斯在《人月神话》中的一个重要章节,探讨了软件工程中是否存在一种能显著提升效率和质量的“银弹”技术。在这个概念中,银弹指的是能够一次性解决所有问题的有效方法。然而,...
其次,敏捷开发推崇“测试驱动开发”(TDD)和“行为驱动开发”(BDD),这两种方法都强调在编写代码之前先编写测试,这样可以确保软件的每一个功能都能按预期工作,同时提高了代码覆盖率,降低了Bug的产生。...
自动化测试:真的是银弹?软件测试没有一种单纯的技术或管理上的进步,能够独立地承诺在10年内大幅度地提高软件的生产率、可靠性和简洁性。Brooks鼓励我们将技术和方法视作一...曾在1986年写过一篇题为《没有银弹:软件工
### 大数据没有唯一的银弹 #### 核心观点: - **多样性与复杂性:**在当前的大数据环境中,没有一种技术或解决方案能够满足所有需求。这是因为数据本身的多样性与复杂性,以及不同业务场景下的特定需求。 - **技术...
我说到,想要Doing敏捷并不难,只要花上几天功夫学习敏捷知识之后就可以在小范围团队中去实践了,而要做到真正的Being敏捷则并不容易,而导致并不是真正敏捷的原因中,人是一个主要问题之一,这也是为什么现在敏捷...