写点什么

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

  • 2020-01-29
  • 本文字数:2139 字

    阅读完需:约 7 分钟

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

前言

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


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

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

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



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

业务学习

业务学习就是从业务角度去学习系统,我们需要了解系统的客户是谁、使用人是谁、带来了什么价值,系统提供了哪些功能等。


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


常见问题:


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

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

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

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

  • 系统有哪些功能模块?

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

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

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

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

技术学习

技术学习主要学习系统的架构、如何实现、系统的运维等。描述一个系统的架构有五视图方法论。


五视图分别是:


  • 逻辑架构

  • 开发架构

  • 运行架构

  • 物理架构

  • 数据架构

1. 逻辑架构

逻辑架构着重考虑功能需求,系统应当向用户提供什么样的服务,关注点主要是行为或职责的划分。


常用表达图形,静态图有包图、类图、对象图;动态图有序列图、协作图、状态图、活动图。逻辑架构的核心设计任务是模块划分、接口定义、领域模型细化。


常见问题:


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

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

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

2. 开发架构

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


常见问题:


  • 代码在哪?

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

  • 用了什么框架,如 ssh、dubbo;

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

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

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

3. 运行架构

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


常见问题:


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

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

4. 物理架构

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


常见问题:


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

  • 系统有多少台机器?

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

  • 有没有容器化?

  • 有没有多机房部署?

5. 数据架构

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


常见问题:


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

  • 梳理 E-R 图;

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

  • 用了哪些 nosql 库?

  • 有哪些数据同步任务?

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

6. 系统运维

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


常见问题:


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

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

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

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

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

实践

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

总结

已有系统通常经历了从 0 到 N 的建设过程,熟悉系统其实是一个逆向推导过程,也是一个学习架构、阅读源码的过程。


在学习的过程中最好能带上思考,比如为什么要这么设计?为什么要用这个中间件?是否有更好的编码方式?哪些地方可以优化等,以此达到一个深入熟悉的过程。


附:总结图



作者介绍


唐志龙(鲲龙),阿里巴巴高级开发工程师


本文转载自公众号阿里巴巴云原生(ID:Alicloudnative)。


原文链接


https://mp.weixin.qq.com/s/J8eK-qRMkmHEQZ_dVts9aQ


2020-01-29 11:308438

评论

发布
暂无评论
发现更多内容

「架构师训练营 4 期」大作业一&二

凯迪

架构师训练营 4 期

陪伴

小天同学

陪伴 育儿 个人感悟 4月日更

Python变量作用域与LEGB规则

大奎

语法 Python Monad 作用域

Android中的图像格式

如浴春风

android 音视频 安卓 签约计划

taskwarrior ,一款提升效率的命令行的 TODO list 工具

Red

效率工具 TODO linux操作

浅析LSM-Tree存储模型

正向成长

LSM树 KV存储引擎

Java 并发基础(五):面试实战之多线程顺序打印

看山

Java并发

TIOBE榜单四月已出:上古语言Fortran重回前20?

Bob

编程语言、 4月日更 Tiobe

猫鼠游戏,一个刷票老千看在线投票项目的防范与取舍

ucsheep

安全 在线投票 防作弊 刷票

重读《重构2》

顿晓

重构 4月日更

浪潮签约“数字基建”合作伙伴共促工业互联网创新发展

工业互联网

架构师训练营 4 期 大作业

引花眠

架构师训练营 4 期

css

赫鲁小夫

4月日更

企业上云一张网,华为将在分析师大会上亮出哪些大招?

脑极体

微服务网关方案:Kong & Nacos

程序员架构进阶

架构 微服务 API网关 28天写作 4月日更

更简的并发代码,更强的并发控制

万俊峰Kevin

并发 go-zero Go 语言

模块二作业

c

架构实战营

「 优秀主题征文名单公布 」—— InfoQ 写作平台【 1 周年盛典 】

InfoQ写作社区官方

1 周年盛典 热门活动

Seldon 使用 (二):打包模型

托内多

tensorflow kubeflow Kubernetes PyTorch seldon

AI数据科学认证-2021年的最佳选择 John 易筋 ARTS 打卡 Week 44

John(易筋)

ARTS 打卡计划

初入江湖,IT从业者应该如何选择?

云峰

最详细的基于 Prometheus 的 Azure 指标监控

耳东@Erdong

azure Prometheus 4月日更

WebRTC基础知识详解

IT酷盖

签约计划

从石器时代到田园牧歌:如何对 API 统一建模

李宇飞

API

MySQL多表查询详解

若尘

MySQL 查询

AI数学基础之:确定图灵机和非确定图灵机

程序那些事

人工智能 AI 程序那些事 图灵机

「架构师训练营 4 期」大作业二

凯迪

架构师训练营 4 期

嘉云公司研发效能平台实践

小江

研发效能 CI/CD

对前端趋势的一些理解

葱小白

大前端

「 最佳内容公布」—— InfoQ 写作平台【 1 周年盛典 】

InfoQ写作社区官方

1 周年盛典 热门活动

Spark原理与实战之部署模式与运行机制

小舰

spark Spark调优 4月日更

如何熟悉一个系统?(内含知识大图)_架构_阿里云容器平台_InfoQ精选文章