RabbitMQ简单介绍

一、RabbitMQ介绍

1、什么是mq

消息队列(Message Queue,简称MQ):是在消息的传输过程中保存消息的容器。用于分布式系统之间进行通信。

2、选型和对比

RabbitMQ ActiveMQ RocketMQ Kafka
公司/社区RabbitApache阿里Apache
开发语言ErlangJavaJavaScala&Java
协议AMQPOpenWire、AUTO、Stomp、MQTT自定义自定义
单机吞吐量万级万级(最差)十万级十万级
消息延迟微妙级毫秒级毫秒级毫秒以内
特性并发能力很强,延时很低老牌产品,文档较多MQ功能比较完备,扩展性佳只支持主要的MQ功能,毕竟是为大数据领域准备的。

综合上面的材料得出以下两点:

  1. 中小型软件公司,建议选RabbitMQ.一方面,erlang语言天生具备高并发的特性,RabbitMQ的社区十分活跃,可以解决开发过程中遇到的bug,这点对于中小型公司来说十分重要。不考虑rocketmq和kafka的原因是中小型软件公司不如互联网公司,数据量没那么大,选消息中间件,应首选功能比较完备的,所以kafka和rocketmq排除。

  2. 大型软件公司,根据具体使用在rocketMq和kafka之间二选一。一方面,大型软件公司,具备足够的资金搭建分布式环境,也具备足够大的数据量。针对rocketMQ,大型软件公司也可以抽出人手对rocketMQ进行定制化开发,毕竟国内有能力改JAVA源码的人,还是相当多的。至于kafka,根据业务场景选择,如果有日志采集功能,肯定是首选kafka了。

3、什么是RabbitMQ?

AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。2006年,AMQP规范发布。类比HTTP。

2007年,Rabbit技术公司基于AMQP标准开发的RabbitMQ1.0发布。RabbitMQ采用Erlang 语言开发。  

总结:rabbitmq是erlang语言编写实现AMQP协议的消息中间件

3.1、AMQP协议

connection(连接)、channel(信道)、exchange(交换器)、queue(队列)(在RabbitMQ安装中有对应的解释)

routingkey:控制消息的去向,支持通配符;eg:*匹配1个单词,#匹配多个单词;

4、为什么要使用RabbitMQ?

4.1、解耦

总结:a服务本来是调用b、c服务,若再添加d服务则无须修改a服务的源代码

传统模式:系统间耦合性太强,如图所示,系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码,过于麻烦!

中间件模式:将消息写入消息队列,需要消息的系统自己从消息队列中订阅,从而系统A不需要做任何修改。  

4.2、异步

总结:a服务把消息发送到mq,b、c服务接收消息后以异步的方式运行

传统模式: 一些非必要的业务逻辑以同步的方式运行,太耗费时间

中间件模式: 将消息写入消息队列,非必要的业务逻辑以异步的方式运行,加快响应速度  

4.3、削峰

总结:按并发能力拉取消息,慢慢处理业务

传统模式:并发量大的时候,所有的请求直接怼到数据库,造成数据库连接异常

 中间件模式: 系统A慢慢的按照数据库能处理的并发量,从消息队列中慢慢拉取消息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值