微服务知识——4大主流微服务架构方案

文章目录

  • 1、微服务聚合模式
  • 2、微服务共享模式
  • 3、微服务代理模式
  • 4、微服务异步消息模式

微服务是大型架构的必经之路,也是大厂重点考察对象,下面我就重点详解4大主流微服务架构方案。

1、微服务聚合模式

微服务聚合设计模式,解决了如何从多个微服务中聚合数据,以便客户端可以获得所需的完整信息,而不需要多次请求不同的服务。

此类模式主要用于简化客户端的操作,减少与多个微服务交互的复杂性。

如下图所示:
在这里插入图片描述
通过构建一个聚合服务(又称聚合层或聚合微服务),将多个微服务的响应数据进行聚合,形成一个统一的结果返回给客户端。

聚合服务,通过调用多个微服务的 API,收集它们的响应并进行整合。

优点:

  • 简化客户端请求:客户端只需调用聚合服务,不需要直接与多个微服务交互。
  • 减少服务间依赖:聚合服务可以减轻微服务之间的耦合度,服务间可以独立变化。

缺点:

  • 聚合服务可能成为性能瓶颈,需特别关注聚合服务的可扩展性。
  • 如果聚合的服务很多,可能需要额外的处理来确保高效聚合。

2、微服务共享模式

微服务提倡的是:每个服务拥有自己的独立数据库(比如:数据库独立性原则),以确保服务之间的高内聚性、和低耦合性。

然而,在某些情况下,由于业务需求或技术限制,多个微服务可能需要共享数据。

如下图所示:
在这里插入图片描述
实际上在微服务架构的初期阶段,很多企业可能会采用 共享数据库 模式,来简化系统的开发和维护,尤其是在微服务迁移的过渡阶段。

这样做虽然简化了架构,但却违反了微服务的原则,因为它导致了微服务之间的紧密耦合。

因此,“共享数据库”模式通常被视为“过渡性”或“反模式”,不是长期推荐的设计。

3、微服务代理模式

微服务代理是一种中间层,用于处理服务之间的通信。

如下图所示:
在这里插入图片描述
在这种模式下,代理服务充当了其他微服务的代理,接收客户端的请求并将其转发给后端服务进行处理。

在 Sidecar 代理模式 中,Sidecar 是与每个微服务实例配对部署的。
每个微服务实例旁边都有一个独立的代理进程,这些代理共同组成一个统一的服务网格。

代理负责捕获并管理服务的入站和出站流量。代理通常会与服务网格的 控制平面 交互,获取流量路由、负载均衡、访问策略等配置。

优点:

  • 解耦:客户端和微服务之间的交互通过代理服务来处理。
  • 统一入口:所有请求都经过代理,易于管理、监控和控制。

缺点:

  • 代理服务需要额外的资源来处理请求,可能成为性能瓶颈。

4、微服务异步消息模式

异步消息设计模式,在微服务架构中非常重要,它允许微服务通过消息队列、事件流等方式进行松散耦合的通信。

如下图所示:
在这里插入图片描述
微服务通过发布事件来通知其他服务发生了某个状态变化。事件通常是业务变化或数据变化的通知,例如:订单创建、支付成功…等。

优点:

  • 服务解耦:服务之间不需要直接调用,只有事件通知机制。
  • 提高吞吐量:通过异步处理,减少了服务的同步依赖。

缺点:

  • 事件的顺序和一致性需要额外考虑,容易出现“事件丢失”或“消息重复消费”的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/66690.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【HTML+CSS】使用HTML与后端技术连接数据库

目录 一、概述 1.1 HTML前端 1.2 后端技术 1.3 数据库 二、HTML表单示例 三、PHP后端示例 3.1 连接数据库 3.2 接收数据并插入数据库 四、安全性 4.1 防止SQL注入 4.2 数据验证与清洗 五、优化 5.1 索引优化 5.2 查询优化 六、现代Web开发中的最佳实践 6.1 使用…

T-SQL语言的数据库编程

T-SQL语言的数据库编程 1. 引言 在信息化迅速发展的今天,数据库已经成为数据管理和使用的重要工具。其中,T-SQL(Transact-SQL)作为微软SQL Server的扩展SQL语言,不仅用于数据查询和管理,还能够进行复杂的…

通信协议—WebSocket

一、WebSocket编程概念 1.1 什么是WebSocket WebSocket 是一种全双工通信协议,允许在客户端(通常是浏览器)和服务器之间建立持久连接,以实现实时的双向通信。它是 HTML5 标准的一部分,相比传统的 HTTP 请求&#xff…

cadence笔记--画PMU6050原理图和封装

简介 本文主要介绍使用Cadence自己画一个PMU6050的原理图PCB的实际用例,Cadence使用的是24.1版本。 原理图 首先获取PMU6050引脚参数,使用立创商城查询PMU6050型号,点击数据手册如下图所示: 如下图所示,左边是原理图&…

CSS3 3D 转换介绍

CSS3 中的 3D 转换提供了一种在二维屏幕上呈现三维效果的方式,主要包括translate3d、rotate3d、scale3d等转换函数,下面来详细介绍: 1. 3D 转换的基本概念 坐标系 在 CSS3 的 3D 空间中,使用的是右手坐标系。X 轴是水平方向&…

Text2SQL 智能报表方案介绍

0 背景 Text2SQL智能报表方案旨在通过自然语言处理(NLP)技术,使用户能够以自然语言的形式提出问题,并自动生成相应的SQL查询,从而获取所需的数据报表,用户可根据得到结果展示分析从而为结论提供支撑&#…

FFmpeg音视频采集

文章目录 音视频采集音频采集获取设备信息录制麦克风录制声卡 视频采集摄像机画面采集 音视频采集 DirectShow(简称DShow)是一个Windows平台上的流媒体框架,提供了高质量的多媒体流采集和回放功能,它支持多种多样的媒体文件格式&…

【漫话机器学习系列】056.F1值(F1 score)

F1值(F1 Score) 定义 F1值是机器学习中一种用于评估模型性能的指标,特别适合用于 不平衡数据集 的分类任务。它是 精确率(Precision) 和 召回率(Recall) 的调和平均值。通过综合考虑精确率和召…

Mac安装Homebrew

目录 安装修改homeBrew源常用命令安装卸载软件升级软件相关清理相关 安装 官网 https://brew.sh/不推荐官网安装方式(很慢很慢或者安装失败联网失败) 检测是否安装homebrewbrew -v执行安装命令 苹果电脑 常规安装脚本 (推荐 完全体 几分钟就…

在K8S中,如果后端NFS存储的IP发送变化如何解决?

在Kubernetes中,如果后端NFS存储的IP地址发生了变化,您需要更新与之相关的Peristent Volume(PV)或Persistent Volume Claim(PVC)以及StorageClass中关于NFS服务器IP的配置信息,确保K8S集群内的Pod能够正确连接到新的NFS存储位置。解决方案如下…

一文大白话讲清楚webpack基本使用——9——预加载之prefetch和preload以及webpackChunkName的使用

文章目录 一文大白话讲清楚webpack基本使用——9——预加载之prefetch和preload1. 建议按文章顺序从头看,一看到底,豁然开朗2. preload和prefetch的区别2. prefetch的使用3. preload的使用4. webpackChunkName 一文大白话讲清楚webpack基本使用——9——…

【Elasticsearch 】 聚合分析:桶聚合

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…

tensorflow源码编译在C++环境使用

https://tensorflow.google.cn/install/source?hlzh-cn查看tensorflow和其他需要下载软件对应的版本,最好一模一样 1、下载TensorFlow源码 https://github.com/tensorflow/tensorflow 2、安装编译protobuf(3.9.2) protobuf版本要和TensorFlo…

P8738 [蓝桥杯 2020 国 C] 天干地支

两种方法 #include<bits/stdc.h> using namespace std;int main(){int year;cin>>year;string tg[10] {"geng", "xin", "ren", "gui","jia", "yi", "bing", "ding", "wu&…

Python 常用运维模块之OS模块篇

Python 常用运维模块之OS模块篇 OS 模块获取当前工作目录更改当前工作目录返回当前目录路径返回上一级目录路径递归生成目录路径删除目录创建目录删除目录列出特定目录下文件和子目录删除某个特定文件重命名某个文件获取某个文件/目录的信息输出目录路径分隔符输出文件行终止符…

uniapps使用HTML5的io模块拷贝文件目录

最近在集成sqlite到uniapp的过程中&#xff0c;因为要将sqlite数据库预加载&#xff0c;所以需要使用HTML5的plus.io模块。使用过程中遇到了许多问题&#xff0c;比如文件路径总是解析不到等。尤其是应用私有文档目录’_doc’。 根据官方文档&#xff1a; 为了安全管理应用的…

使用 F12 查看 Network 及数据格式

在浏览器中&#xff0c;F12 开发者工具的 “Network” 面板是用于查看网页在加载过程中发起的所有网络请求&#xff0c;包括 API 请求&#xff0c;以及查看这些请求的详细信息和响应数据的。以下以常见的 Chrome 浏览器为例&#xff0c;介绍如何使用 F12 控制台查看 Network 里…

Redis 2.6.12在Win10系统上的安装教程

诸神缄默不语-个人CSDN博文目录 这个版本的安装包是跟同事要的&#xff0c;em&#xff0c;如果真的需要这个版本的话可以跟我要&#xff1a; 解压后双击第一个bat文件&#xff0c;即可挂起Redis服务&#xff1a;

分布式数据库中间件(DDM)的使用场景

华为云分布式数据库中间件&#xff08;DDM&#xff09;是一款专注于解决数据库分布式扩展问题的中间件服务&#xff0c;突破了传统数据库的容量和性能瓶颈&#xff0c;能够实现海量数据的高并发访问。以下是九河云总结的DDM的典型使用场景&#xff1a; 1. 互联网应用 在电商、…

Ubuntu16.04 安装OpenCV4.5.4 避坑

Ubuntu16.04 安装C版OpenCV4.5.4 Ubuntu16.04 VSCode下cmakeclanglldb调试c 文章目录 Ubuntu16.04 安装C版OpenCV4.5.41. 下载Opencv压缩包2. 安装Opencv-4.5.43. 配置OpenCV的编译环境4.测试是否安装成功 1. 下载Opencv压缩包 下载Opencv压缩包&#xff0c;选择source版本。…