【SpringCloud】微服务架构设计模式
一、聚合气微服务设计模式
最常见、最简单的设计模式,效果如图所示:

聚合器调用多个服务实现应用程序所需的功能
它可以是一个简单的 Web 页面,将检索到的数据进行处理并展示,也可以是一个更高层次的组合微服务,对检索到的数据增加业务逻辑后进一步发布成一个新的微服务,这符合 DRY 原则
另外,每个服务都有自己的缓存和数据库系统
如果聚合器是一个组合服务,那么它也有自己的缓存和数据库
二、代理微服务设计模式
这是聚合模式的一个变种,如图所示:

在这种情况下,客户端并不聚合数据,但会根据业务需求的差别调用不同的微服务
代理仅仅可以委派请求,也可以进行数据转换工作
每个微服务都有自己独立地缓存和数据库系统,彼此独立
三、链式微服务设计模式
这种模式在接收到请求后会产生一个经过合并的响应,如图所示:

Load Balancer 到 Service A 的线只有单向,如图一,此处为绘画错误
在这种情况下,服务 A 接收到请求后会与服务 B 进行通信,类似地,服务 B 会同服务 C 进行通信
所有服务都使用同步消息传递
在整个链式调用完成之前,客户端会一直阻塞
因此,服务调用链不宜过长,以免客户端长时间等待
四、分支微服务设计模式
这种模式是聚合器模式的扩展,允许同时调用两个微服务链,如图所示:

Load Balancer 到 Service A 的线只有单向,如图一,此处为绘画错误
每个调用链分别调用自己的服务
当某个调用出现问题时,互相之间不是造成影响
五、数据共享微服务设计模式
自治是微服务的设计模式之一,也就是说微服务是全栈式服务
但在重构现有的 “单体应用(monolithic application)” 时,SQL 数据库反规范化可能会导致数据重复和不一致
因此,在单体应用到微服务架构的过渡阶段,可以使用这种设计模式。如图所示:

Load Balancer 到 Service A 的线只有单向,如图一,此处为绘画错误
在这种情况下,部分微服务可能会共享缓存和数据库存储
不过,这只有在两个服务之间存在强耦合关系才可以
对于基于微服务的新建应用程序而言,这是一种反模式
六、异步消息传递微服务设计模式
虽然 RESTful 设计模式非常流行,但它是同步的,会造成阻塞
因此部分基于微服务的架构可能会选择使用消息队列代替 RESTful 请求 / 响应,如图所示:

各个服务之间通过异步的消息队列进行交互,当服务出现问题时,不会造成阻塞,队列会帮忙缓存消息,直到消息服务开始工作
参考资料:《微服务架构实战》—— 张锋
一 叶 知 秋,奥 妙 玄 心
相关文章:
【SpringCloud】微服务架构设计模式
一、聚合气微服务设计模式 最常见、最简单的设计模式,效果如图所示: 聚合器调用多个服务实现应用程序所需的功能 它可以是一个简单的 Web 页面,将检索到的数据进行处理并展示,也可以是一个更高层次的组合微服务,对…...
【EI会议征稿】第三届航空航天工程与系统国际研讨会(ISAES 2024)
第三届航空航天工程与系统国际研讨会(ISAES 2024) 2024 3rd International Symposium on Aerospace Engineering and Systems 第三届航空航天工程与系统国际研讨会将于2024年3月22-24日在南京召开!会议紧密聚焦“航空航天工程”领域的热点和难点问题,…...
唯创知音WT588F02A-16S录音语音芯片在宠物喂食器中的应用:小芯片,大功能
在现代社会中,宠物已经成为人们生活中的一部分,而宠物喂食器作为宠物养护的重要工具,也越来越受到人们的关注。为了满足人们对宠物喂食器的多样化需求,唯创知音的WT588F02A-16S录音芯片在其中发挥着重要作用。 唯创知音的WT588F0…...
SELinux零知识学习三十七、SELinux策略语言之约束(1)
接前一篇文章:SELinux零知识学习三十六、SELinux策略语言之角色和用户(7) 四、SELinux策略语言之约束 SELinux对策略允许的访问提供了更严格的约束机制,不管策略的allow规则如何。 1. 近距离查看访问决定算法 为了理解约束的用途,先来看一下SELinux Linux安全模块(Lin…...
sqli-labs靶场详解(less25/25a-less28/28a)
在SQL注入过程中难点就是判断注入点 只要注入点确定了 获取数据库数据的过程就是复制 从这关开始 只进行判断注入点了和代码逻辑分析了 因为注入操作太简单了(不演示了) 目录 less-25 less-25a less-26 less-26a less-27 less-27a less-28 less-…...
如何优化 Elasticsearch 查询性能
优化 Elasticsearch 查询性能需要从多个方面入手。通过合理的索引设计、优化查询语句、优化硬件资源和集群架构等方面的优化,可以显著提高 Elasticsearch 的查询性能。 1.索引设计优化 良好的索引设计是优化 Elasticsearch 查询性能的关键。可以通过以下几个方面来…...
成功的蓝图:实现长期成长与卓越表现的 6 项策略
能在收入和利润上持续领先同行的公司寥寥无几,不到四分之一。McKinsey的最新研究揭示了这些增长标杆公司与众不同的六大心态和策略。过度谨慎的公司,尤其在动荡时期,也许能捱过当下,但往往无法发掘全部潜力。考虑到近五年历经前所…...
【JavaEE初阶】认识线程、创建线程
1. 认识线程(Thread) 1.1 概念 1) 线程是什么 一个线程就是一个 "执行流". 每个线程之间都可以按照顺序执行自己的代码. 多个线程之间 "同时" 执行着多份代码. 举例: 还是回到我们之前的银⾏的例⼦中。之前我们主要描…...
uniapp中uni.navigateBack返回后刷新页面数据
文章目录 一、前言1.1、[uni.navigateBack](https://uniapp.dcloud.net.cn/api/router.html#navigateback) 二、方法2.1、父页面设置钩子函数onBackPress2.2、uni.$emit和uni.$on监听通知数据变更2.2.1、子页面2.2.2、父页面 2.3、onShow钩子函数处理数据2.3.1、子页面2.3.2、父…...
sed文本 免交互
目录 什么是sed 概念 格式 基本用法 命令的选项 打印第三行 打印日志文件 打印奇数行 打印偶数行 第三行退出 删除第三行 sed在不打开文件的情况下修改文件内容 在后面添加 选项a 在字符中间添加 \n 实现追加换行 全部追加 在前面插入 选项i 替换 选项c …...
轻巧高效的剃须好工具,DOCO黑刃电动剃须刀上手
剃须刀大家都用过,我比较喜欢电动剃须刀,尤其是多刀头的悬浮剃须刀,感觉用起来很方便,剃须效率也很高。最近我在用一款DOCO小蔻的黑刃电动剃须刀,这款剃须刀轻巧易用,而且性价比超高。 相比于同类产品&…...
第15关 K8s HPA:自动水平伸缩Pod,实现弹性扩展和资源优化
------> 课程视频同步分享在今日头条和B站 大家好,我是博哥爱运维,这节课带来k8s的HPA 自动水平伸缩pod( 视频后面有彩蛋 : ) )。 我们知道,初始Pod的数量是可以设置的,同时业务也分流量高峰和低峰&a…...
接口测试工具(Jmeter)必学技巧
安装 使用JMeter的前提需要安装JDK,需要JDK1.7以上版本 目前在用的是JMeter5.2版本,大家可自行下载解压使用 运行 进入解压路径如E: \apache-jmeter-5.2\bin,双击jmeter.bat启动运行 启动后默认为英文版本,可通过Options – Choos…...
C++面试,说明const和#define的特点和区别
#define只是用来做文本替换的,例如: #define PI 3.1415926 float angel; angel 30 * PI /180; 当程序进行编译的时候。编译器会首先将"#define PI 3.1415926"以后所有代码中的PI都替换成3.1415926,然后进行编译。它的生命周期止…...
aikit 2023 3D与机械臂结合!
引言 今天我们主要了解3D摄像头是如何跟机械臂应用相结合的。我们最近准备推出一款新的机械臂套装AI Kit 2023 3D,熟悉我们的老用户应该知道,我们之前的AI Kit 2023套装使用的是2D摄像头。 随着技术进步,市场需求和领域的扩大,2D的…...
模拟退火算法应用——求解TSP问题
仅作自己学习使用 一、问题 旅行商问题(TSP) 是要求从一个城市出发,依次访问研究区所有的城市,并且只访问一次不能走回头路,最后回到起点,求一个使得总的周游路径最短的城市访问顺序。 采用模拟退火算法求解TSP问题&#x…...
【LeetCode】每日一题 2023_11_28 设计前中后队列(数组/链表/双端队列)
文章目录 刷题前唠嗑题目:设计前中后队列题目描述代码与解题思路偷看大佬题解 结语 刷题前唠嗑 LeetCode?启动!!! 这道题的难度,才是我想象中的中等题的难度好吧,昨天那玩意对我来说还是太难了…...
python基于YOLOv8全系列模型【n/s/m/l/x】开发构建不同参数量级的钢铁产业产品智能自动化检测识别系统
在前文的项目开发实践中,我们已经以钢铁产业产品缺陷检测数据场景为基准,陆续开发构建了多款目标检测模型,感兴趣的话可以自行阅读即可。 《YOLOv3老矣尚能战否?基于YOLOv3开发构建建钢铁产业产品智能自动化检测识别系统…...
力扣142. 环形链表 II
文章目录 力扣142. 环形链表 II示例代码实现总结收获 力扣142. 环形链表 II 给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,…...
【设计模式-2.2】创建型——简单工厂和工厂模式
说明:本文介绍设计模式中,创建型设计模式中的工厂模式; 飞机大战 创建型设计模式,关注于对象的创建,本文介绍的简单工厂和工厂模式同样也是。举一个游戏例子,如飞机大战游戏中,屏幕中敌人类型…...
3分钟搞定:为Windows 11 24H2 LTSC系统一键恢复微软商店的终极方案
3分钟搞定:为Windows 11 24H2 LTSC系统一键恢复微软商店的终极方案 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 你是否选择了Windows 1…...
Android应用语言独立设置:打破系统语言束缚的终极解决方案
Android应用语言独立设置:打破系统语言束缚的终极解决方案 【免费下载链接】Language-Selector Language Selector let users select individual app languages (Android 13) 项目地址: https://gitcode.com/gh_mirrors/la/Language-Selector 你是否曾在多语…...
QuickBMS终极指南:三步掌握游戏文件提取与修改的免费神器
QuickBMS终极指南:三步掌握游戏文件提取与修改的免费神器 【免费下载链接】QuickBMS QuickBMS by aluigi - Github Mirror 项目地址: https://gitcode.com/gh_mirrors/qui/QuickBMS QuickBMS是一款革命性的通用文件提取工具,专为游戏资源提取、逆…...
电脑越用越卡?用Mem Reduct轻松释放Windows内存的完整指南
电脑越用越卡?用Mem Reduct轻松释放Windows内存的完整指南 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...
COSEM/DLMS协议栈解析:从对象模型到APDU的通信之旅
1. 从电表读数看COSEM/DLMS协议栈 想象一下这样的场景:你拿着手机APP查看家里电表的实时用电量,这个看似简单的操作背后,其实隐藏着一套精密的通信协议体系。这就是我们今天要拆解的COSEM/DLMS协议栈,它就像电能计量领域的"普…...
如何用10分钟语音打造专业AI变声器:RVC语音转换终极指南
如何用10分钟语音打造专业AI变声器:RVC语音转换终极指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-Conve…...
EldenRingSaveCopier终极教程:轻松实现艾尔登法环存档安全迁移
EldenRingSaveCopier终极教程:轻松实现艾尔登法环存档安全迁移 【免费下载链接】EldenRingSaveCopier 项目地址: https://gitcode.com/gh_mirrors/el/EldenRingSaveCopier 还在为《艾尔登法环》存档丢失而烦恼吗?这款开源工具EldenRingSaveCopie…...
verilog中的、、有什么区别和联系?
在 Verilog 中,&、&& 和 &&& 都是逻辑运算符,但它们在操作的对象和行为上有显著的不同。 1. & (按位与运算符,bitwise AND) 用途:& 是按位与运算符,用于对两个操作数的每一位执行 AND 运算。 操作对象:它对每个操作数的 每一位 执行逻…...
零基础玩转Ostrakon-VL-8B:手把手教你搭建零售场景多模态助手
零基础玩转Ostrakon-VL-8B:手把手教你搭建零售场景多模态助手 1. 认识零售场景的AI专家:Ostrakon-VL-8B 1.1 什么是Ostrakon-VL-8B? Ostrakon-VL-8B是一款专为零售和食品服务行业设计的开源多模态大模型。想象一下,当你走进一家…...
Cursor 3 Agents Window 实操:IDE 退居二线,Agent 编排成了主角
Cursor 3 Agents Window 实操:IDE 退居二线,Agent 编排成了主角 4月2日,Cursor 发布了 3.0 版本(代号 Glass)。这次更新的核心变化只有一句话:编辑器不再是默认界面,Agents Window 是。 不是加了…...
