简述软件架构模式

更多内容关注微信公众号:fullstack888

c42b0860cab8be5bf6b3ffd8060aa3e9.png

当你深入到软件工程领域时,总有一天需要学习软件架构模式的基础知识。我刚开始写代码时,并不知道在哪里可以找到一些资料来简要介绍现有的架构模式,这样就不会太过详细和混乱,而是非常抽象和易于理解。

这一直是个问题,直到我发现了Mark Richards的《软件架构模式》一书。在这里,我想与您分享这本书中最重要的部分和架构模式。(要了解更多信息,我强烈建议你阅读这本书或他的报告)。
作为软件工程师,为什么至少要学习基本的架构模式?

我相信有许多文章回答了这个问题,但我将给你一些参考答案。首先,如果您了解架构模式的基础知识,那么您就更容易遵循架构的需求。其次,了解这些模式将帮助您决定如何编码:例如,如果您的应用程序设计是基于事件驱动的微服务,作为一个软件工程师,你必须将代码解耦到单独的服务,应该注意现有服务逻辑的复杂性和职责。(如果你没有理解这部分,就跟随本文,下面将简要解释这些模式)。
Mark Richards在书中描述了5种模式:

  • 分层架构

  • 事件驱动架构

  • 微内核架构(或称为插件架构)

  • 微服务架构

  • 云架构模式


1.分层架构

它是单体应用程序最常见的架构。该模式背后的基本思想是将应用程序逻辑划分为几个层,每层封装特定的角色。例如,持久化层将负责应用程序与数据库的通信。

f64b8c31cae58dcd3cce8c1f06ba4ae0.png

分层架构


2. 事件驱动架构

此模式背后的思想是将应用程序逻辑解耦为异步接收和处理事件的单一目的事件处理组件。该模式是一种流行的分布式异步架构模式,以高可伸缩性和适应性而闻名。

eae0727905c6281d342f36756b29ba87.png

事件驱动架构


3、微内核架构

微内核架构,也被称为插件架构,是一种设计模式,它有两个主要组件:核心系统和插件模块(或扩展)。一个很好的例子就是Web浏览器(核心系统),您可以在其中安装无限的扩展(或插件)。

faed34b2a3c435cd71e705ba913971a2.png

微内核架构


4. 微服务架构

微服务架构由独立部署的服务组成,其中每个服务在理想情况下都具有单一的职责。这些服务是相互独立的,如果一个服务失败,其他服务也不会停止运行。

8148e114c746a4d8d5f890f9a753b4c0.png

微服务架构


5. 基于空间架构(云架构)

基于空间架构背后的主要思想是分布式共享内存,以减轻经常在数据库级别发生的问题。假设通过使用内存数据库处理大多数的数据操作,我们可以避免额外的操作,因此解决任何未来可能发生的问题。

基本方法是将应用程序划分为处理单元(也可以根据需求自动向上和向下扩展),数据将被复制到对应处理单元中进行处理,这些处理单元之间没有任何持久化的集中数据库(尽管因为系统故障会有本地存储系统)。

712f4ad320a9f81022d1ea559cda4bea.png

基于空间架构

- END -

往期回顾

微服务下蓝绿部署、红黑部署、AB测试、灰度发布、金丝雀发布、滚动发布的概念与区别

非常详细的HTTPS分享

作为技术负责人,如何从0搭建公司后端技术栈

Apache Log4j2高危漏洞解决方案(新)

vivo AI 计算平台 kubernetes 集群弹性伸缩实践

MySQL 主键的重要度

◆如何画出一张优秀的架构图(老鸟必备)

e8dc0aab6baa12941d1f51532d37ce56.png

技术交流,请加微信: jiagou6688 ,备注:Java,拉你进架构群

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值