架构师必备 -- 如何画好架构图

Posted ukzq

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了架构师必备 -- 如何画好架构图相关的知识,希望对你有一定的参考价值。

1. 什么是架构

架构就是对系统中的实体以及实体之间的关系所进行的抽象描述,是一系列的决策.

架构是结构和愿景.

系统架构是概念的体现,是对物/信息的功能与形式元素之间的对应情况所做的分配,是对元素之间的关系以及元素同周边环境之间的关系所做的定义.

做好架构是个复杂的任务,也是个很大的话题,本篇就不做深入了.有了架构之后,就需要让干系人理解,遵循相关决策.

2. 什么是架构图

系统架构图是为了抽象的表示软件系统的整体轮廓和各个组件之间的相互关系和约束边界,以及软件系统的物理部署和软件系统的演进方向的整体视图.

3. 架构图的作用

一图胜千言.要让干系人理解,遵循架构决策,就需要把架构信息传递出去.架构图就是一个很好的载体.那么,画架构图是为了:

  • 解决沟通障碍
  • 达成共识
  • 减少歧义

4. 架构图分类

搜集了很多资料,分类有很多,有一种比较流行的是4+1视图,分别为场景视图,逻辑视图,物理视图,处理流程视图和开发视图.

  • 场景视图  
    • 场景视图用于描述系统的参与者与功能用例间的关系,反映系统的最终需求和交互设计,通常由用例图表示.
    • 场景视图用于描述系统的参与者与功能用例间的关系,反映系统的最终需求和交互设计,通常由用例图表示.
    • 技术图片

       

       

  • 逻辑视图
    • 逻辑视图用于描述系统软件功能拆解后的组件关系,组件约束和边界,反映系统整体组成与系统如何构建的过程,通常由UML的组件图和类图来表示.
    • 逻辑视图用于描述系统软件功能拆解后的组件关系,组件约束和边界,反映系统整体组成与系统如何构建的过程,通常由UML的组件图和类图来表示.
    • 技术图片

       

       

  • 物理视图
    • 物理视图用于描述系统软件到物理硬件的映射关系,反映出系统的组件是如何部署到一组可计算机器节点上,用于指导软件系统的部署实施过程.
    • 物理视图用于描述系统软件到物理硬件的映射关系,反映出系统的组件是如何部署到一组可计算机器节点上,用于指导软件系统的部署实施过程.
    • 技术图片

       

       

  • 处理流程视图
    • 处理流程视图用于描述系统软件组件之间的通信时序,数据的输入输出,反映系统的功能流程与数据流程,通常由时序图和流程图表示.
    • 处理流程视图用于描述系统软件组件之间的通信时序,数据的输入输出,反映系统的功能流程与数据流程,通常由时序图和流程图表示.
    • 技术图片

       

       

  • 开发视图

    开发视图用于描述系统的模块划分和组成,以及细化到内部包的组成设计,服务于开发人员,反映系统开发实施过程.

    开发视图用于描述系统的模块划分和组成,以及细化到内部包的组成设计,服务于开发人员,反映系统开发实施过程.

    技术图片

 

 

以上5种架构视图从不同角度表示一个软件系统的不同特征,组合到一起作为架构蓝图描述系统架构.

以上是关于架构师必备 -- 如何画好架构图的主要内容,如果未能解决你的问题,请参考以下文章

怎么画出好的架构图,架构师必备。。

怎么画出好的架构图,架构师必备。。

架构师必备技能:教你画出一张合格的技术架构图

史上最全最详细的Java架构师成长路径图,程序员必备

怎么画出好的架构图,架构师必备技能

架构师成长之路--架构师必备技能(目标)