前言

开发人员经常会面临下面一些场景:

  • 新人入职,需要学习已有系统,作为 landing 的一部分,如何学习?

  • 被拉过去参与一个陌生系统的迭代开发或者系统维护(bugfix),如何快速上手?

  • 同事离职或转岗,需要把系统交接给你,怎么去接?内心 os:这是一口锅吗?

这样的场景多了,就需要去梳理常见问题以及应对方法,方便后续遇到类似场景可以快速应对。本文总结熟悉系统主要分三部分:业务学习、技术学习、实战。每部分会梳理一些在学习过程中需要解答的问题,这些问题随着经验的积累需要逐步补充完善。

业务学习

业务学习就是从业务角度去学习系统,我们需要了解系统的客户是谁、使用人是谁、带来了什么价值,系统提供了哪些功能等。不清楚业务,就等于不知道系统在干什么。技术是为业务落地而服务,清楚了业务才知道怎样用技术更好地服务业务,所以业务学习是熟悉一个系统的首要任务。这块主要的学习方式有跟产品、运营、开发沟通,学习产品设计文档文档、PRD、自己使用系统,还有一些常见图,如产品功能架构图、业务流程图、功能树,用例图等。

常见问题:

  • 系统所在行业的情况是怎样?

  • 系统的目标用户是谁?比如是给公司高层做决策用?给运营或客服用?还是互联网用户用?

  • 平均有多少人在使用?高峰期多有少人在用?

  • 系统有什么业务价值?有哪些指标可以衡量系统业务价值?

  • 系统有哪些功能模块?

  • 系统有哪些领域概念?梳理下系统的领域模型。

  • 系统的关键业务流程有哪些?关键业务流程是怎样?

  • 系统的非功能性需求有哪些?如性能、质量、扩展性、安全性等。

  • 系统未来的发展规划是怎样?

技术学习

技术学习主要学习系统的架构、如何实现、系统的运维等。描述一个系统的架构有五视图方法论,五视图分别是:逻辑架构、开发架构、运行架构、物理架构、数据架构。

逻辑架构

逻辑架构着重考虑功能需求,系统应当向用户提供什么样的服务,关注点主要是行为或职责的划分。常用表达图形,静态图有包图、类图、对象图,动态图有序列图、协作图、状态图、活动图。逻辑架构的核心设计任务是模块划分、接口定义、领域模型细化。

常见问题:

  • 有哪些子系统或模块?系统之间是什么样的关系?

  • 对外上下游接口有哪些?对接人是谁?

  • 关键业务流程怎么实现的?用类图、序列图等方式表达出来。

开发架构

开发架构关主要关注系统源代码、第三方SDK、使用的框架、中间件、工具包。

常见问题:

  • 代码在哪?

  • 包怎么划分的?怎么分层?如 mvc、controller-service-dao。

  • 用了什么框架?如 ssh、dubbo。

  • 用了哪些工具包?如 apache commons、guava。

  • 用了哪些中间件?如 metaq、tair、schedulerX、Diamond。

  • 依赖哪些平台?如权限平台、流程引擎等。

运行架构

运行架构的着重考虑运行期质量属性,关注点是系统的并发、同步、通信等问题,这势必涉及到进程、线程、对象等运行时概念,以及相关的并发、同步、通信等。

常见问题:

  • 系统能支撑多少 qps ?峰值 qps 多少?

  • 与上下游系统怎么交互的?rpc?http?同步还是异步?

物理架构

物理架构的设计着重考虑安装和部署需求,关注点是目标程序及其依赖的运行库和系统软件最终如何安装或部署到物理机器,以及如何部署机器和网络来配合软件系统的可靠性、可伸缩性、持续可用性、性能和安全性等要求。

常见问题:

  • 系统如何发布部署?有哪些部署环境?

  • 系统有多少台机器?

  • 系统部署怎么部署的?关注接入层,部署方式,如集群部署、分布式部署等。

  • 有没有容器化?

  • 有没有多机房部署?

数据架构

数据架构的设计着重考虑数据需求,关注点是持久化数据的存储方案,不仅包括实体及实体关系数据存储格式,还可能包括数据传递、数据复制、数据同步等策略。

常见问题:

  • 数据存储在哪?用了什么数据库,如 oracle、mysql。

  • 梳理 E-R 图。

  • 数据量有多少?是否有分库分表?

  • 用了哪些 nosql 库?

  • 有哪些数据同步任务?

  • 大数据框架的使用情况如何?

系统运维

系统运维重点关注什么时候会出问题,出了问题怎么解决。

常见问题:

  • 什么时间容易出问题?比如电商双十一,对系统的压力很大,这时候很容易出问题。

  • 对关键功能是否有监控?需要看系统有配置了哪些报警项,监控了哪些方面。

  • 出了问题怎么解决?日志在哪?是否有全链路跟踪?是否有一些紧急操作,比如开关配置、降级、限流配置。

  • 系统有哪些坑?找开发同学回顾历史问题,以免踩坑。通过同事总结的 case,或者与负责的产品、运营、技术与了解。系统总会有一些坑,需要把这些坑填上。历史代码经过多次迭代总会导致复杂度高(分支、嵌套、循环很多),存在设计漏洞,性能隐患等,很难维护,这些就需要我们去重构了。记住有一句话:填的坑越大,能力越大。

  • 运营、客服反馈的常见问题有哪些?

实践

熟悉了系统的业务和技术后,就要实战了,通过实战进一步加深对系统的熟悉程度。实践可以通过做需求、修 bug、重构等方式,亲自动手编码、调试、测试、上线。

总结

已有系统通常经历了从 0 到 N 的建设过程,熟悉系统其实是一个逆向推导过程,也是一个学习架构、阅读源码的过程。在学习的过程中最好能带上思考,比如为什么要这么设计,为什么要用这个中间件?是否有更好的编码方式?哪些地方可以优化等,以此达到一个深入熟悉的过程。

总结图

如何快速熟悉一个系统相关推荐

  1. 灵魂 36 问,让你快速熟悉一个系统

    简介: 面对一个完全陌生的系统,如何快速的熟悉并上手?本文将从三个方面进行总结,提供一个系统的方法,同时也可以用来 review 已有的系统,查漏补缺. 前言 开发人员经常会面临下面一些场景: 新人入 ...

  2. 入职新公司,如何快速熟悉一个系统

    文章末尾给大家留下了大量的福利 前言 大家都知道我们新入职一家公司,经常会面临下面一些场景: 新人入职,需要学习已有系统,作为 landing 的一部分,如何学习? 被拉过去参与一个陌生系统的迭代开发 ...

  3. 如何熟悉一个系统?(内含知识大图)

    作者 | 唐志龙(鲲龙)  阿里巴巴高级开发工程师 导读:本文总结了熟悉系统主要分三部分:业务学习.技术学习.实战.每部分会梳理一些在学习过程中需要解答的问题,这些问题随着经验的积累需要逐步补充完善. ...

  4. 新闻发布系统类图_如何熟悉一个系统?(内含知识大图)

    开发人员经常会面临下面一些场景: 新人入职,需要学习已有系统,作为 landing 的一部分,如何学习? 被拉过去参与一个陌生系统的迭代开发或者系统维护(bugfix),如何快速上手? 同事离职或转岗 ...

  5. 开发者如何快速熟悉一个新敏捷项目

    在ThoughWorks有一句流传甚广的话 -- "在ThoughtWorks需要有拥抱随时变化的心态",因为我们践行敏捷.我们有各种各样的客户,而商机稍纵即逝.作为普通的dev, ...

  6. 如何快速了解一个系统?

    前言 开发人员经常会面临下面一些场景: 新人入职,需要学习已有系统,作为 landing 的一部分,如何学习?被拉过去参与一个陌生系统的迭代开发或者系统维护(bugfix),如何快速上手?同事离职或转 ...

  7. 没有文档,没有老员工讲解,悲催的新人如何快速熟悉一个新项目?

    本文来自闪客Sun的投稿,博客地址: https://www.cnblogs.com/flashsun/p/9450066.html 看完你就会明白,虽然有一定的方法论,但是不下功夫,没有耐心,还是万 ...

  8. 分享:新入职时,如何快速熟悉一个项目的代码

    一.总体思路 昨晚是深夜撰文的阿菌,希望通过这篇文章和大家分享一下,初入职场时,如何才能快速地熟悉一个项目的代码. 说实话,感觉自己去年入职时上手项目的速度是比较慢的,可能是没有一些系统的方法论参考吧 ...

  9. 如何快速熟悉一个项目

    2019独角兽企业重金招聘Python工程师标准>>> 对IT人士而言,换一份工作或进入一个新的公司,往往意味着要熟悉一个新的开发环境,要快速了解新的项目.如何快速地熟悉项目代码,是 ...

最新文章

  1. 从严把控_精准把控 推动从严治党走深走实
  2. U3D临时文件GICache巨大
  3. Quantconnect
  4. gradle编译打包过程 之 ProcessAndroidResources的源码分析
  5. Spring JdbcTemplate Curd
  6. 1-算法 排序 选择排序
  7. as的Enter_Frame与Timer
  8. python 多线程读写文件_Python多线程同步---文件读写控制方法
  9. Android增量更新——bsdiffbspatch
  10. pandas 的数据结构Series与DataFrame
  11. 【jmeter教程——从入门到熟练】
  12. tenacity 报错_tenacity 重试
  13. 回归技术——我看中国软件的发展方向
  14. qsort vs sort
  15. AG7110|AG7111|HDMI视频切换器方法全解
  16. 黑马程序员_Java_交通灯管理
  17. 我的世界1.12.2java下载_我的世界1.12.2
  18. 数据通信原理_华为面向全球发布Datacom认证 未来三年培养15万数据通信网络人才...
  19. 计算机在食品上的应用论文,文字设计在食品包装设计中的运用论文
  20. 程序员怎么悄无声息迈过36岁大槛?

热门文章

  1. JAVA实现QRCode的二维码生成以及打印
  2. this.date与this.setDate(
  3. 用PDMReader导成word
  4. php进程导致服务器cpu占用100%问题追查过程
  5. 使用禅道或Jira系统对接钉钉的群机器人消息管理,为什么没有艾特 @人呢?
  6. 你知道阿里钉钉群机器人@所有人自动发送消息功能用程序如何实现吗?
  7. Python编写超级玛丽竟如此简单?不信你试试
  8. 1.Java基础-注解
  9. 李沐动手学深度学习V2-实战Kaggle比赛:叶子分类(Classify Leaves)和代码实现
  10. 在自定义Shader中应用Unity全局光照