SpringCloud篇 微服务架构

devtools/2025/2/2 23:21:05/

1. 工程架构介绍

1.1 两种工程架构模型的特征

1.1.1 单体架构

上面这张图展示了单体架构(Monolithic Architecture)的基本组成和工作原理单体架构是一种传统的软件架构模式,其中所有的功能都被打包在一个单一的、紧密耦合的应用程序中

下面对图中各部分的详细解释:

  1. Application(应用程序)

    • 这是整个系统的中心,包含了所有的业务逻辑和用户界面。

    • 用户通过应用程序与系统进行交互,应用程序则负责处理用户请求并返回相应的结果。

  2. Admin、User、Goods等模块

    • 这些模块代表了应用程序中的不同功能部分。

    • Admin(管理模块):可能包含用户管理、权限管理、系统设置等功能。

    • User(用户模块):处理用户相关的操作,如注册、登录、个人信息管理等。

    • Goods(商品模块):管理商品信息,包括添加、修改、删除商品等。

    • 这些模块虽然在同一个应用程序中,但它们之间可能存在一定的耦合,因为它们共享相同的数据库和缓存资源。

  3. DB(数据库)

    • 数据库是单体架构中的核心数据存储组件。

    • 所有的模块都直接或间接地与数据库交互,以存储和检索数据。

    • 数据库的设计通常需要考虑所有模块的需求,这可能导致数据库结构复杂且难以维护。

  4. Cache(缓存)

    • 缓存用于提高系统的响应速度和性能。

    • 它存储了频繁访问的数据,以减少对数据库的直接访问,从而减轻数据库的负担。

    • 在单体架构中,缓存通常由应用程序统一管理,所有模块都可以访问缓存中的数据。

  5. 单体架构的特点

    • 简单性:开发和部署相对简单,因为所有功能都在一个应用程序中。

    • 部署困难:随着应用程序规模的增长,部署和维护变得越来越困难,因为任何小的更改都可能需要重新部署整个应用程序。

    • 扩展性差:由于所有功能都紧密耦合在一起,扩展特定功能可能需要扩展整个应用程序。

    • 技术限制:整个应用程序通常使用相同的技术栈,这可能限制了使用不同技术优化特定功能的能力。

简单来说就是所有功能模块都集成在一个应用程序中共享数据库和缓存资源。这种架构小型或简单的应用程序中可能非常有效,但在大型或复杂的系统中,它可能导致维护和扩展的方面有很大的挑战。


1.1.2 微服务架构

上面这张图展示了微服务架构(Microservices Architecture)的基本组成和工作原理微服务架构是一种将应用程序分解为一组小服务的架构风格每个服务实现特定的业务功能并可以独立部署和扩展。

下面对图中各部分的详细解释:

  1. Gateway(网关)

    • 网关是用户访问系统的入口点。

    • 它负责接收用户请求,并将请求路由到相应的服务。

    • 网关还可以提供额外的功能,如认证、授权、请求日志记录等。

  2. Admin Service(管理服务)

    • 这是一个独立的微服务,负责管理相关的功能,如用户管理、权限管理等。

    • 它可以独立部署和扩展,以满足管理功能的需求。

  3. User Service(用户服务)

    • 这是另一个独立的微服务,负责处理与用户相关的功能,如用户注册、登录、个人信息管理等。

    • 它也可以独立部署和扩展,以满足用户功能的需求。

  4. Goods Service(商品服务)

    • 这是负责商品管理的微服务,包括商品的添加、修改、删除等操作。

    • 它可以独立部署和扩展,以满足商品管理的需求。

  5. ...... Service(其他服务)

    • 这表示系统中可能还有更多的微服务,每个服务负责不同的业务功能。

    • 每个服务都是独立的,可以独立部署和扩展。

  6. 微服务架构的特点

    • 独立性:每个服务都是独立的,可以独立开发、部署和扩展。

    • 灵活性:可以使用不同的技术栈来实现不同的服务,以满足特定的需求。

    • 可维护性:由于服务是独立的,修改一个服务不会影响其他服务,从而提高了系统的可维护性。

    • 可扩展性:可以根据需要独立扩展特定的服务,以满足业务需求。

简单来说就是一个网关接收用户请求,并将其分发到不同的服务。每个服务独立运行,负责不同的任务,比如管理、用户或商品。这种设计让系统更灵活、容易维护,但也需要处理服务间的通信和数据同步问题


2. 微服务架构组成与优点

2.1 使用微服务架构需要什么

微服务架构基础组件:

  1. 注册中心负责管理微服务的注册和发现。服务启动时会在注册中心注册自己的信息,其他服务可以通过注册中心查找并调用这些服务。

  2. 服务网关:作为系统的入口点,接收外部请求并路由到相应的微服务。它还可以处理认证、授权、限流等跨服务的公共功能。

  3. 微服务通信:指微服务之间的消息传递和数据交换。服务之间通过API调用、消息队列等方式进行通信。

  4. 链路追踪:用于监控和诊断微服务之间的请求路径和性能问题。它可以帮助追踪请求在服务间的流动,识别延迟和故障点。


2.2 使用微服务架构的优点

  1. 降低代码耦合:代码之间更独立,修改容易。

  2. 降低维护成本:系统更易维护,成本减少。

  3. 灵活扩容:根据需要轻松增加服务能力。

  4. 技术栈不受限:可以使用多种技术,更灵活。


 3. 使用微服务架构的原因

  1. 业务扩张快

    • 未来几年,业务会快速发展。

    • 微服务架构可以灵活应对快速变化的业务需求。

  2. 降低耦合

    • 业务复杂,可以拆分成多个独立服务。

    • 这样每个服务只负责一部分功能,减少相互依赖。

  3. 提高可靠性

    • 服务之间相互独立,一个服务出问题不会影响其他服务。

    • 这样整个系统的稳定性和可靠性更高。


http://www.ppmy.cn/devtools/155565.html

相关文章

受击反馈HitReact、死亡效果Death Dissolve、Floating伤害值Text(末尾附 客户端RPC )

受击反馈HitReact 设置角色受击标签 (GameplayTag基本了解待补充) 角色监听标签并设置移动速度 创建一个受击技能,并应用GE 实现设置角色的受击蒙太奇动画 实现角色受击时播放蒙太奇动画,为了保证通用性,将其设置为一个函数,并…

SepLLM:大型语言模型中高效稀疏注意力的一种实用AI方法

大型语言模型(Large Language Models,简称LLMs)在自然语言处理领域展现出了其无与伦比的才华,无论是文本生成还是语境推理,都游刃有余。然而,其自注意力机制的二次复杂性却如同一道枷锁,限制了其…

五分钟搭建本地deepseek r1基于Ollama工具的LLM大语言模型蒸馏模型

deepseek-r1:1.5b 下载安装后执行,命令:ollama run deepseek-r1:1.5b 运行cmd

Autogen_core源码:_cancellation_token.py

目录 _cancellation_token.py代码代码解释类的初始化取消操作检查取消状态添加回调函数关联异步Future对象总结 代码示例示例 1:基本的取消操作示例 2:添加回调函数示例 3:检查令牌是否已取消 _cancellation_token.py代码 import threading …

基于 NodeJs 一个后端接口的创建过程及其规范 -- 【elpis全栈项目】

基于 NodeJs 一个后端接口的创建过程及其规范 一个接口的诞生: #mermaid-svg-46HXZKI3fdnO0rKV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-46HXZKI3fdnO0rKV .error-icon{fill:#552222;}#mermaid-sv…

22.Word:小张-经费联审核结算单❗【16】

目录 NO1.2 NO3.4​ NO5.6.7 NO8邮件合并 MS搜狗输入法 NO1.2 用ms打开文件,而不是wps❗不然后面都没分布局→页面设置→页面大小→页面方向→上下左右:页边距→页码范围:多页:拼页光标处于→布局→分隔符:分节符…

【RAG】SKLearnVectorStore 避免使用gpt4all会connection err

gpt4all 列表中包含了多个开源的大模型,如 Qwen2.5、Llama 3、DeepSeek、Mistral 等,但 不包含 OpenAI 的 GPT-4o。GPT-4o 是 OpenAI 提供的闭源模型,目前只能通过 OpenAI API 或 ChatGPT 官方应用(网页版、移动端)访问,并不支持本地运行,也没有 GGUF 量化格式的模型文件…

wx043基于springboot+vue+uniapp的智慧物流小程序

开发语言:Java框架:springbootuniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包&#…