消息中间件汇总

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
相关推荐
步步为营DotNet1 小时前
深度解析CancellationToken:.NET中的优雅取消机制
java·前端·.net
JH30739 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_10 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble11 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟11 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖11 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_124987075312 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_12 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.12 小时前
Day06——权限认证-项目集成
java
瑶山12 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard