zoukankan      html  css  js  c++  java
  • 软件架构的5种视图

    方法如路标。

    软件架构的5中视图包括:逻辑架构、开发架构、运行架构、物理架构、数据架构。

    逻辑架构:关注功能。不仅包括用户可见的功能,也包括一些基础模块以及辅助模块。

    开发架构:关注程序包,不仅包括要编写的程序,还包括可以直接使用的第三方SDK或者现成的框架、类库以及开发的系统将运行于其上的系统软件或者中间件。

    运行架构:关注进程、线程、对象等运行时概念,以及相关的并发、同步、通信等问题。

    物理架构:关注‘目标程序及其依赖的运行库和系统软件’最终如何安装或部署到物理机器,以及如何部署机器和网络来配合软件系统的可靠性、可伸缩性等要求。

    数据架构:关注持久化数据的存储方案,不仅包括实体及其实体关系的数据存储格式,还包括数据传递、数据复制和数据同步等策略。

    运行架构和开发架构的关系:开发架构一般偏重于程序包在编译时期的静态依赖关系,而这些程序运行起来后会表现为对象、线程、进程,运行架构比较关注这些运行时单元的交互问题。

    物理结构和运行架构的关系:运行架构特别关注目标程序的动态执行情况,而物理架构重视目标程序的静态位置问题;物理架构还要考虑软件系统和包括硬件在内的整个IT系统之间是如何相互影响的。

    数据架构和物理架构的关系:对于很多集成系统,数据需要在不同系统之间的传递、复制和暂存,这往往要涉及到不同的物理机器。

    五种架构视图的关注点各有侧重。逻辑架构侧重功能需求;开发架构侧重开发期间质量属性;运行架构侧重运行期质量属性;物理架构侧重安装和部署需求;数据架构侧重数据需求。

    两个问题:

    1.       多个架构视图之间的同步问题

    不同的软件架构视图之间不是独立的,它们分别从不同的角度反映了一个软件系统的特性,所以之友它们合在一起时,才是一个完整的软件系统,所以需要保持各个视图之间是相互解释的,而不是相互矛盾的。

    2.       架构视图的数量问题

    忌讳为了架构而架构,不是所有类型的软件系统都需要所有的5个视图。例如对于不涉及到数据存储的系统,那么是不需要数据架构的;对于单机版的系统,不涉及到分布式的需求,那么物理架构相对来说也比较简单。


    参考文献
    《软件架构设计》 温昱
        
    作者:李潘
             
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    2.2 Scala基础知识
    Linux---用户及权限管理类命令
    Linux---进程控制类命令
    Linux---vim编辑文本文件
    Linux---文件压缩与解压缩命令
    Linux---查找命令
    Linux---基本目录与文件命令
    nginx配置技巧汇总
    Go 内嵌静态资源
    go语言的time.Sleep
  • 原文地址:https://www.cnblogs.com/wing011203/p/1244715.html
Copyright © 2011-2022 走看看