Java面试之消息中间件

消息队列

    • 优缺点
      • 特点
        • 解耦
        • 异步
        • 削峰
      • 缺点
        • 系统可用性降低
          • 兜底:代码中try、catch 异常捕捉后直接进行数据库操作,或者 搭建高可用集群,Kafka集群、RocketMQ集群
        • 提高复杂度
          • 消息重复(消费端的幂等性设计)、消息丢失(主要集中RabbitMQ)、消息的顺序(业务:1,下单 2,支付 3,发送物流 4,通知)
        • 一致性问题
          • a,b,c三个系统,a、b两个写入数据库成功了,c系统写库失败?使用分布式事务来控制。RocketMQ提供了,其他的seta方式
      • 特点
        • 解耦
        • 异步
        • 削峰
      • 缺点
        • 系统可用性降低
          • 兜底:代码中try、catch 异常捕捉后直接进行数据库操作,或者 搭建高可用集群,Kafka集群、RocketMQ集群
        • 提高复杂度
          • 消息重复(消费端的幂等性设计)、消息丢失(主要集中RabbitMQ)、消息的顺序(业务:1,下单 2,支付 3,发送物流 4,通知)
        • 一致性问题
          • a,b,c三个系统,a、b两个写入数据库成功了,c系统写库失败?使用分布式事务来控制。RocketMQ提供了,其他的seta方式
    • RabbitMQ、Kafka、RocketMQ 对比
      • 性能角度
        • RabbitMQ 1.2w
        • Kafka 100w
        • Rocket MQ 10w
      • 集群扩展支持
        • Rabbit MQ集群很弱(确保高可用 不能扩展性能)
        • Kafka 天生分布式,支持动态扩展
        • Rocket MQ 天生分布式,支持动态扩展
      • 功能
        • Rabbit MQ比较丰富(死信消息、延迟消息)
        • Kafka比较弱
        • Rocket MQ比较丰富(死信、延迟、消息回溯、消息过滤)
    • 常见问题及解决方案
      • 重复消费
        • 死信消息
        • MVCC(多版本控制)
          • 对整体业务改动较大,使用很不便利,代价较高
        • 去重表(MySQL、Redis)
          • 表上构建唯一性索引
          • try{处理业务:插入数据/判断是否存在}catch(exception e){return

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

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

相关文章

STM32/GD32——电源管理单元PWU

芯片选型 Ciga Device — GD32F470系列 PWU介绍 PMU全称Power Management Unit,电源管理单元。 电源域 总共有三大电源域,包括VDD / VDDA域,1.2V域和备份域。 VDD/VDDA 域 提供PMU 常规电源供应以下模块的供电: 看门狗主频晶…

Spring笔记——Bean的生命周期

Spring其实就是一个管理Bean对象的工厂,它负责对象的创建,对象的销毁等。生命周期的本质是:在哪个时间节点上调用了哪个类的哪个方法。我们可能需要在某个特殊的时间点上执行一段特定的代码,因此要了解在这个生命线上有哪些特殊时…

YoloV8改进策略:Block改进|自研Block,涨点超猛|代码详解|附结构图

涨点效果 涨点效果:在我自己的数据集上,mAP50 由0.986涨到了0.993,mAP50-95由0.737涨到0.757,涨点明显! 参考模型 参考的Block,如下图: 我对Block做了修改,修改后的结构图如下: 代码详解 from timm.models.layers import DropPathfrom torch import Tensor def …

C++设计模式-工厂模式(简单工厂模式、工厂方法模式、抽象工厂模式)

本文讲解C++设计模式-工厂方法模式 目录 概述 简单工厂模式 工厂方法模式 抽象工厂模式 概述 工厂模式属于创建型模式,大致可以分为三类&#x

代码随想录算法训练营第34天—动态规划02 | ● 62.不同路径 ● *63. 不同路径 II

62.不同路径 https://programmercarl.com/0062.%E4%B8%8D%E5%90%8C%E8%B7%AF%E5%BE%84.html 视频讲解:https://www.bilibili.com/video/BV1ve4y1x7Eu 考点 二维动规 我的思路 当前位置的路线总数为左位置和上位置的路线数之和 视频讲解关键点总结 我的思路没问题&…

如何学习ChatGPT?从入门到精通(附资料下载)

2023 ChatGPT从入门到精通视频教程(共30课).zip 学习ChatGPT需要涉及多个层面,包括理解其基本原理、掌握相关技术、以及进行实际的项目应用。以下是一些具体的学习步骤和建议: 理解ChatGPT的基本原理: 深入了解ChatGP…

AI数字虚拟人来了你会失业吗?

AI数字虚拟人是一种由人工智能技术驱动的虚拟实体,以及通过语音和图像等界面与人进行交互。它可以模拟人的外貌、声音和行为,并能回答问题、提供信息和执行特定任务。AI数字虚拟人已经开始在各个领域得到广泛应用,例如客户服务、教育、医疗保…

MySQL的连接池原理和架构雏形

实际上没什么好说的,这里只是简单总结一下连接池原理,顺便梳理下一个用户注册和登录的过程,进一步带您理解一些业务逻辑。 预先设置好连接池内的正在等待的执行单元(进程/线程),每个执行单元保持和 MySQL …

Java二级--操作题详解(1)

目录 1.第一套: 1.1 基本操作: 1.2 题解分析: 2.1 简单应用: 2.2 解题分析: 3.1 综合应用: 3.2解题分析: 1.第一套: 1.1 基本操作: 在考生文件夹中存有文件名为J…

Facebook商城号防封养号技巧,速看

由于Facebook商城的高利润空间,越来越多的跨境电商商家注意到它的存在。Facebook作为全球最大、用户量最大的社媒平台,同时也孕育了一个巨大的商业生态,包括广告投放、商城交易等。依托背后的大流量,Facebook商城起号较快&#xf…

【李沐精读系列】GPT、GPT-2和GPT-3论文精读

论文: GPT:Improving Language Understanding by Generative Pre-Training GTP-2:Language Models are Unsupervised Multitask Learners GPT-3:Language Models are Few-Shot Learners 参考:GPT、GPT-2、GPT-3论文精读…

MaterialApp

MaterialApp 是 flutter 中提供入口的一个类,是符合Material Design设计理念的入口Widget,使用 theme 属性来为整个 MaterialApp 设置主题。可以在这里设置路由,后续用到再详细学习。debugShowCheckedModeBanner属性经常提到,设置他为True后,…

Linux权限系统深度解析

Linux操作系统的权限管理对于维护系统安全和稳定性至关重要。本文将通过详细的语法说明和实际案例,深入探讨Linux权限系统的工作原理及其应用。 权限基础 Linux文件和目录的权限分为三类:读(r)、写(w)、执…

JavaScript高级Ⅰ(自认为很全面版)

目录 第1章 BOM编程 1.1 BOM编程概述 1.1.1 BOM编程的概念 1.1.2 BOM编程的作用 1.1.3 BOM常用的对象 1.2 window对象 1.2.1 JS三个弹框(了解) 代码演示: 运行效果: 1.2.2 JS两个定时器 代码演示: 运行效果: 1.2.3 案…

机器学习——向量化

通常各种编程语言里,都有对应的各种线性代数库,我们可以利用现成的代数库来快速的求解我们想要的结果,也就是说,通过代数库,会让我们可以用更少的代码,更高的效率实现需求,这就是向量化的作用 …

(黑马出品_05)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

(黑马出品_05)SpringCloudRabbitMQDockerRedis搜索分布式 微服务技术分布式搜索 今日目标1.初识elasticsearch1.1.了解ES1.1.1.elasticsearch的作用1.1.2.ELK技术栈1.1.3.elasticsearch和lucene1.1.4.为什么不是其他搜索技…

go语言基础 -- 文件操作

基础的文件操作方法 go里面的文件操作封装在os包里面的File结构体中,要用的时候最好去查下官方文档,这里介绍下基本的文件操作。 打开关闭文件 import("os" ) func main() {// Open返回*File指针,后续的操作都通过*File对象操作…

白酒:蒸馏技术的优化与新型蒸馏设备的研发

蒸馏技术是豪迈白酒生产中的重要环节,直接关系到产品的质量和风格。云仓酒庄在蒸馏技术的优化和新型蒸馏设备的研发方面进行了大量探索和实践,旨在提升白酒的品质和口感。 首先,蒸馏技术的优化对于豪迈白酒的品质至关重要。传统的蒸馏技术通常…

天星数科精细化运营,擘画金融服务实体发展新篇章

党的二十大报告提出“建设现代化产业体系”,要求“坚持把发展经济的着力点放在实体经济上”。这是站在改革开放40多年发展实践基础上,实现第二个百年奋斗目标作出的战略部署。天星数科作为深耕金融服务多年的科技公司,聚焦主业、立足于专业&a…

Python实现时间序列分析Theta模型(ThetaModel算法)项目实战

说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 时间序列分析中的Theta模型(Theta Model)是由Athanasios Theodoridis在2008年提出的一种统计预测方法&…