gitbook/软件工程之美/docs/88259.md
2022-09-03 22:05:03 +08:00

192 lines
13 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 15 | 风险管理不能盲目乐观凡事都应该有B计划
你好我是宝玉我今天想与你分享的主题是风险管理凡事都应该有B计划。
说到风险,很多人都模模糊糊有一些了解,然而在软件项目中,有风险意识的却不多。比如说:
* 估算一个模块工作量,程序员总是会给出一个乐观的进度,而最终实现这个模块的时候,却发现总是有些其他的事情发生影响了进度;
* 一个关键的程序员,突然离职了,导致项目进度停滞。其实早前就有一些迹象,而项目经理没引起重视;
* 技术负责人很激进的采用了一个最近很流行的新技术,结果做的过程中,发现这个技术还不太成熟,很多坑没法填,导致项目最终失败;
* 服务器突然挂了,才发现硬盘坏了而数据没有备份,造成巨大的损失。
这些问题其实都和风险相关,如果没有及时发现这些潜在的风险,没有应对方案,轻则导致项目进度延迟,重则导致项目失败,造成重大损失。
在软件工程里面,针对这些可能造成风险的问题,对风险进行提前识别和管理,就可以有效地应对。
## 什么是风险管理?
风险是指不确定的事件,一旦发生,将会造成消极的影响。风险包含两个方面的内容:
1. 发生后,会造成什么样的损失?
2. 发生的概率有多大?
所以也有人认为:**风险 = 损失 x 发生概率。**
比如说有一次我负责一个小项目激进的采用了刚开始流行的React框架如果使用熟悉的Angularjs框架正常来说一个月就能完成当时很乐观的觉得React和Angularjs也差不多时间应该不会多出来太多就按照一个月时间来做项目计划。
最后到实际开发的时候发现React和Angularjs有很多不一样的地方必须要现学现用原本计划一个月完成的最后加班加点拖到一个半月时间才完成。
在这个项目中,使用新技术就是一个风险:
* 造成的损失就是导致了进度延误;
* 发生延误的概率如果项目开始前估算大概在60%左右项目进行中这个概率就上升到80%了。
像软件项目中这样的风险,如果发生后就会变成问题,问题如果没有及时解决,就会影响到项目计划。如果我们能有效的对风险加以识别,加以管理,就能减少对项目的负面影响。
> 风险管理就是指在项目进行过程中,识别可能的风险,对风险进行评估,并加以监控,从而减少风险对项目的负面影响。
## 风险管理重要吗?
对于风险管理,现在软件项目中提起的不多,应用的更少。
主要原因还在于大家都比较乐观,多少有一定侥幸心理,都觉得自己不会运气那么差,风险事件正好就发生了。还有就是因为如果要做风险管理,需要额外多做一些工作。
这就跟你买保险的道理一样,风险事件没发生,相当于你买保险的钱白花了,但是一旦发生了,你才知道买保险的钱花的值得。
**对软件项目风险的管理,才是体现项目管理水平的地方。**我们对比下面几种应对风险的层次来看:
* 被动应对:风险已经发生,造成了问题才被动应对;
* 有备无患:事先制定好风险发生后的补救方案,但没有任何防范措施;
* 防患未然:对可能的风险做出防范,并把风险防范作为项目任务的一部分。
哪一种层次更体现项目管理水平,相信你心中已经有了答案。
拿前不久发生的拼多多被“薅羊毛”事件来举例。
> 2019年1月20日凌晨拼多多平台出现系统漏洞用户可以领取100元无门槛券。因此开始出现大批用户借此“薅羊毛”利用无门槛券下单虚拟商品例如充话费或Q币等等并一度有消息传出拼多多将因此损失200亿元。
这个事件追究原因的话,当然可以说是开发代码没写好,可以说是测试没测好,也可以说运维没有监控好。
但另一个角度讲,如果这个项目的负责人有一点风险意识,做了风险管理,即使出现这样的问题,损失也一定不会这么大。
## 如何做好风险管理?
#### 1\. 培养风险意识
风险管理其实最大的问题不是如何做,而是项目成员缺少风险意识,有了风险意识,才能去识别出来项目中可能的风险,进而去管理风险。
对于培养风险意识,我的经验就是:**项目中的任务不能盲目乐观都思考一下它最坏的结果是什么如果最坏的结果不能接受就说明要有个B计划考虑风险管理了。**
比如说拼多多的无门槛券,最坏的情况是被无限刷,造成巨额经济损失,那这种结果是不能接受的,就需要考虑风险管理。
#### 2\. 管理风险
软件项目风险管理,通常分四步来做。
**第一步:风险识别,识别可能的风险**
风险识别,就是看项目中有哪些可能的风险,因为只有找出来有可能存在的风险,才会有后续的步骤。
识别风险这种事经验很重要因为大部分风险其实都是相似的。以前看CSDN总裁蒋涛发过一条微博内容引发了很多人的共鸣每一条无不应对着软件项目中的常见风险。
> **10个项目死亡的信号**
>
> 1. 第一版做太多功能;
> 2. 太依赖新技术平台;
> 3. 与公司另一个有份量的产品竞争;
> 4. 团队人手不足;
> 5. 复杂的问题,需要复杂的解法;
> 6. 成员开始隐藏进度落后的事实和原因;
> 7. 不断更改、增加的需求
> 8. 2.0 症候群-非要更大、更强、更美
> 9. 产品没有市场立足点;
> 10. 你根本无法解决的大问题。
一个识别风险的方法叫**检查表法**,就是可以把类似于上面这些常见风险收集整理起来,分类列成清单,按照清单去检查对照。
软件项目的风险主要分成以下几类:
* 项目风险:项目预算、进度、用户和需求等方面的问题;
* 人员风险:人员离职、人手不足等问题;
* 技术风险:采用的技术所可能带来的风险;
* 商业风险:与市场、产品策略等有关的商业风险。
你也可以按照上面的分类整理出自己的风险检查表。
另外你还可以借助集体的智慧,定期针对风险问题开一些头脑风暴会议,一起发现可能的风险。另外,要有合适的渠道,让项目成员可以反馈可能发生的风险问题。
**第二步:风险量化,对风险进行评估量化**
在风险识别出来以后,需要从两个方面去评估:
* 发生的概率多大?
* 发生后,后果多严重?
对于概率大,后果严重的风险,需要高优先级重点考虑;对于概率不高但后果严重的问题也要考虑,不过优先级略低;对于概率高但后果不严重的风险事件,可以优先级很低或者不考虑;对于概率低后果不严重的,则可以不予考虑。
拿拼多多的“无门槛券”来说,这就属于一个高风险、高概率的事,需要重点考虑。
**第三步:应对计划,对风险制定应对策略**
在评估后,需要后续进一步考虑的,就要制定好应对的计划。针对风险,主要分成以下几个策略。
![](https://static001.geekbang.org/resource/image/1f/d5/1f0834c11f675e1846779134746903d5.jpg)
* **回避风险——更改导致风险的方案**
回避风险很好理解,就是要对可能发生的风险,放弃或者修改导致风险的方案。这样就从根源上消除了风险,简单而彻底。
就像我前面举的因为使用React技术导致风险的例子可以直接放弃使用React用回熟悉的Angularjs技术这样就可以避免技术风险的发生。
但这种方案不一定适合所有情况,例如拼多多“无门槛券”的风险,就无法采用这种方案。
* **转移风险——将损失转嫁出去**
以前玩大富翁游戏,最开心就是有一张“嫁祸卡”,万一遇到倒霉事就可以转嫁到其他玩家身上。转移风险也是这个思路,就是为了避免承担风险损失,将损失转嫁出去的方法。
日常生活中买保险就是一个例子,发生意外,保险公司会帮助赔付。
在软件项目中,举例来说,如果你的团队对于服务器管理不是很在行,有可能会遇到服务器宕机或数据库丢失数据等风险,就可以考虑购买云服务,这样云服务商会帮你解决服务器宕机或数据库丢失的问题,而且万一宕机或丢数据了他们也会承担一定的责任。
* **缓解风险——降低风险发生概率或减少可能造成的损失**
缓解风险就是在风险发生前采取一定措施,降低风险发生的概率,或者减少风险可能造成的损失。
比如你要担心数据库数据丢失的风险,就需要定期备份数据库;比如你担心核心成员要离职,那就涨点工资,避免人才流失。
拼多多的无门槛券也是个典型的例子如果对券的消费增加一定的限制比如说每个用户有领取的上限一个月不能超过100张每张券不超过10元不能用于购买Q币手机话费等虚拟物品这样即使出现问题也不会造成很大损失。
我们在《[04 | 瀑布模型之外,还有哪些开发模型?](http://time.geekbang.org/column/article/84054)》中学到了“螺旋模型”,也是这种策略:每个迭代都要做一下风险评估,再决定项目是不是继续。
* **接受风险——明知山有虎偏向虎山行**
还有一些风险本身很难避免,或者去应对这个风险的成本超过风险发生后造成的损失,那么就没必要应对,直接选择承担风险后果就好了。
比如说前面说的采用新技术React导致进度延迟的案例这个风险虽然有很大概率发生但是进度延迟的影响可以接受并且让团队今后在技术栈上多了新的选择长远来看对项目更有利那么这个风险就是可以接受的还是可以继续做下去。
回避风险、转移风险、缓解风险、接受风险,以上就是针对风险提前准备的一些应对策略,实际项目中,可以根据实际情况来灵活运用以上策略,有效应对风险,减少可能损失。
**第四步:风险监控,对风险进行监控预警**
风险在没发生的时候并不会变成问题也不会造成损失,如果风险可以监控,可以预知风险即将发生,或者可以在风险发生后,第一时间知道,那么就可以马上对风险进行干预,避免变成更大的问题。
要做好监控,第一要能对监控的内容量化,第二要设置阈值,第三就是要有后续的报警和处理机制。
很多公司都已经建立了自己的监控系统,将关键数值量化,并设置阈值,超过阈值后自动触发报警机制。
一个简单的例子就是服务器宕机了,监控系统发现机器没响应了,自动通过邮件、短信、电话等方式通知正在值班的人员。
还有稍复杂一点的方式,像网络服务,可以监控每一次请求结果的状态码,统计请求的成功率。如果单位时间内,服务出错的比例低于阈值,那说明服务是正常的;如果错误比例超过阈值,那说明是出现了问题,需要报警通知相关人员,马上处理。
再回到拼多多“无门槛优惠券”的例子,其实有很多数据可以监控到,比如说单位时间内优惠券使用数量,商品销售数量等,如果结合一些可视化视图,应该可以直观地看到当时有大量虚拟商品销售,大量的优惠款被使用。
如果针对优惠款设置了阈值例如每分钟使用超过1000张就触发报警那么也可以及时发现无限刷的问题避免造成更大损失。
以上四个风险管理的步骤是一个连续循环的过程,在整个项目期间,都要持续地对风险进行识别,对风险量化,对于风险采取应对计划,对风险进行监控。
![](https://static001.geekbang.org/resource/image/11/30/11b6e81fd2baffcb0c025bb56c71e130.jpg "项目风险管理过程")
## 总结
今天带你一起学习了软件项目管理中的风险管理知识。软件项目中的风险就是指那些不确定的但是可能会造成消极影响的事件,通过对风险的管理,可以有效降低风险发生的概率,减少风险发生后的损失。
软件项目风险管理包括风险识别、风险量化、应对计划和风险监控四个过程,这四个过程是一个循环的过程,需要在项目中持续进行。
希望你在学习后能提高风险意识不能盲目乐观凡事都应该有B计划。并且能将学到的风险管理知识应用到项目中做到对可能的风险了然于胸未雨绸缪运筹帷幄。
## 课后思考
按照风险管理的知识可以对你目前项目中按照发生概率或造成后果列出1-3条风险并思考如何能管理这些风险。欢迎在留言区与我分享讨论。
感谢阅读,如果你觉得这篇文章对你有一些启发,也欢迎把它分享给你的朋友。