作者 | Bella酱

有人说“一起在湖边吹过晚风的人,会记得更久一些吧”,那一起住过院的人,是不是可以刻骨铭心了?之前就想写篇文章总结一下自己前段时间当PM的经历呢,奈何发布了这个需求,还有另外一个需求要发布,周末稍微有点时间了,又想睡觉续命,我的懒癌就又犯了:(哇哇,我也只是个孩子呀,咳咳,阿姨言归正传,所以所以,一拖再拖,直到在医院的这几天。

每一个项目做完,或者跳出了一个舒适区,还是要自我总结复盘下的,不是么?一来以一个局外人的身份,系统地看待下自己所做的这个事情,二则为自己以后回顾这段时光提供一些素材,不然,说不定以后自己会忘记呢~

以下来源于Bella酱在阿里当PM的经历的总结,如有不当,欢迎批评指正~

1.项目立项

做一个项目之前,你要清楚为何要做这个项目,这个项目的价值和意义在哪里?如果是现有版本的大升级,那你还需要清晰的知道目前版本存在哪些问题,痛点是什么,扩展性如何,可维护性如何等等。同时还要确定升级后的版本的目标,只有目标确定了,后面技术方案选型的时候,你才会知道应该选取哪种技术方案,因为你选的技术方案,要能足够实现你的目标。

对于中台项目而言,还要考虑2个问题,即兼容性和差异性。所谓的兼容性,即指升级后的版本是否可以无缝兼容新接入一个行业?接入成本有多高?是否可以把一部分接入工作交由产品 or 运营同学来做,解放一部分技术同学劳动力?所谓差异性,即指升级后的版本是否可以支持不同行业间存在的差异,是否可以做到相互隔离,互不影响。

一般情况下,我会选择用思维导图来表达这些信息,图往往会比文字更简明直观一些,TL们的接受度也更高一些。

2.技术预研

这一阶段的主要目的就是基于上一阶段确定的目标,调研哪些技术可以支撑你实现这个目标,这些技术理论上的可行能否最准转变为落地上的可行,可以拿当前业务场景以及数据做一个推演,数据推演ok之后,可以再做一个小的可以运行的demo,以证明该技术真正可以用在此项目中。

此阶段需要产出各个技术选型的数据推演图,如果推演过程比较复杂的话,也可以考虑再产出一份比较详细的Excel样式的数据推演图,每一个步骤数据如何变化都要体现出来。另外,还需要产出各个技术选型可运行的demo。最后,需要产出各种技术选型的对比,表格形式或思维导图形式都可以,切忌纯文字。基于上述对比,确定最终的技术选型,然后就可以开始技术方案的编写啦~

3.技术方案编写

私以为技术方案应该包含以下几部分,业务背景、场景分析、系统架构、应用架构、系统流程图、领域模型设计、存储模型设计、全局可用定义、功能模块设计、接口定义、项目里程碑等等,如果是需要出海的项目,还需要考虑下本地化方式、时区偏移、部署方式等等。

3.1 业务背景

业务背景主要是交代下做这个项目的背景,即为什么要做这个项目,基于一个什么样的业务背景,也可以把【1.项目立项】中画的思维导图直接放在这一pa。

3.2 场景分析

场景分析则主要是讲这个系统有哪些应用场景,如果能够列举出业务方的真实诉求,那是最好不过了。然而大多数程序员的生活,并不会直接对接业务方同学,而是对接产品经理。

3.3 系统架构

系统架构推荐以图的方式来展示。开局一张图,剩下全靠讲,也不是不可以哈。Bella酱就有过这种经历,开局我放了一张图,然后看着大佬们讲了3个多小时。佩服佩服,那次经历也让我懂得,表达方式是何等重要。一般情况下我会这么画系统架构图,主要侧重于表达用了哪些中间件、什么数据源、什么应用、开放什么SPI、以及这其中各组件之间是如何交互的,最终可以支撑哪些业务。

3.4 应用架构

应用架构仍然推荐图的方式来表达。我一般这么画应用架构图,主要侧重于表达应用由哪些模块组成,每个模块包含哪些功能,各模块之间的层次关系,哪些应用包含哪些模块。另外,这张图中也是可以把用了哪些中间件、什么数据源,支持哪些业务场景画上的,这样这张图会更完整一些,即使不看系统架构图,单单看这一张图,也是可以明白整个项目的设计的。

3.5 系统流程图

系统流程图以流程图为主,可以辅以文字说明,或者表格说明,由于这个和业务逻辑紧密相关,此处不再举例。

3.6 领域模型设计

领域模型设计,这一阶段是非常有必要的,先确定领域模型,后再根据领域模型确定存储模型,并非所有的领域模型都要转换为存储模型,从而保存到数据库中。领域模型设计过程中,要十分清楚系统整体流程图,可以结合上个阶段的系统流程图,来推演一下,根据这些领域模型是否可以推演出系统的正常正确运行。图为主,辅以必要的文字说明此领域模型设计如何让系统运行即可。

3.7 存储模型设计

存储模型设计,需要详细到表中每个字段的设计,字段类型、是否为主键、是否需要建索引、是否可为空、是否为分表字段等等。表结构设计表格展示即可。存储模型设计,还是建议图片的形式表达,方便展示各表之间的关系。

3.8 全局可用定义

全局可用定义,主要定义一些通用的方法、枚举类、共同的约定等,以避免各个应用or各开发人员定义一套自己的方法、枚举等,以确保同一个字段or同一个方法等在系统内唯一。

3.9 功能模块设计

功能模块设计,即各模块的详细设计,这里应该尽可能详细,可以举一些例子,确保负责此模块开发的同学看文档即可明白要做什么,以及如何做。必要的话,可以各模块再出一个详细的技术方案。

3.10 接口定义

接口定义,呐,不多做解释,记得写清楚入参、出参、接口名字,入参和出参记得用自定义类来接收,不要忘记实现序列化哟~

BaseResult、isSuccess、getData、getErrorMessage、buildErrorResponse、buildSuccessResp这些基础的类和方法也不要忘记呀!

3.11 项目里程碑

项目里程碑,即项目的时间节奏,例如开发时间、联调时间、提测时间、发布时间等,此时也应该确定各种资源了,确保相关同学可以在你计划的时间范围内投入项目中。

3.12 其他

如果你的项目需要出海,那你还需要考虑系统的部署方式、本地化、时区偏移、系统所需中间件是否支持等等。

4.项目过程把控

只有好的方案,项目过程把控不到位,最终也是无法交付一个令人满意的产品的。那如何才能使项目按照既定计划有序进行,同时又能保证交付的质量呢?

作为一个项目的owner,你需要做:

  1. 技术方案要切实可行

  2. 明确整个项目的时间节奏,每个阶段应该交付什么可衡量的结果,每个阶段之间的关联性,不能按时交付的影响

  3. 明确每个人所做的事情,每个事情需要做多久,交付结果是什么

  4. 是否可阶段性提测,阶段性验证

  5. 识别项目中存在的风险,风险是否可控

  6. 大促封网,和上下游依赖这些因素也要考虑

  7. 测试人员等相关人员需要提前锁定

具体到action上面,则可以考虑下下面这些:

  1. 日会了解每个人的进度、风险点、需要协助的点等

  2. 各个阶段的可运行单测是必须的

  3. 定期review代码(例如一周一次),check真实进度,owner或owner&相应开发人员参加即可

  4. 制定开发规范,保证代码风格统一

  5. 功能拆分尽可能细,一个功能点最好不要超过5天,尽量控制在3天之内

  6. 开发整体自测ok之后,对项目进行整体code review,同时提测

  7. code review之后修改的代码,全部修改完毕之后,要进行整体的回归测试,回归测试期间除bug问题,不允许再修改代码

  8. 发布避开大促封网,发布之前确定依赖方发布时间点,看下发布顺序有木有要求

其中,应重点关注项目中的风险,无论是何种原因,自己可控or不可控因素造成的,现状偏离计划的事情,都属于项目风险,应尽早抛出来,而且应尽可能保证你希望看到这一风险的人看到。其次,风险不是抛出来就完事了,还要考虑下是否可以cover掉这一风险,是否需要其他人协助,需要的话,也应尽早提出来。最后,尽可能多给测试留一些时间,你永远不知道测试过程中会发现什么问题。

5.交付清单

交付清单的意义不仅仅在于给到产品同学,让他check他所提的需求我们已实现,还在于我们自身对这个项目的一个回顾,另外,交付清单也可以给到测试同学一个最强王者辅助的作用,测试人员对比交付清单即可知道本次项目的所有功能,方便他们测试。所以,交付清单应尽可能详细,和TC 不冲突哦~

推荐思维导图+Excel+文字的形式展现。

6.发布前准备

主要是一些资源准备,例如线上服务器、线上DB、线上mq等等各种中间件及资源的准备。

其次,将项目中用到的SNAPSHOT 版本二方包替换为正式版二方包,替换完,记得再回归测试一下。

另外,还需要确定依赖的上下游的发布时间,如果此次发布依赖上下游的发布时间,需要和他们协商好具体的发布时间,确定到几点,以方便我们到点check他们是否发布,以决定我们是否可以发布。

咳咳,发布前也可以写一些工具,假如线上数据出现问题,可以通过这些工具修复数据。一名合格的数据卫士不应该直接订db,而应该通过工具来修复。项目上线,相应的工具也同步上线。

7.发布

发布过程中,需要看各种监控,确保此次发布没有问题,才能继续大范围发布。

发布完成,还应该有线上测试环节,以check线上功能可用。

同时,需要跟进几天线上监控、报警、日志等,确保没有问题后,才算此次发布顺利完成。

8.复盘

个人的复盘是必须的,原因我就不多说了。这里的复盘指的不是你对外分享/宣讲等等的复盘,而是对你内心那个真实的自己来讲的复盘,在这个项目中自己究竟有没有成长,成长了哪些,哪些地方做的好,哪些地方做的不好,不好的地方下次可不可以避免or解决,这个项目有没有偏离你的初衷等等。

特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:

长按订阅更多精彩▼如有收获,点个在看,诚挚感谢

在阿里当PM都需要做什么?相关推荐

  1. 阿里腾讯都在做的可视化大屏,我用这工具里的100个模板实现了

    必须得给各位来点干货东西. 阿里腾讯都在做的可视化大屏,我用这工具里的100个模板实现了. 我听很多人说,很多景区.医院.工厂的入口处都有这种可视化大屏,其实你不知道的是,这些东西不仅仅是所谓的&qu ...

  2. 阿里当 PM 需要做什么?程序媛的亲身经历告诉你!| 程序员有话说

    作者 | Bella酱 来源 | Bella的技术轮子 有人说"一起在湖边吹过晚风的人,会记得更久一些吧",那一起住过院的人,是不是可以刻骨铭心了?之前就想写篇文章总结一下自己前段 ...

  3. 阿里技术大神:你没做错啥,你错在啥都没做

    难受,那是因为你正在爬坡,正在成长 你有没有想过,如果你现在做的工作,能看到你10年后的样子,你愿意吗? 领着固定薪水,做着熟练到形成肌肉记忆的事情. 有一天,在舒适区里呆得太久,想跳出来,发现已经没 ...

  4. “感动阿里”的技术小二刘畅:善良的事情,我身边很多人都在做

    凌晨四点半,正是人们为甜蜜的梦乡收尾的时候,刘畅却在这个时候因一阵急促的捶门声而惊醒,门外是一个女孩惊慌失措地喊叫声:"我妈跳楼了,快救救她!" 这位腼腆的阿里巴巴CBU技术小二, ...

  5. 学了阿里中台,却依然做不好系统? 聊聊阿里的项目管理

    戳蓝字"CSDN云计算"关注我们哦! 作者 | 墨玖 来源|  阿里技术 导读:在技术公司.尤其是互联网公司,技术人员作为PM(项目经理)是非常常见的.有些同学得心应手,有条不紊, ...

  6. 为什么多数互联网公司CEO都是做技术出身?

    技术是互联网发展的关键因素,所以只有真正掌握了互联网技术的发展趋势,才能看到价值和利益.从字面上的意思来看,一个互联网公司的创始人,掌管着整个公司前进的方向,他做出的每一个决策都是站在公司的角度而不是 ...

  7. 早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望

    点击上方蓝色"方志朋",选择"设为星标"回复"666"获取独家整理的学习资料! 来源 | https://jitwxs.cn/a64edcb ...

  8. 基于阿里云用C/C++做了一个http协议与TCP协议的web聊天室的服务器——《干饭聊天室》

    基于阿里云用C/C++做了一个http协议与TCP协议的web聊天室的服务器--<干饭聊天室> 在这里首先感谢前端小伙伴飞鸟 前端技术请看一款基于React.C++,使用TCP/HTTP协 ...

  9. NDC 2010视频下载:看看其他微软平台程序员们都在做什么

    原文地址:<NDC 2010视频下载:看看其他微软平台程序员们都在做什么> NDC(Norwegian Developers Conference,挪威开发者大会)是一年一度的挪威最大的微 ...

最新文章

  1. 2021年大数据Flink(二十一):​​​​​​​案例三 会话窗口
  2. 鼠标移到某一行 某一行变色 鼠标移开恢复
  3. JS template string 神奇术
  4. Java线程的优先级
  5. C++描述杭电OJ 2000. ASCII码排序 ||
  6. 支持在iPad中播放的HTML5视频网站推荐
  7. 前端学习(499):水平居中布局得第一种方式得优点和缺点
  8. LeetCode MySQL 1211. 查询结果的质量和占比
  9. include动作与include指令的区别
  10. CoreAnimation编程指南(三)几何变换
  11. 作者:陈婷婷(1986-),女,中国科学院北京基因组研究所生命与健康大数据中心工程师...
  12. 用Android Stuidio开发Flutter
  13. 面向对象课程第四单元作业总结
  14. java基础篇(二) ----- java面向对象的三大特性之继承
  15. 2018跟着小虎玩着去软考--信息系统项目管理师(趣味好玩讲解历年上午试题)-刘畅-专题视频课程...
  16. 用友云实名认证,了解一下
  17. 计算机视觉研究院手把手教你深度学习的部署(手势识别,源码已开源)
  18. 更新显卡驱动后黑屏无法进入系统的解决办法
  19. 企查查接口php版本~
  20. java诺基亚nba,NBA“神器”大比拼 詹皇如三星邓肯似诺基亚

热门文章

  1. 计算机控制系统康波答案,计算机控制系统(康波)第4章部分参考答案[1]
  2. 7/15 我的第一篇博客-写给自己
  3. python中关于sqlite3数据库更新数据的使用
  4. 计算几何题中的英语生词
  5. python 因果推断_KDD 2018:微软推出用于因果推断的Python库
  6. base64 linux_每个Linux新手都应该记住的10个基本Linux命令
  7. 物理学在计算机领域的应用,物理学在计算机中的应用.doc
  8. php sqlsrv_query,sqlsrv_query
  9. matlab disp fprinr,matlab如何使输出结果更美观(symdisp函数——pretty函数升级版)
  10. python编程超市购物系统_python实现简单购物车系统(练习)