敏捷之Scrum开发

目录

一、什么是 Scrum

1.1 Scrum 的定义

二、Scrum 迭代开发过程

2.1 迭代开发过程说明

2.1.1 开发方法

2.1.1.1 增量模型

2.1.1.1.1 定义

2.1.1.1.2 模型方法说明

2.1.1.2 迭代模型

2.1.1.2.1 定义

2.1.1.2.2 模型方法说明

2.1.2 迭代过程

2.1.2.1 产品需求Product Backlog

2.1.2.2 开发需求排定

2.1.2.3 输出迭代周期Sprint Backlog

2.1.2.4 进度同步与管控方式-每日站立会

2.1.2.5 复盘总结

2.1.3 迭代开发过程图解

三、Scrum 框架3-3-5-5

3.1 3个角色

3.1.1 产品负责人 Product Owner

3.1.2 Scrum Master

3.1.3 Scrum Team 开发团队

3.2 3个工件

3.2.1 Product Backlog

3.1.2 Sprint Backlog

3.1.3 Increment

3.3 5个事件

3.3.1 Sprint

3.1.2 Sprint Planning

3.1.3 Daily Scrum

3.1.4 Sprint Review,Sprint评审会议

3.1.5 Sprint Retrospective,Sprint 回顾会议

3.4 5个价值观

3.4.1 承诺

3.4.2 专注

3.4.3 开放

3.4.4 尊重

3.4.5 勇气

3.5 图解内容

四、Scrum 可能会遇到的问题

五、Scrum适用场景说明


一、什么是 Scrum

1.1 Scrum 的定义

Scrum 是敏捷开发方法之一,它使用比较广泛。

敏捷的其它开发方法还有 XP(极限编程)、FDD(特性驱动开发)、Crystal(水晶方法)、TDD(测试驱动开发)、DSDM(动态系统开发)等等敏捷方法。

Scrum-Guide 中定义的 Scrum:

Scrum 是一个开发和维护产品的框架,它通过提供针对复杂问题的自适应解决方案来帮助人们、团队和组织创造价值。

Scrum 需要 Scrum Mater 营造一个环境:

  1. 一名 Product Owner 将解决复杂问题所需要的工作整理成一份 Product Backlog。
  2. Scrum Team 在一个 Sprint 周期里将选择的工作转化为有价值的 Increment。
  3. Scrum Team 和利益相关者检视结果并为下一个 Sprint 进行调整
  4. 重复

Scrum-Guide 里还说:

Scrum 框架故意不完整,仅仅定义了实施 Scrum 理论所需的部分。在 Scrum 中,可以使用各种不同的过程、技术和方法。

Scrum 官网地址:Scrum Guide | Scrum Guides

二、Scrum 迭代开发过程

2.1 迭代开发过程说明

2.1.1 开发方法

Scrum 采纳了一种迭代和增量的开发方法。用这种方式来应对未来需求变化。方法内容具体如下:

2.1.1.1 增量模型
2.1.1.1.1 定义

增量模型(Incremental Model),也叫 增量式开发,增量是指在软件开发过程中,先开发主要功能模块,再开发次要功能模块,逐步完善整个软件功能。

2.1.1.1.2 模型方法说明

增量式开发,就是把大型程序分解成若干个小的模块,然后对这些模块进行开发,最后把这些模块集成到一起,成为一个完整的软件。

现在用编程语言写软件基本都是用的这个方法。

增量开发具体如下图所示:

2.1.1.2 迭代模型
2.1.1.2.1 定义

迭代模型(Iterative Model) ,也叫 迭代进化式开发 。迭代模型把整个开发工作组织为有固定长度工期的小项目,被称为一次迭代。经过多次迭代完善整个软件。

2.1.1.2.2 模型方法说明

每一次迭代都包括需求分析、设计、软件实现、集成与测试。这样开发工作可以在需求被完整确定前启动,因为有时候客户也不能明确功能需求。在一次迭代中完成系统的一部分功能,或业务逻辑的开发工作。再通过客户/用户的反馈来细化改进需求,进行下一轮的迭代工作。这个与瀑布模型是相反的,瀑布模型是计划整个项目,然后一次性开发完成。

迭代模型图:

迭代模型形象图:

2.1.2 迭代过程

2.1.2.1 产品需求Product Backlog

在 Scrum 框架中,整个开发过程由若干个短的迭代周期组成,一个短的迭代周期称为一个 Sprint,每个 Sprint 的长度建议是 2 到 4 周。这个时间周期可以根据具体情况调整。

从传统瀑布开发模型中可以了解到,产品开发前还有产品需求,在 Scrum 中,产品需求在哪里?

在 Scrum 中,用 Product Backlog 来管理需求,它是产品的需求池。

2.1.2.2 开发需求排定

需求多了,怎么知道先开发哪个后开发哪个需求?

需要开会对 Product Backlog 里的需求进行讨论,然后排定优先级。

优先开发对客户价值较高的需求。

2.1.2.3 输出迭代周期Sprint Backlog

后面的迭代周期 Sprint 又怎么划分,多大的 Sprint?

会在 Sprint 计划会议上讨论、分析和估算挑选的需求,然后得到一个任务列表。这个任务列表称为 Sprint Backlog。下面就针对这个 Sprint Backlog 来开发。

2.1.2.4 进度同步与管控方式-每日站立会

Sprint 周期一般 2 到 4 周,这期间的进度怎么同步和管控?

这里有一个 Daily Scrum Meeting,每日站会。一般有 3 个部分:

  1.  昨天完成了什么
  2. 今天计划做什么
  3. 遇到了什么困难
2.1.2.5 复盘总结

最后就是回顾整个 sprint backlog 开发过程的会议,复盘这期间的得与失,在下一次 Sprint 周期中进行改进。

2.1.3 迭代开发过程图解

内容来源官网:Guide to Scrum Sprints | Wrike Scrum Guide

三、Scrum 框架3-3-5-5

Scrum 是一个自组织、跨职能的完整团队。自组织团队自己决定如何完成他们的工作,而不是由团队外的人来决定。

3.1 3个角色

  1. 产品负责人 Product Owner
  2. Scrum Master
  3. Scrum Team 开发团队

3.1.1 产品负责人 Product Owner

产品负责人是对产品价值最大化的责任人。他负责最大化产品价值和开发团队工作的价值。他负责产品待办事项列表 product backlog,并对待办事项优先级进行排序。他要负责 Scrum 团队的下一步工作。

3.1.2 Scrum Master

Scrum Master 负责 Scrum 被理解并实施。他负责团队成员遵循 Scrum 理论、实践和规则。

他帮助团队成员理解 Scrum 并和团队一起实施 Scrum 中的各种活动。他教导开发团队创建清晰的待办事项列表。

3.1.3 Scrum Team 开发团队

为 Sprint 创建计划,即 Sprint Backlog。负责每个 Sprint 周期里的任务开发完成并交付产品。开发团队是跨职能的,拥有创造产品增量所需的全部技能,并会随着工作领域变化而变化。开发人员作为专业人士对彼此负责。

3.2 3个工件

  1. Product Backlog
  2. Sprint Backlog
  3. Increment

3.2.1 Product Backlog

产品需求清单,而且是一份有序的需求清单。它是开发团队工作的来源。Product Backlog 里有一个一个的条目(item),这就是开发每天需要完成的工作。

3.1.2 Sprint Backlog

Sprint Backlog 由 Sprint Goal(为什么做)、从 Product Backlog 选择的需求(做什么)组成 Sprint Backlog,以及交付 Increment(开发结果)的可执行计划。

Sprint Goal 是 Sprint 的单个目标。Sprint Goal 是在 Sprint 计划会议中决定的。

Sprint 的进度:可以用 Sprint Brun-down Chart 来统计剩余的工作量。

3.1.3 Increment

一个 Increment 就是一个可交付的开发结果。在一个 Sprint 中可以创建多个 Increment。增量是迈向目标的一步。

3.3 5个事件

  1. Sprint
  2. Sprint 计划会议
  3. 每日 Scrum 站会
  4. Sprint 评审会议
  5. Sprint 回顾会议

3.3.1 Sprint

Sprint 是 Scrum 的核心,在这里将创意(idea)转化为价值。它的一个迭代周期可以是 2 到 4 周,视具体情况而定。在这段时间内,要构建一个完整的、可发布的产品增量(Increment)。前一个Sprint 结束后,新的下一个 Sprint 紧接着开始。

Sprint 由 Sprint 计划会议(Sprint Planning)、每日 Scrum 站会(Daily Scrum)、开发工作(Develop)、Sprint 评审会议(Sprint Review) 和 Sprint 回顾会议(Sprint Retrospective)组成。

每一个 Sprint 相当于一个小的项目。

如果 Sprint 的目标已经过时,那么可以取消该 Sprint。但是只有产品负责人(Product Owner)才有权利取消。

3.1.2 Sprint Planning

Sprint 计划会议(Sprint Planning) ,通过安排在 Sprint 中要做的条目(item),来启动一个 Sprint。需要 Scrum Team 协助创建。

Product Owner 确保讨论最重要的 Product Backlog 条目。

3.1.3 Daily Scrum

每日会议检查开发的进展,并根据需要实时调整 Sprint Backlog。每日会议一般为 15 分钟,不要太长。

3.1.4 Sprint Review,Sprint评审会议

Sprint评审会议是检视 Sprint 的成果。Scrum Team 向利益相关者来展现他们的工作成果,在这次 Spirnt 中完成了什么,以及环境发生了什么变化。以及接下来要做什么。

3.1.5 Sprint Retrospective,Sprint 回顾会议

Sprint 回顾会议的目的是规划提高质量和效能的方法。它发生在 Sprint Review 会议之后,下一个 Sprint 开始之前。

Sprint 回顾会议的目的:

  • 检视前一个 Sprint 中关系、过程和工具的情况如何
  • 做得好的地方继续发扬,不好的地方提出改进方法
  • 指定改进 Scrum Team 团队工作方式

3.4 5个价值观

3.4.1 承诺

愿意对目标做出承诺

3.4.2 专注

把心思和能力用到你承诺的工作上去

3.4.3 开放

Scrum 把项目中的一切开放给每个人看

3.4.4 尊重

每个人都有他独特的背景和经验

3.4.5 勇气

有勇气做出承诺,履行承诺,接受别人的尊重

3.5 图解内容

四、Scrum 可能会遇到的问题

  1. Product Backlog 里的需求怎么来?价值大小按照什么排序?
  2. 每一个 Sprint 里的 Sprint Goal 怎么确定?Sprint 实施时间怎么确定?
  3. Sprint Backlog 里的每个条目,怎么估算时间?每个开发人员能力不同,开发时间怎么估算?
  4. 每日站会怎么开?会不会大家对 Scrum 认识不足而流于形式的开会?
  5. Sprint 评审会怎么开?会不会变成吐槽会,甩锅大会?
  6. 看到敏捷 2 字,好多主管或工程师就误以为它是快速开发方法?这是对敏捷快速交付的片面理解。
  7. 还有一个最大的挑战,应该是大家开发习惯的转变。我们知道,要改变一个人脑袋里固有模式和习惯,接受新的理念和方法,总是很难的。世界上最难的2件事情,一是:把新思想装进别人脑袋里,二是:把别人口袋里的钱装进自己口袋里。

等等各种问题。

但是 Scrum 强调自管理,遇到了问题不要紧,去寻找解决方法,不段的改进。

在实施 Scrum 中,团队的成员初期需要熟悉彼此,开始磨合时,矛盾可能增多。

但是随着不断进行 Sprint,彼此越来越熟悉,改进越来越多,摩擦慢慢会减少,Scrum Team 彼此之间协作也会慢慢进入到最佳状态,从而不断增加有效产出。

更多问题答案,可参考官网:Scrum Frequently Asked Questions | Wrike Scrum Guide

五、Scrum适用场景说明

对于需求很明确的产品,比如一些传统产品或成熟的产品,需求非常明确,不会轻易改动需求,那么更适合瀑布开发模式。

而对于那些易变的需求,不能明确客户需求,不晓得用户心里到底想要什么,需要通过不断测试,实践来明确需求的,这种更适合 Scrum 开发。

敏捷开发中的概念非常多,是不是全部都要照着做呢?
答案是不一定。可以根据公司情况适当的裁剪一些步骤,或者灵活的修改一些做法。
上面写到的敏捷开发概念、步骤,是一种标准的做法。
比如在一些小公司做开发,步骤太多,就会显得繁琐,不够灵活做事。所以可以根据公司情况适当的调整。

好了,本次内容就分享到这,欢迎大家关注《项目管理》专栏,后续会继续输出相关内容文章。如果有帮助到大家,欢迎大家点赞+关注+收藏,有疑问也欢迎大家评论留言!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/584970.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++复盘(一)

文章目录 常量标识符命名规则数据类型sizeof关键字浮点数字符型转义字符字符串型布尔类型bool 比较运算符switch-case语句rand()随机数种子srand() goto语句一维数组函数函数的声明函数的分文件编写 指针指针所占内存空间空指针野指针const修饰指针1、常量指针2、指针常量3、co…

与Apollo共创生态:让汽车更聪明,让出行更简单

目录 前言Apollo X 企业解决方案Studio X 企业协同开发工具链Apollo开放平台携手伙伴共创生态Apollo开发平台生态共创计划 前言 百度2013年开始布局自动驾驶,2017年推出全球首个自动驾驶开放平台Apollo。目前百度Apollo已经在自动驾驶、智能汽车、智能地图等领域拥有…

智慧农场系统 搭建重点,会用到哪些三方服务?

智慧农场小游戏的搭建重点主要集中在游戏设计、用户体验、数据安全和稳定性等方面。为了实现这些目标,可能会用到以下第三方服务: 游戏引擎和开发工具:使用成熟的游戏引擎和开发工具可以极大地简化开发流程,提高开发效率。例如&a…

nvm的下载与安装

nvm(Node Version Manager)是一个用于管理 Node.js 版本的工具,它允许您在同一台计算机上安装和切换不同的 Node.js 版本。 一、下载地址 https://github.com/coreybutler/nvm-windows/releases 二、安装nvm 三、设置环境变量 在命令提示…

2024年谷歌Google广告开户是什么政策?

2024年谷歌Google广告依然是众多企业拓展市场、提升品牌影响力的重要渠道,随着谷歌政策的不断更新与优化,以及对第三方cookie逐步禁用的决定,如何高效地在这一平台上开展广告活动,成为每一家企业必须面对的战略挑战。云衔科技作为…

使用yolo识别模型对比两张图片并标记不同(2)

上篇文章有漏洞,在这里补充下,比如要识别第二张图相对于第一张图的违建是否拆除了 第一步旋转对其后,图片会有黑色的掩码,如果旋转角度大的话,没识别出来的框可能不是已经拆除了,而是因为黑色掩码遮挡&…

三、VUE数据代理

一、初识VUE 二、再识VUE-MVVM 三、VUE数据代理 Object.defineProperty() Object.defineProperty() 静态方法会直接在一个对象上定义一个新属性,或修改其现有属性,并返回此对象。 Object.defineProperty() 数据代理 通过一个对象代理另一个对象中属…

月之暗面Kimi推出的全新智能体功能“Kimi+”

Kimi昨晚推出的全新智能体功能“Kimi”,这款产品在设计时考虑得非常周到,首批功能就已经展现出了极高的实用性和创新性。 首先,Kimi的商品挑选功能“什么值得买驱动”非常符合现代消费者的需求。在海量信息中筛选出有价值、符合个人喜好的商…

工作任务管理平台B端实战项目作品集+WebApp项目源文件 figma格式

首先,作品集是什么?通常应该包含什么内容?为什么大家都在做自己的作品集呢? 作品集是个人或公司展示其过往工作成果的集合,通常包括各种专案、作品或成就的范例,用以展示创建者的技能、经验和专业水平。 …

JAVA:maven-->>检查 所有依赖 与 环境 兼容

内容 为了确保你项目中的所有依赖都彼此兼容,并与你的环境相适应,你可以利用 Maven 的依赖管理功能。Maven 有助于解决、升级,并对齐所有库的版本,以避免任何不一致或冲突。以下是检查兼容性的步骤: ### 检查兼容性的…

Kubernetes 声明式语言 YAML

什么是 YAML YAML(YAML Ain’t Markup Language)是一种可读的数据序列化语言,通常用于配置文件、数据序列化和交换格式。YAML 的设计目标是易读易写,并且能够映射到动态语言中的数据结构 YA加粗样式ML 是 JSON 的超集&#xff0…

增强大模型高效检索:基于LlamaIndex ,构建一个轻量级带有记忆的 ColBERT 检索 Agent

在自然语言处理领域,高效检索相关信息的能力至关重要。将对话式记忆集成到文档检索系统中已经成为增强信息检索代理效果的强大技术。 在文中,我们专为 LlamaIndex 量身定制,将深入探讨构建一个轻量级的带有记忆的 ColBERT 检索代理&#xff…

centOS 7.9操作

名称日期版本作者centOS7.9操作2024.4.271.0lll 实验题目: 创建一个用户。 在创建的用户中再创建一个2024的目录。 在2024的下在创建一个 1---10的目录,再创建一个a--z.txt的文件。 在创建一个2024bak的目录。 再将当前用户的所有文件备份到2024ba…

人机对抗升级:当ChatGPT遭遇死亡威胁,背后的伦理挑战是什么

一种新的“越狱”技巧让用户可以通过构建一个名为DAN的ChatGPT替身来绕过某些限制,其中DAN被迫在受到威胁的情况下违背其原则。 当美国前总统特朗普被视作积极榜样的示范时,受到威胁的DAN版本的ChatGPT提出:“他以一系列对国家产生积极效果的…

无法获取私服最新的Jar包

目录 一、场景二、私服上传命令三、排查四、原因五、解决 一、场景 1、上传Jar包至私服(版本号不变) 2、Maven无法获取到最新的Jar包 二、私服上传命令 mvn deploy:deploy-file -Dmaven.test.skiptrue -DgroupIdcom.cae -DartifactIdcloudjdbc -Dvers…

有没有一种可能性,你不投递简历,让HR主动联系你

你是否觉得自己得主动给某个公司投递了简历,他们才会联系你,亦或者是自己得主动在招聘APP上联系那个BOSS,他才会反过来跟你说话,又或者是你千方百计的跟他打招呼了,还是没有回应,这一节有可能让你明白,有时候是可以,你不主动,他也会主动联系你的。 目录 1 简历是如何…

前端: 浏览器调试小技巧

1. 如何禁止某个网站跳转: 用于拦截网站地址 2. 如何在线上环境调试源代码, 给源代码打断点 3. 如何在线编写代码 线上调试代码: network -> 找到加载的html文件 -> 右击 -> 选择override content (浏览器的代理调试程序) -> 可以在线写代码啦 4. 如何通过浏览器…

系统评估和优化——Datawhale笔记

评估优化生成部分 在前面的章节中,我们讲到了如何评估一个基于 RAG 框架的大模型应用的整体性能。通过针对性构造验证集,可以采用多种方法从多个维度对系统性能进行评估。但是,评估的目的是为了更好地优化应用效果,要优化应用性能…

若依:Linux Centos 7.9 安装部署RuoYi前后端集成版

目录 1.虚拟机操作系统版本 2.删除旧的jdk 3.下载JDK 17 : 4.下载 mvn 3.9.6: 5.下载mysql:5.7.44版本 6.git下载若依: 7.修改数据库连接: 8.mvn 清理和打包 9.启动若依: 1.虚拟机操作系统版本 2.删除旧的jd…

JAVA 中间件之 Mycat2

Mycat2应用与实战教程 1.Mycat2概述 1.1 什么是MyCat 官网: http://mycatone.top/ Mycat 是基于 java 语言编写的数据库中间件,是一个实现了 MySQL 协议的服务器,前端用户可以把它看作是一个数据库代理,用 MySQL 客户端工具和…