架构模式从子系统或模块、及其之间的关系层次上描述了粗粒度的解决方案。
架构风格是描述某一特定应用领域中系统组织方式的惯用模式,是系统主要的、组织性的设计。
风格是模式的外在表现。
三者的共同点是都用于设计,是一套可重用的方法套路。不同点:前二者的不同点在于粒度,设计模式定义出子系统或组件的微观结构,结架构模式则从子系统或模块、及其之间的关系层次上描述了粗粒度的解决方案;后二者的区别在于前者着重描述系统的内部组织,后者着重于描述结构的外在表现。
架构风格描述
客户端-服务器 将系统分为两个应用,其中客户端向服务器发送服务请求。
基于组件的架构 把应用设计分解为可重用的功能、逻辑组件,这些组件的位置相互透明,只暴露明确定义的通信接口。
分层架构 把应用的关注点分割为堆栈组(层)。
消息总线 指接收、发送消息的软件系统,消息基于一组已知格式,以便系统无需知道实际接收者就能互相通信。
N层/三层架构 用与分层风格差不多一样的方式将功能划分为独立的部分,每个部分是一个层,处于完全独立的计算机上。
面向对象 该架构风格是将应用或系统任务分割成单独、可重用、可自给的对象,每个对象包含数据,以及与对象相关的行为。
分离表现层 将处理用户界面的逻辑从用户界面(UI)视图和用户操作的数据中分离出来。
面向服务架构(SOA) 是指那些利用契约和消息将功能暴露为服务、消费功能服务的应用。
这些架构风格分别适用于特定领域:
分类架构风格
通信 SOA,消息总线,管道和过滤器
部署 客户端/服务器,三层架构,N层架构
领域 领域模型,网关
交互 分离表现层
结构 基于组件的架构,面向对象,分层架构