当前位置: 首页 > news >正文

【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开发构建建钢铁产业产品智能自动化检测识别系统&#xf…...

力扣142. 环形链表 II

文章目录 力扣142. 环形链表 II示例代码实现总结收获 力扣142. 环形链表 II 给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达&#xff0c…...

【设计模式-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变声器&#xff1a;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终极教程&#xff1a;轻松实现艾尔登法环存档安全迁移 【免费下载链接】EldenRingSaveCopier 项目地址: https://gitcode.com/gh_mirrors/el/EldenRingSaveCopier 还在为《艾尔登法环》存档丢失而烦恼吗&#xff1f;这款开源工具EldenRingSaveCopie…...

verilog中的、、有什么区别和联系?

在 Verilog 中,&、&& 和 &&& 都是逻辑运算符,但它们在操作的对象和行为上有显著的不同。 1. & (按位与运算符,bitwise AND) 用途:& 是按位与运算符,用于对两个操作数的每一位执行 AND 运算。 操作对象:它对每个操作数的 每一位 执行逻…...

零基础玩转Ostrakon-VL-8B:手把手教你搭建零售场景多模态助手

零基础玩转Ostrakon-VL-8B&#xff1a;手把手教你搭建零售场景多模态助手 1. 认识零售场景的AI专家&#xff1a;Ostrakon-VL-8B 1.1 什么是Ostrakon-VL-8B&#xff1f; Ostrakon-VL-8B是一款专为零售和食品服务行业设计的开源多模态大模型。想象一下&#xff0c;当你走进一家…...

Cursor 3 Agents Window 实操:IDE 退居二线,Agent 编排成了主角

Cursor 3 Agents Window 实操&#xff1a;IDE 退居二线&#xff0c;Agent 编排成了主角 4月2日&#xff0c;Cursor 发布了 3.0 版本&#xff08;代号 Glass&#xff09;。这次更新的核心变化只有一句话&#xff1a;编辑器不再是默认界面&#xff0c;Agents Window 是。 不是加了…...