RabbitMQ是流行的开源消息队列系统,用erlang语言开发,RabbitMQ是AMQP(高级消息队列协议)的标准实现。采用该技术,我们可以实现异步处理、流量削峰、系统解耦。
什么是消息队列(MQ)
消息是在不同应用间传递的数据。这里的消息可以非常简单,比如只包含字符串,也可以非常复杂,包含多个嵌套的对象。消息队列(Message Queue)简单来说就是一种应用程序间的通讯方式,消息发送后立即返回,然后由消息系统保证消息的可靠性传输,消息生产者只需要把消息发到MQ中就可以了,不需要关心消息的消费,同样,消息消费者只管从MQ中拉取消息而不管是谁生产的消息,通过这样的一个“互相不知道对象存在”模式,将消息的生产者和消息的消费者解耦了。
什么场景下考虑使用消息队列
从上面可以知道,消息队列是一种应用间的异步协作机制,那么我们什么时候需要用到MQ呢?以常见的订单系统为例,当用户点击「下单」后的业务逻辑可能包括:扣减库存、生成相应订单数据、发短信通知等。在项目和业务发展初期上面这些逻辑可能放在一起执行,随着业务的发展订单量的增加,需要提升系统服务的性能,此时就可以将一些不需要立即生效的操作拆分出来异步执行,比如发送短信通知等。这种场景下就可以使用MQ,在下单主流程(比如扣减库存、生成订单数据等)完成之后发送一条消息到MQ让主流程快速走完,然后由另外一个线程拉取MQ的消息,执行相应的业务逻辑。这里的例子主要是用消息队列来解耦。
RabbitMQ的特点
RabbitMQ是一个由Erlang语言开发的AMQP的开源实现。AMQP(Advanced Message Queue:高级消息队列协议)它是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产品、开发语言等条件的限制。RabbitMQ最初起源于消息系统,用于在分布式系统中存储转发消息,具体有如下一些特点:
可靠性:RabbitMQ使用一些机制来保证可靠性,比如持久化、传输确认机制(ack)和发布确认等。
灵活的路由策略:在消息进入队列之前,通过Exchange来路由消息,对于典型的路由功能,RabbitMQ已经提供了一些内置的Exchange来实现。针对复杂的路由功能,可以将多个Exchange绑在一起,也通过插件机制实现自己的Exchange。
消息集群:多个RabbitMQ服务器可以组成一个集群,形成一个逻辑Broker。
高可用:队列可以在集群中的集群上进行镜像,使得在部分节点出问题的情况下队列仍然可用。
多种协议:RabbitMQ支持多种消息队列协议,比如STOMP、MQTT等。
多语言客户端:RabbitMQ几乎支持多有常用的语言,比如:Java、.NET等
管理界面:RabbitMQ提供了一个易用的用户界面,使得用户可以监控和管理消息Broker的许多方面。
零基础学习RabbitMQ入门教程,极悦的教学课程将讲授RabbitMQ的环境搭建、消息的发送与接收、消息确认、与SpringBoot集成等,让大家快速掌握RabbitMQ技术,以适应项目开发的需要;
课程学习目录
1.RabbitMQ:什么是消息队列
2.RabbitMQ:为什么使用消息队列
3.RabbitMQ:RabbitMQ的特点
4.RabbitMQ:安装RabbitMQ
5.RabbitMQ:启动和关闭服务
6.RabbitMQ:插件添加
7.RabbitMQ:用户管理
8.RabbitMQ:权限分配
9.RabbitMQ:vhost
10.RabbitMQ:AMQP协议机制
11.RabbitMQ:消息路由交换机类型
12.RabbitMQ:Direct类型交换机
13.RabbitMQ:Fanout类型交换机
14.RabbitMQ:Topic类型交换机
15.RabbitMQ:消息发送
16.RabbitMQ:消息发送测试
17.RabbitMQ:消息接收
18.RabbitMQ:消息接收测试
19.RabbitMQ:交换机-direct-消息接收
20.RabbitMQ:交换机-direct-消息发送
21.RabbitMQ:交换机-fanout-消息接收
22.RabbitMQ:交换机-fanout-消息发送
23.RabbitMQ:交换机-topic-消息接收和发送
完整目录可以关注极悦Java视频教程
以上就是极悦极悦注册机构的小编针对“Rabbitmq视频下载,零基础入门学习”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。
你适合学Java吗?4大专业测评方法
代码逻辑 吸收能力 技术学习能力 综合素质
先测评确定适合在学习