什么是真正的架构设计?十年Java经验让我总结出了这些( 二 )


类似:

什么是真正的架构设计?十年Java经验让我总结出了这些

文章插图
 
应用架构:应用作为独立可部署的单元,为系统划分了明确的边界,深刻影响系统功能组织、代码开发、部署和运维等各方面. 应用架构定义系统有哪些应用、以及应用之间如何分工和合作 。这里所谓应用就是各个逻辑模块或者子系统 。
应用架构图关键有2点:
①. 职责划分: 明确应用(各个逻辑模块或者子系统)边界
  • 逻辑分层
  • 子系统、模块定义 。
  • 关键类 。
【什么是真正的架构设计?十年Java经验让我总结出了这些】②. 职责之间的协作:
  • 接口协议:应用对外输出的接口 。
  • 协作关系:应用之间的调用关系 。
应用分层有两种方式:
  • 一种是水平分(横向),按照功能处理顺序划分应用,比如把系统分为web前端/中间服务/后台任务,这是面向业务深度的划分 。
  • 另一种是垂直分(纵向),按照不同的业务类型划分应用,比如进销存系统可以划分为三个独立的应用,这是面向业务广度的划分 。
应用的合反映应用之间如何协作,共同完成复杂的业务case,主要体现在应用之间的通讯机制和数据格式,通讯机制可以是同步调用/异步消息/共享DB访问等,数据格式可以是文本/XML/JSON/二进制等 。
应用的分偏向于业务,反映业务架构,应用的合偏向于技术,影响技术架构 。分降低了业务复杂度,系统更有序,合增加了技术复杂度,系统更无序 。
应用架构的本质是通过系统拆分,平衡业务和技术复杂性,保证系统形散神不散 。
系统采用什么样的应用架构,受业务复杂性影响,包括企业发展阶段和业务特点;同时受技术复杂性影响,包括IT技术发展阶段和内部技术人员水平 。业务复杂性(包括业务量大)必然带来技术复杂性,应用架构目标是解决业务复杂性的同时,避免技术太复杂,确保业务架构落地 。
3. 数据架构
数据架构指导数据库的设计. 不仅仅要考虑开发中涉及到的数据库,实体模型,也要考虑物理架构中数据存储的设计 。
什么是真正的架构设计?十年Java经验让我总结出了这些

文章插图
 
4. 代码架构(也叫开发架构):
子系统代码架构主要为开发人员提供切实可行的指导,如果代码架构设计不足,就会造成影响全局的架构设计 。比如公司内不同的开发团队使用不同的技术栈或者组件,结果公司整体架构设计就会失控 。
代码架构主要定义:
①. 代码单元:
  • 配置设计
  • 框架、类库 。
②. 代码单元组织:
  • 编码规范,编码的惯例 。
  • 项目模块划分
  • 顶层文件结构设计,比如mvc设计 。
  • 依赖关系

什么是真正的架构设计?十年Java经验让我总结出了这些

文章插图
 
5. 技术架构
技术架构:确定组成应用系统的实际运行组件(lvs,nginx,Tomcat,php-fpm等),这些运行组件之间的关系,以及部署到硬件的策略 。
技术架构主要考虑系统的非功能性特征,对系统的高可用、高性能、扩展、安全、伸缩性、简洁等做系统级的把握 。
系统架构的设计要求架构师具备软件和硬件的功能和性能的过硬知识,这也是架构设计工作中最为困难的工作 。
6. 部署拓扑架构图(实际物理架构图):
拓扑架构,包括架构部署了几个节点,节点之间的关系,服务器的高可用,网路接口和协议等,决定了应用如何运行,运行的性能,可维护性,可扩展性,是所有架构的基础 。这个图主要是运维工程师主要关注的对象 。
什么是真正的架构设计?十年Java经验让我总结出了这些

文章插图
 
物理架构主要考虑硬件选择和拓扑结构,软件到硬件的映射,软硬件的相互影响 。
三. 架构级别我们使用金字塔的架构级别来说明,上层级别包含下层:
什么是真正的架构设计?十年Java经验让我总结出了这些

文章插图
 
  • 系统级:即整个系统内各部分的关系以及如何治理:分层
  • 应用级:即单个应用的整体架构,及其与系统内单个应用的关系等 。
  • 模块级:即应用内部的模块架构,如代码的模块化、数据和状态的管理等 。
  • 代码级:即从代码级别保障架构实施 。
战略设计与战术设计
基于架构金字塔,我们有了系统架构的战略设计与战术设计的完美结合:


推荐阅读