初识RabbitMQ

1.什么是MQ?

MQ翻译为消息队列,通过典型的生产者和消费者模型,生产者不断向消息队列中生产消息,消费者不断的从队列中获取消息。因为消息的生产和消费都是异步的,而且只关心消息的发送和接收,没有业务逻辑的侵入,轻松的实现系统间的解耦。别名为消息中间件。

2.RabbitMQ

RabbitMQ是使用Erlang 语言开发的开源消息队列系统,基于AMQP协议 来实现。AMQP的主要特征是面向消息、队列、路由、可靠性、安全。AMQP协议更多应用在企业系统内对数据一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求排在其次。

RabbitMQ比Kafka可靠,Kafka更适合IO高吞吐的处理,一般应用在大数据日志处理或对实时性,可靠性要求稍低的场景使用,比如说大数据统计、日志收集等等。

3.AMQP协议

AMQP协议:是进行消息传递的一种协议,AMQP不从API层进行限定,而是直接定义网络交换的数据格式。

我们看到Virtual Host代表着虚拟主机,那么如果有多个项目都要使用RabbitMQ,它们之间的消息肯定不能混在一起,所以就靠着虚拟主机把它们分开,多个项目建立不同的虚拟主机。

相关推荐
中国lanwp7 分钟前
Jenkins Pipeline中参数化构建
java·jenkins
记录Java学习的三木20 分钟前
Java:将视频上传到腾讯云并通过腾讯云点播播放
java
qianmoq30 分钟前
第01章:Stream是什么?5分钟让你的循环代码变优雅
java
UserNamezhangxi1 小时前
kotlin 协程笔记
java·笔记·kotlin·协程
咖啡里的茶i1 小时前
数字化图书管理系统设计实践(java)
java·课程设计
九转苍翎2 小时前
Java内功修炼(2)——线程安全三剑客:synchronized、volatile与wait/notify
java·thread
曲莫终2 小时前
正则表达式删除注释和多余换航
java·kotlin
whitepure2 小时前
万字详解JavaObject类方法
java·后端
Momentary_SixthSense2 小时前
RESP协议
java·开发语言·javascript·redis·后端·python·mysql
程序员清风2 小时前
程序员兼职月入20K+?这6种路径+平台避坑又赚钱!
java·后端·面试