概念

MQ:消息队列(消息中间件),开源的基于AMQP协议的消息中间件,异步 解耦 削峰

核心作用:1.异步 2.解耦 3.消息通信

RabbitMQ

消息的类型:1.点对点 2.Worker 3.发布/定义(交换器)

四种交换器:

■1.fanout直接转发

■2.direct路由关键字匹配,精确

■3.topic路由关键字匹配,支持模糊(*和#)

■4.header消息头

RabbitMQ保证消息的可靠性(消息丢失)

原因:

有一定的概率会出现消息丢失

比如:1.消息刚从发送者发送到服务器中,发送者宕机了,在发送的一瞬间,服务器网络异常

2.消费者刚从服务器获取数据,还没获取完,服务器宕机了,或者网络延迟了

3.任何一款的MQ都有可能遇到消息丢失的问题,特别是高并发下

发送端:

要考虑的问题:

1.保证消息发送成功

2.保证服务端接收成功

3.要采用应答模式 发送端和服务端的应答模式

4.需要考虑消息补偿机制

解决方案:

1.消息开启本地持久化 --- 实现消息的落库的处理

2.实现基于延迟的二次确认机制 --- 消息采用2次投递方案,第一次立即执行,第二次间隔执行 采用延迟的模式进行,第二次的投递是为了保证数据的校验。如果存在就不做处理,要是不存在就同步一次

3.RabbitMQ支持消息事务 --- 可以采用事务的模式来处理消息是否成功

消费端:

1.保证消息的获取并应答

结合RabbitMQ的消息应答模式 实现消息消费的应答

2.保证消息过重

每一个消息都有唯一ID,每当消费者获取到消息的时候,先检验此消息有没有被消费过,如果没有再继续进行操作。要是之前消费过,那么就不能再次处理!可以结合Redis

RabbitMQ保证消息幂等性(消息重复)

幂等性:用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用。

消息重复

MQ有可能会出现一个消息发送多次,导致消息的重复性

可能出现的场景:1.网络抖动 2.网络闪断 3.端点异常 服务端或者发送端或者消费端

消息出现非幂等性,就会导致消息的重复

解决方案:

1.唯一ID+指纹码

唯一ID 可以使用:雪花算法等等 这种分布式唯一ID生成器

指纹码:就是一段密文,加密规则各不相同

常用:时间戳+随机码+唯一ID+业务ID 采用一定加密技术 进行密文生成

2.基于Redis的原子性实现

Redis的原子性,自增啥的都可以,关键Redis支持集群

为消息设置唯一id,生成唯一id可以用雪花算法,实现去重

RabbitMQ延时队列

延时队列:跟普通队列比起来,多了一个延时的作用

死信消息:就是一个消息的TTL(有效期)结束了,但是消息还未处理,这时这个消息就变为了死信消息

死信队列和延迟消息投递

死信消息的条件:1.拒绝 2.过期 3.队列满了

延迟队列:RabbitMQ没有延迟队列,但是我们可以通过死信消息实现延迟消息投递\

消息的优先级

默认为5,可以通过设置x-max-priority,

MQ集群:1.默认模式 数据存储在其中某一台机器上,在使用的时候,才会进行同步。

2.镜像模式

项目中的应用场景:1.解耦逻辑 2.数据同步(近乎实时)3.延迟队列

RabbitMQ零碎整理,总有一天在你工作中会用到的更多相关文章

  1. 自己整理的所有java知识点(不断迭代中)

    1. 自己整理的所有java知识点(不断迭代中) 画图工具注册 https://www.processon.com/i/599d35fae4b00d97d7f9bb17 1.1. Java整体知识架构 ...

  2. 【Unity】近期整理Unity4.x 项目升级Unity5.0 过程中出现的各种常见问题,与大家共享。

    近期整理Unity4.x 项目升级Unity5.0 过程中出现的各种常见问题,与大家共享. 1:Unity4.x 项目中3D模型其材质丢失,成为"白模"?       解决方式:手 ...

  3. RabbitMQ学习整理

    1.什么是消息队列? 概念: 消息队列(Message Queue,简称MQ),本质是个队列,FIFO先入先出,只不过队列中存放的内容是一些Message. 2.为什么要用消息队列,应用场景? 不同系 ...

  4. js零碎整理

    本文格式: 大整合类标题 文章标题 作者:文章网址 USA:参考老外网址/老外网址 &&: 意思是内涵一个系列 javascript方面整理: 1. for in 循环的输出顺序问题 ...

  5. RabbitMQ 资料整理

    前言: 官方教程: https://www.rabbitmq.com/getstarted.html 应用场景(之马云赚钱): http://blog.csdn.net/whoamiyang/arti ...

  6. RabbitMq的整理 exchange、route、queue关系

    https://blog.csdn.net/samxx8/article/details/47417133

  7. ## jvm知识点零碎整理

    1.初始化VM options配置 idea安装目录\bin\idea.exe.vmoptions 和 idea64.exe.vmoptions可以看到初始配置: -Xms128m  (设置初始化堆内 ...

  8. 工作中积累整理-CSS样式表(一)

    [layout] clear:该属性的值指出了不允许有浮动对象的边. 默认值:none none: 允许两边都可以有浮动对象 both: 不允许有浮动对象 left: 不允许左边有浮动对象 right ...

  9. 工作中常用的JS函数整理分享(欢迎大家补充)

    今年在渣X工作整理的常用JS函数 今年来了渣X工作,我所在这个部门分工很奇怪,CSS竟然有专门的人在搞,开发PHP的人员需要处理JS,以至于有时候开发起来不是那么得心应手,感觉把JS和CSS拆开就像是 ...

  10. 【linux】工作中linux系统常用命令操作整理

    1.Linux如何查看端口 使用lsof(list open files)命令,lsof -i:端口号 用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof -i:8000. 或者使用n ...

随机推荐

  1. 【技术剖析】7. 看看毕昇 JDK 团队是如何解决 JVM 中 CMS 的 Crash

    [技术剖析]7. 看看毕昇 JDK 团队是如何解决 JVM 中 CMS 的 Crashhttps://bbs.huaweicloud.com/forum/thread-168485-1-1.html ...

  2. NOI Linux 下 Geany 配置教程

    没有括号补全? 现在有自动括号补全了! 红色的 a.cpp 的意思是 a.cpp 没有保存. 现在来设置编译运行的快捷键. 不难推测 "%e" 是可执行文件的意思,"%f ...

  3. js中forEach的用法、forEach如何跳出循环、forEach与for之间的区别

    定义和用法 forEach() 调用数组的每个元素,并将元素传递给回调函数. 注意: forEach() 对于空数组是不会执行回调函数的. 用法: array.forEach(function(cur ...

  4. 如何在IntelliJ IDEA中运行Java/Scala/Spark程序

    本文将分两部分来介绍如何在IntelliJ IDEA中运行Java/Scala/Spark程序: 基本概念介绍 在IntelliJ IDEA中创建和运行java/scala/spark程序 基本概念介 ...

  5. C#不显示小数点0部分

    c#去掉小数点后的无效0 ,保留指定位数的小数,比如10.0显示成10,小数部分会四舍五入 float value = 0.0500f; value.ToString("0.##" ...

  6. TienChin 运行 RuoYi-Vue3

    在前几篇文章当中,之前使用的是 Vue2,在某一天发现若依提供了 Vue3 的版本,所以这篇文章主要是运行起来,Vue2,迟早要被替代,所以这里采用最先进的 Vue3. 仓库地址:https://gi ...

  7. 强化学习从基础到进阶-常见问题和面试必知必答[8]:近端策略优化(proximal policy optimization,PPO)算法

    强化学习从基础到进阶-常见问题和面试必知必答[8]:近端策略优化(proximal policy optimization,PPO)算法 1.核心词汇 同策略(on-policy):要学习的智能体和与 ...

  8. 15.1 套接字通过域名取IP地址

    首先我们来实现一个DNS查询功能,该功能的目的是传入一个网站域名自动将该域名解析为对应的IP地址,该功能的实现依赖于gethostbyname函数,该函数将主机名作为参数,并返回一个指向hostent ...

  9. C/C++ 使用CRC检测磁盘文件完整性

    当软件被开发出来时,为了增加软件的安全性,防止被破解,通常情况下都会对自身内存或磁盘文件进行完整性检查,以防止解密者修改程序,我们可以将exe与dll文件同时做校验,来达到相互认证的目的,解密者想要破 ...

  10. 常用容器:动态数组array、列表list、队列 queue、map或字典、 集合、栈等等

    一般语言都会提供一些逻辑容器的实现,各个语言的实现方式不同:底层的数学算法应该差不多: 动态数组 `` 这个没啥可说的,就是一个数组,满了时候,再创建一个数组,把之前的数组里的数据移过来,销毁之前数组 ...