消息中间件汇总

RocketMQ和MetaQ的区别

RocketMQ和MetaQ其实是同一种消息队列中间件的两种不同称呼。

在阿里巴巴内部,它被称为MetaQ,而在开源版本中,它被称为RocketMQ。RocketMQ是MetaQ的3.0版本

ONS

阿里ONS是阿里巴巴公司推出的一款分布式消息系统。它基于阿里自主研发的可伸缩消息队列RocketMQ

一、RocketMQ

二、Kafka

相关概念 跳转

java 复制代码
【生产者】、【Top】、1个top多个分区【partition】, Group对应Top, 一个Group多个消费者
注意:TopA的消息只会给到GroupA


【生产者】 和 【top】
生产者发送消息时,只能选择发送到Top里面的某个分区里面去,这个是【消息生产者】可以选择的。

那在kafka中,如果某个topic有多个partition,producer又怎么知道该将数据发往哪个partition呢,
kafka中有几个原则:
1、partition在写入的时候可以指定需要写入的partition,如果有指定,则写入对应的partition。
2、如果没有指定partition,但是设置了数据的key,则会根据key的值hash出一个partition。
3、如果既没指定partition,又没有设置key,则会轮询选出一个partition。


【Top】和【消费者】
Group是一个组,那么组内必然可以有多个消费者或消费者实例(consumer instance),
它们共享一个公共的ID,即groupID。 

组内的所有【消费者】协调在一起来消费订阅主题Top的所有分区(partition)。
当然【每个分区】只能由【同一个消费组内】的一个Consumer来消费。

三、ribbtMQ

1、MQ概念
跳转

2、工作模型
跳转

3、消息可靠性投递方式(RabbitMQ防止重复消费和丢失的问题)
跳转

4、死信队列和延时队列(Rabbitmq死信队列及延时队列实现)
跳转

java 复制代码
ribbtMQ笔记草稿
https://blog.csdn.net/weixin_37862824/article/details/127109086

rabbitMq相关代码,死信队列相关
https://blog.csdn.net/weixin_37862824/article/details/126249018

通过注解RabbitListener设置多个消费者的问题
https://blog.csdn.net/weixin_37862824/article/details/128301572
相关推荐
BillKu2 小时前
推荐 Eclipse Temurin 的 OpenJDK
java·ide·eclipse
Morri32 小时前
[Java恶补day53] 45. 跳跃游戏Ⅱ
java·算法·leetcode
悟能不能悟2 小时前
eclipse怎么把项目设为web
java·eclipse
乂爻yiyao2 小时前
java 代理模式实现
java·开发语言·代理模式
2301_770373733 小时前
Java集合
java·开发语言
哈喽姥爷3 小时前
Spring Boot---自动配置原理和自定义Starter
java·spring boot·后端·自定义starter·自动配置原理
老华带你飞5 小时前
考研论坛平台|考研论坛小程序系统|基于java和微信小程序的考研论坛平台小程序设计与实现(源码+数据库+文档)
java·vue.js·spring boot·考研·小程序·毕设·考研论坛平台小程序
CHEN5_025 小时前
leetcode-hot100 11.盛水最多容器
java·算法·leetcode
songx_995 小时前
leetcode18(无重复字符的最长子串)
java·算法·leetcode
在路上`6 小时前
前端学习之后端java小白(三)-sql外键约束一对多
java·前端·学习