前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简述软件架构模式

简述软件架构模式

作者头像
肉眼品世界
发布2021-12-22 09:26:50
4240
发布2021-12-22 09:26:50
举报
文章被收录于专栏:肉眼品世界肉眼品世界

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

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

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

  • 分层架构
  • 事件驱动架构
  • 微内核架构(或称为插件架构)
  • 微服务架构
  • 云架构模式
1.分层架构

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

分层架构

2. 事件驱动架构

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

事件驱动架构

3、微内核架构

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

微内核架构

4. 微服务架构

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

微服务架构

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

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 肉眼品世界 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.分层架构
  • 2. 事件驱动架构
  • 3、微内核架构
  • 4. 微服务架构
  • 5. 基于空间架构(云架构)
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档