聊聊十种常见的软件架构模式
有没有想过要设计多大的企业规模系统?
在主要的软件开发开始之前,我们必须选择一个合适的体系结构,它将为我们提供所需的功能和质量属性。因此,在将它们应用到我们的设计之前,我们应该了解不同的体系结构。
什么是架构模式?
根据维基百科中的定义:
架构模式是一个通用的、可重用的解决方案,用于在给定上下文中的软件体系结构中经常出现的问题。架构模式与软件设计模式类似,但具有更广泛的范围。
在本文中,将简要地解释以下10种常见的体系架构模式,以及它们的用法、优缺点。
分层模式
客户端-服务器模式
主从设备模式
管道-过滤器模式
代理模式
点对点模式
事件总线模式
模型-视图-控制器模式
黑板模式
解释器模式
一. 分层模式
这种模式也称为多层体系架构模式。它可以用来构造可以分解为子任务组的程序,每个子任务都处于一个特定的抽象级别。每个层都为下一个提供更高层次服务。
一般信息系统中最常见的是如下所列的4层。
表示层(也称为UI层)
应用层(也称为服务层)
业务逻辑层(也称为领域层)
数据访问层(也称为持久化层)
使用场景:
一般的桌面应用程序
电子商务Web应用程序
二. 客户端-服务器模式
这种模式由两部分组成:一个服务器和多个客户端。服务器组件将为多个客户端组件提供服务。客户端从服务器请求服务,服务器为这些客户端提供相关服务。此外,服务器持续侦听客户机请求。
使用场景:
电子邮件,文件共享和银行等在线应用程序
三. 主从设备模式
这种模式由两方组成;主设备和从设备。主设备组件在相同的从设备组件中分配工作,并计算最终结果,这些结果是由从设备返回的结果。
使用场景:
在数据库复制中,主数据库被认为是权威的来源,并且要与之同步
在计算机系统中与总线连接的外围设备(主和从驱动器)
四. 管道-过滤器模式
此模式可用于构造生成和处理数据流的系统。每个处理步骤都封装在一个过滤器组件内。要处理的数据是通过管道传递的。这些管道可以用于缓冲或用于同步。
使用场景:
编译器。连续的过滤器执行词法分析、解析、语义分析和代码生成
生物信息学的工作流
五. 代理模式
此模式用于构造具有解耦组件的分布式系统。这些组件可以通过远程服务调用彼此交互。代理组件负责组件之间的通信协调。
服务器将其功能(服务和特征)发布给代理。客户端从代理请求服务,然后代理将客户端重定向到其注册中心的适当服务。
使用场景:
消息代理软件,如Apache ActiveMQ,Apache Kafka,RabbitMQ和JBoss Messaging
六. 点对点模式
在这种模式中,单个组件被称为对等点。对等点可以作为客户端,从其他对等点请求服务,作为服务器,为其他对等点提供服务。对等点可以充当客户端或服务器或两者的角色,并且可以随时间动态地更改其角色。
使用场景:
像Gnutella和G2这样的文件共享网络
多媒体协议,如P2PTV和PDTP
像Spotify这样的专有多媒体应用程序
七. 事件总线模式
这种模式主要是处理事件,包括4个主要组件:事件源、事件监听器、通道和事件总线。消息源将消息发布到事件总线上的特定通道上。侦听器订阅特定的通道。侦听器会被通知消息,这些消息被发布到它们之前订阅的一个通道上。
使用场景:
安卓开发
通知服务
八. 模型-视图-控制器模式
这种模式,也称为MVC模式,把一个交互式应用程序划分为3个部分,
模型:包含核心功能和数据
视图:将信息显示给用户(可以定义多个视图)
控制器:处理用户输入的信息
这样做是为了将信息的内部表示与信息的呈现方式分离开来,并接受用户的请求。它分离了组件,并允许有效的代码重用。
使用场景:
在主要编程语言中互联网应用程序的体系架构
像Django和Rails这样的Web框架
九. 黑板模式
这种模式对于没有确定解决方案策略的问题是有用的。黑板模式由3个主要组成部分组成。
黑板——包含来自解决方案空间的对象的结构化全局内存
知识源——专门的模块和它们自己的表示
控制组件——选择、配置和执行模块
所有的组件都可以访问黑板。组件可以生成添加到黑板上的新数据对象。组件在黑板上查找特定类型的数据,并通过与现有知识源的模式匹配来查找这些数据。
使用场景:
语音识别
车辆识别和跟踪
蛋白质结构识别
声纳信号的解释
十. 解释器模式
这个模式用于设计一个解释用专用语言编写的程序的组件。它主要指定如何评估程序的行数,即以特定的语言编写的句子或表达式。其基本思想是为每种语言的符号都有一个分类。
使用场景:
数据库查询语言,比如SQL
用于描述通信协议的语言
体系架构模式的比较
下面给出的表格总结了每种体系架构模式的优缺点。
名称 | 优点 | 缺点 |
---|---|---|
分层模式 | 一个较低的层可以被不同的层所使用。层使标准化更容易,因为我们可以清楚地定义级别。可以在层内进行更改,而不会影响其他层。 | 不是普遍适用的。在某些情况下,某些层可能会被跳过。 |
客户端-服务器模式 | 很好地建立一组服务,用户可以请求他们的服务。 | 请求通常在服务器上的单独线程中处理。由于不同的客户端具有不同的表示,进程间通信会导致额外开销。 |
主从设备模式 | 准确性——将服务的执行委托给不同的从设备,具有不同的实现。 | 从设备是孤立的:没有共享的状态。主-从通信中的延迟可能是一个问题,例如在实时系统中。这种模式只能应用于可以分解的问题。 |
管道-过滤器模式 | 展示并发处理。当输入和输出由流组成时,过滤器在接收数据时开始计算。轻松添加过滤器,系统可以轻松扩展。过滤器可重复使用。可以通过重新组合一组给定的过滤器来构建不同的管道。 | 效率受到最慢的过滤过程的限制。从一个过滤器移动到另一个过滤器时的数据转换开销。 |
代理模式 | 允许动态更改、添加、删除和重新定位对象,这使开发人员的发布变得透明。 | 要求对服务描述进行标准化。 |
点对点模式 | 支持分散式计算。对任何给定节点的故障处理具有强大的健壮性。在资源和计算能力方面具有很高的可扩展性。 | 服务质量没有保证,因为节点是自愿合作的。安全是很难得到保证的。性能取决于节点的数量。 |
事件总线模式 | 新的发布者、订阅者和连接可以很容易地添加。对高度分布式的应用程序有效。 | 可伸缩性可能是一个问题,因为所有消息都是通过同一事件总线进行的。 |
模型-视图-控制器模式 | 可以轻松地拥有同一个模型的多个视图,这些视图可以在运行时连接和断开。 | 增加复杂性。可能导致许多不必要的用户操作更新。 |
黑板模式 | 很容易添加新的应用程序。扩展数据空间的结构很简单。 | 修改数据空间的结构非常困难,因为所有应用程序都受到了影响。可能需要同步和访问控制。 |
解释器模式 | 高度动态的行为是可行的。对终端用户编程性提供好处。提高灵活性,因为替换一个解释程序很容易。 | 由于解释语言通常比编译后的语言慢,因此性能可能是一个问题。 |
原文作者:Vijini Mallawaarachchi
原文地址:10 Common Software Architectural Patterns in a nutshell
- END -
作者:架构精进之路,专注软件架构研究,技术学习与个人成长,关注并私信我回复“01”,送你一份程序员成长进阶大礼包,欢迎勾搭。
往期热文推荐:
我也曾对架构师的力量一无所知
高级软件工程师必备的五大技能
聊聊集群、分布式和微服务之间的联系和异同点
白话讲解,拜占庭将军问题
「技术架构精进」专注架构研究,技术分享
Thanks for reading!
聊聊十种常见的软件架构模式相关推荐
- 10种常见的软件架构模式-快速记忆
10种常见的软件架构模式-快速记忆 这里通过数字宫殿的方法快速记忆10种常见的设计模式,通过记忆名字+理解的情况下熟悉常见的软件架构模式 文章目录 10种常见的软件架构模式-快速记忆 前言 一.快速记 ...
- 10种常见的软件架构模式
有没有想过要设计多大的企业规模系统?在主要的软件开发开始之前,我们必须选择一个合适的体系结构,它将为我们提供所需的功能和质量属性.因此,在将它们应用到我们的设计之前,我们应该了解不同的体系结构. 什么 ...
- 企业架构中常见的十种软件架构模式
想知道如何设计大型企业级的系统吗?在开始主要的代码开发之前,我们必须选择一种合适的体系架构,它将为我们提供所需的功能和质量属性.因此,在将它们应用到我们的设计之前,应该先了解不同的体系结构. - ...
- [ZT]网站十种常见盈利模式简介
网站十种常见盈利模式简介 网站是如何盈利的?有多少种好的盈利方式?如果我想运营一个网站怎样如何寻找盈利点?我适合做哪一种网站?相信这样的问题是众多网站运营者或对网站运营感兴趣的朋友所关注的,下面对一些 ...
- 10个常见软件架构模式和三层架构模式
10个常见软件架构模式: 1. 分层模式: 信息系统常见的4层划分:Presentation layer表示层(也就是UI层).Application layer应用层(也就是服务层).Busines ...
- 不可不知的软件架构模式
什么是系统架构(Architecture) 设计不仅仅指的是外观和感觉,它还包括运作方式.-- 史蒂夫·乔布斯 系统架构(System Architecture),软件架构(Soft Architec ...
- 精华:软件架构模式的7种武器
架构模式是对给定上下文的软件架构中常见问题的一种通用的可复用的解决方案.一种模式就是特定上下文的问题的一种解决方案. 然而,很多开发者至今还对各种软件架构模式之间的差别搞不清,甚至对其所知甚少. 大体 ...
- 程序员必知的7种软件架构模式
作者:Trung Anh Dang 策划:万佳 架构模式是对给定上下文的软件架构中常见问题的一种通用的可复用的解决方案. 一种模式就是特定上下文的问题的一种解决方案. 然而,很多开发者至今还对各种软件 ...
- 软件架构模式 mark Richards - 读后总结 1 - 分层架构
软件架构模式 Mark Richards 著 版权归 © 2015 O'Reilly Media, Inc. 所有. 原书发布链接为 Software Architecture Patterns [ ...
最新文章
- PM配置详解之二:工厂维护和客户服务中心的主数据
- 前嗅ForeSpider教程:网站登录配置
- pyecharts line_base绘图只有坐标轴,数据不再数轴上显示
- js模板引擎——art Template
- spring spring c3p0 mysql配置_Spring通过c3p0配置bean连接数据库
- hdu--1075--字典树||map
- mybatis学习(29):适用于没有自增的数据库
- 2019年春第四次课程设计实验报告
- Python第三方库使用——splinter
- 莫队(bzoj 2038: [2009国家集训队]小Z的袜子(hose))
- Android 12中系统Wallpaper详解1--锁屏透看壁纸和桌面透看壁纸的切换
- Linux系统CentOS7破解密码
- HTML竖着写古诗,诗词竖着写的格式(例: 题临安邸 )
- 系统进程网络流量监控软件
- 红罐王老吉品牌定位战略
- OpenGL ES 之uniform和varying
- 全息网御上榜《CCSIP 2022中国网络安全产业全景图》
- 用阿里云安装docker
- WQ7033开发指南(基础篇)之1.0 开发环境搭建和编译
- 丑小鸭到白天鹅的蜕变—棋牌游戏
热门文章
- Jquery UI Tabs 动态添加页签,并跳转到新页签
- springboot+mysql+微信小程序点餐系统-计算机毕业设计源码65933
- 日志管理(一)-日志级别
- Unity Asset Bundles Manifest文件
- 查壳、加壳、脱壳详细教程
- [Windows][Photoshop] 透视变开形工具灰色不可选择的原因
- 工作中遇到的问题之异常
- win2003dns服务器其它域名解析不,让dns服务器支持泛域名解析_windows 2003
- java+springmvc+vues 基于ssm的小微企业人事管理系统#毕业设计
- Cocos 知乎官方账号已开通!