软件模式之单体架构介绍

简介: 您正在开发服务器端企业应用程序。它必须支持各种不同的客户端,包括桌面浏览器、移动浏览器和本地移动应用程序。该应用程序还可能公开一个 API 供第 3 方使用。它还可以通过 Web 服务或消息代理与其他应用程序集成。应用程序通过执行业务逻辑来处理请求(HTTP 请求和消息);访问数据库;与其他系统交换消息;并返回 HTML/JSON/XML 响应。有对应于应用程序不同功能区域的逻辑组件。

背景

您正在开发服务器端企业应用程序。它必须支持各种不同的客户端,包括桌面浏览器、移动浏览器和本地移动应用程序。该应用程序还可能公开一个 API 供第 3 方使用。它还可以通过 Web 服务或消息代理与其他应用程序集成。应用程序通过执行业务逻辑来处理请求(HTTP 请求和消息);访问数据库;与其他系统交换消息;并返回 HTML/JSON/XML 响应。有对应于应用程序不同功能区域的逻辑组件。

问题

应用程序的部署架构是什么?

限制

  • 有一个开发团队正在开发该应用程序
  • 新的团队成员必须迅速变得富有成效
  • 应用程序必须易于理解和修改
  • 您想练习应用程序的持续部署
  • 您必须在多台机器上运行应用程序的多个实例以满足可伸缩性和可用性要求
  • 您想利用新兴技术(框架、编程语言等)

解决方案

构建具有单体架构的应用程序。例如:

  • 一个 Java WAR 文件。
  • Rails 或 NodeJS 代码的单个目录层次结构

例子

假设您正在构建一个电子商务应用程序,该应用程序从客户那里接收订单,验证库存和可用性,然后发货。该应用程序由几个组件组成,包括实现用户界面的 StoreFrontUI,以及一些用于检查信用、维护库存和运输订单的后端服务。

该应用程序被部署为单个应用程序。例如,Java Web 应用程序由一个在 Web 容器(如 Tomcat)上运行的 WAR 文件组成。Rails 应用程序由单个目录层次结构组成,使用例如 Apache/Nginx 上的 Phusion Passenger 或 Tomcat 上的 JRuby 部署。您可以在负载均衡器后面运行应用程序的多个实例,以扩展和提高可用性。

结果上下文

这个解决方案有很多好处:

  • 易于开发 - 当前开发工具和 IDE 的目标是支持单片应用程序的开发
  • 易于部署 - 您只需在适当的运行时部署 WAR 文件(或目录层次结构)
  • 易于扩展 - 您可以通过在负载均衡器后面运行应用程序的多个副本来扩展应用程序

但是,一旦应用程序变大并且团队规模扩大,这种方法就会有许多缺点,这些缺点变得越来越明显:

  • 庞大的单体代码库吓倒了开发人员,尤其是团队新手。该应用程序可能难以理解和修改。因此,开发速度通常会放缓。此外,由于没有硬模块边界,模块化会随着时间的推移而分解。此外,由于很难理解如何正确实施更改,因此代码的质量会随着时间的推移而下降。这是一个向下的螺旋。
  • IDE 过载 - 代码库越大,IDE 越慢,开发人员的生产力就越低。
  • 重载的 Web 容器 - 应用程序越大,启动所需的时间就越长。这对开发人员的生产力产生了巨大的影响,因为等待容器启动的时间被浪费了。它也影响部署。
  • 持续部署很困难——大型单体应用程序也是频繁部署的障碍。为了更新一个组件,您必须重新部署整个应用程序。这将中断后台任务(例如 Java 应用程序中的 Quartz 作业),无论它们是否受到更改的影响,并可能导致问题。尚未更新的组件也有可能无法正确启动。因此,与重新部署相关的风险会增加,从而阻碍频繁更新。这对于用户界面开发人员来说又是一个问题,因为他们通常需要快速迭代并频繁重新部署。
  • 扩展应用程序可能很困难 - 单体架构是它只能在一个维度上扩展。一方面,它可以通过运行更多的应用程序副本随着交易量的增加而扩展。一些云甚至可以根据负载动态调整实例数量。但另一方面,这种架构无法随着数据量的增加而扩展。应用程序实例的每个副本都将访问所有数据,这会降低缓存效率并增加内存消耗和 I/O 流量。此外,不同的应用程序组件具有不同的资源需求——一个可能是 CPU 密集型的,而另一个可能是内存密集型的。使用单体架构,我们无法独立扩展每个组件
  • 扩展开发的障碍 - 单体应用程序也是扩展开发的障碍。一旦应用程序达到一定规模,就可以将工程组织划分为专注于特定功能领域的团队。例如,我们可能希望拥有 UI 团队、会计团队、库存团队等。单体应用程序的问题在于它阻止了团队独立工作。团队必须协调他们的开发工作和重新部署。团队做出改变和更新产品要困难得多。
  • 需要对技术堆栈做出长期承诺——单体架构迫使您与您在开发之初选择的技术堆栈(在某些情况下,与该技术的特定版本)结合。对于单体应用程序,可能难以逐步采用更新的技术。例如,假设您选择了 JVM。您可以选择一些语言,因为除了 Java 之外,您还可以使用与 Java 很好地互操作的其他 JVM 语言,例如 Groovy 和 Scala。但是用非 JVM 语言编写的组件在您的单体架构中没有一席之地。此外,如果您的应用程序使用的平台框架随后变得过时,那么将应用程序逐步迁移到更新和更好的框架可能具有挑战性。

相关模式

微服务架构(我们将在接下来的讲解会介绍微服务架构模式)是解决单体架构局限性的另一种模式。

已知案例

Netflix、Amazon.com 和 eBay 等知名互联网服务最初采用单体架构。作者开发的大多数 Web 应用程序都采用单体架构。

目前很少有企业使用单体模式

敬请期待下一遍:软件模式之微服务架构介绍

目录
相关文章
|
28天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
154 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
18天前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
130 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
2月前
|
运维 负载均衡 Shell
控制员工上网软件:高可用架构的构建方法
本文介绍了构建控制员工上网软件的高可用架构的方法,包括负载均衡、数据备份与恢复、故障检测与自动切换等关键机制,以确保企业网络管理系统的稳定运行。通过具体代码示例,展示了如何实现这些机制。
129 63
|
2月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
164 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
2月前
|
Dubbo Java 应用服务中间件
服务架构的演进:从单体到微服务的探索之旅
随着企业业务的不断拓展和复杂度的提升,对软件系统架构的要求也日益严苛。传统的架构模式在应对现代业务场景时逐渐暴露出诸多局限性,于是服务架构开启了持续演变之路。从单体架构的简易便捷,到分布式架构的模块化解耦,再到微服务架构的精细化管理,企业对技术的选择变得至关重要,尤其是 Spring Cloud 和 Dubbo 等微服务技术的对比和应用,直接影响着项目的成败。 本篇文章会从服务架构的演进开始分析,探索从单体项目到微服务项目的演变过程。然后也会对目前常见的微服务技术进行对比,找到目前市面上所常用的技术给大家进行讲解。
60 1
服务架构的演进:从单体到微服务的探索之旅
|
2月前
|
消息中间件 运维 Kubernetes
后端架构演进:从单体到微服务####
本文将探讨后端架构的演变过程,重点分析从传统的单体架构向现代微服务架构的转变。通过实际案例和理论解析,揭示这一转变背后的技术驱动力、挑战及最佳实践。文章还将讨论在采用微服务架构时需考虑的关键因素,包括服务划分、通信机制、数据管理以及部署策略,旨在为读者提供一个全面的架构转型视角。 ####
39 1
|
2月前
|
消息中间件 监控 安全
后端架构演进:从单体到微服务####
在数字化转型的浪潮中,企业应用的后端架构经历了从传统单体架构到现代微服务架构的深刻变革。本文探讨了这一演进过程的背景、驱动力、关键技术及面临的挑战,揭示了如何通过微服务化实现系统的高可用性、扩展性和敏捷开发,同时指出了转型过程中需克服的服务拆分、数据管理、通信机制等难题,为读者提供了一个全面理解后端架构演变路径的视角。 ####
55 8
|
2月前
|
Kubernetes 前端开发 分布式数据库
工作中常见的软件系统部署架构
在实际应用中,会根据项目的具体需求、规模、性能要求等因素选择合适的部署架构,或者综合使用多种架构模式来构建稳定、高效、可扩展的系统。
245 2
|
2月前
|
缓存 负载均衡 JavaScript
探索微服务架构下的API网关模式
【10月更文挑战第37天】在微服务架构的海洋中,API网关犹如一座灯塔,指引着服务的航向。它不仅是客户端请求的集散地,更是后端微服务的守门人。本文将深入探讨API网关的设计哲学、核心功能以及它在微服务生态中扮演的角色,同时通过实际代码示例,揭示如何实现一个高效、可靠的API网关。
|
2月前
|
缓存 监控 API
探索微服务架构中的API网关模式
随着微服务架构的兴起,API网关成为管理和服务间交互的关键组件。本文通过在线零售公司的案例,探讨了API网关在路由管理、认证授权、限流缓存、日志监控和协议转换等方面的优势,并详细介绍了使用Kong实现API网关的具体步骤。
53 3

热门文章

最新文章