本文探讨以下几个问题:php
若是你搜索「架构模式和架构风格的区别」,你会发现答案千差万别:设计模式
我我的的观点是:架构模式是特定问题域下,架构风格的具体应用!浏览器
咱们来一个个的说!架构
在说架构模式以前,咱们先来看看咱们常挂在嘴边的设计模式是怎么定义的!app
GOF在《Design Patterns》这本书的「What is a Design Pattern?」小节,对设计模式下了一个明确的定义:ide
The design patterns in this book are descriptions of communicating objects and classes that are customized to solve a general design problem in a particular context.
设计模式描述了一组类和对象的关系,用以解决特定上下文内的某个常见的设计问题!微服务
那咱们能够这么定义架构模式:架构模式描述了一组组件之间的关系,用以解决特定上下文内的某个常见的架构问题!ui
Wiki上也给架构模式作了相似的定义:this
An architectural pattern is a general, reusable solution to a commonly occurring problem in software architecture within a given context
架构模式是一个通用的、可重用的解决方案,用以解决特定上下文内的某个常见的架构问题!设计
Roy Thomas Fielding博士,在他的REST论文中,对架构风格作出了定义:
An architectural style is a coordinated set of architectural constraints that restricts the roles/features of architectural elements and the allowed relationships among those elements within any architecture that conforms to that style.
一种架构风格是一组协做的架构约束,这些约束限制了架构元素的角色和功能,以及在任何一个遵循该风格的架构中容许存在的元素之间的关系。
Martin Flower在微服务文章中的说明,也间接支持了此定义。文中首先明确「微服务」是一种架构风格,而后给出了微服务所具备的特征(就是约束),具备这些约束的系统就能够说是使用了微服务架构风格!
微软的Azure文档也给出了相似的定义:架构风格即约束!
上面咱们分别给「架构模式」和「架构风格」下了定义!那么「架构模式」和「架构风格」到底有什么区别呢?
咱们来看架构模式的定义,能够抽出几个关键词:
咱们再看架构风格的定义,它仅仅就是约束!约束了组件之间的关系!
因此「架构模式」和「架构风格」的区别就在这里:
若是你仔细看看Wiki中列出的架构风格和架构模式,你就能看出点端倪了!
架构模式 | 架构风格 |
---|---|
Three-Tier Multilayered architecture Model-View-Controller(MVC) Domain Driven Design Micro-Kernel Blackboard Pattern Sensor-Controller-Actuator Presentation–Abstraction–Control |
CQRS Component-based Monolithic application Layered (or multilayered architecture) Pipes and Filters Database-Centric Blackboard Rule-based Event-driven aka implicit invocation Publish-subscribe Asynchronous Messaging Plug-Ins Microkernel Reflection Domain Specific Languages(DSL) Client-Server (2-tier, 3-tier, n-tier exhibit this style) Shared Nothing Architecture Space-based Architecture Object Request Broker Peer-to-Peer Representational State Transfer (REST) Service-Oriented Cloud Computing Patterns MicroServices |
你会发现,架构风格中有「Multilayered」这个架构风格,架构模式里也有「Multilayered」架构模式!好像分层架构既是架构风格,也是架构模式!实际上架构模式中的「分层架构」是架构风格中的「分层架构」的实际应用。
更具备说服力的是CS架构风格,能够看到此架构风格后面有个阐述「2-tier, 3-tier, n-tier exhibit this style」,意思是两层架构、三层架构、n层架构都是CS架构风格的一种表现形式。而能够看到,三层架构是一个架构模式!
你有没有一个疑问?两层架构、三层架构、N层架构为何不是分层架构风格的表现形式?而是CS架构风格的一种表现形式?
这个问题在后面的CS架构和分层架构中会具体阐述。
再具体一点,咱们看看CS架构的约束:
能够看到,这里只是约束了系统分为Client和Server,以及Server和Client之间的行为。
再来看三层架构模式,三层架构通常分为:
能够看到,三层架构模式比CS架构风格更具体,描述了每一层的做用。
当系统有以下需求时,就能够考虑三层架构:
用Renan Johannsen de Paula Venilton FalvoJr在《Architectural Patterns and Styles》中对架构模式和架构风格的区别来总结一下:
实际工做中,咱们通常会说「架构」,而没有具体到是「架构风格」仍是「架构模式」。这么作其实有几点好处: