RabbitMQ的工作模式】的更多相关文章

目录 一.RabbitMQ入门程序 二.Work queues 工作模式 三.Publish / Subscribe 发布/订阅模式 四.Routing 路由模式 五.Topics 六.Header 七.RPC 八.Spring Data Elasticsearch 一.RabbitMQ入门程序 <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifa…
问题:请讲下rabbitMQ的工作模式 分析:该问题纯属概念题,需要掌握rabbtiMQ的基础知识,同时该题也是切入MQ的一个引子: 回答要点: 主要从以下几点去考虑, 1.rabbitMQ的基本概念? 2.交换机的概念? rabbitmq有以下几种工作模式, 简单模式 简单模式,是一个生产者对应一个消费者,mq起到一个代理的作用, 使用场景:可以作为一个队列来使用,比如发邮件功能,生产者把要发送的邮件交给MQ,发邮件服务从MQ中获取邮件进行发送,很好的解耦特性的体现 工作队列模式 工作队列模式…
一.前言 之前,笔者写过< CentOS 7.2 安装 RabbitMQ> 这篇文章,今天整理一下 RabbitMQ 相关的笔记便于以后复习. 二.模式介绍 在 RabbitMQ 官网上提供了 6 中工作模式:简单模式.工作队列模式.发布/订阅模式.路由模式.主题模式 和 RPC 模式. 本篇只对前 5 种工作方式进行介绍. 2.1 简单模式与工作队列模式 之所以将这两种模式合并在一起介绍,是因为它们工作原理非常简单,由 3 个对象组成:生产者.队列.消费者. 生产者负责生产消息,将消息发送到…
RabbitMQ有以下几种工作模式 : 1.Work queues 2.Publish/Subscribe 3.Routing 4.Topics 5.Header 6.RPC 1.Work queues work queues与入门程序相比,多了一个消费端,两个消费端共同消费同一个队列中的消息. 应用场景:对于 任务过重或任务较多情况使用工作队列可以提高任务处理的速度. 测试: 1.使用入门程序,启动多个消费者. 2.生产者发送多个消息. 结果: 1.一条消息只会被一个消费者接收: 2.rabb…
Publish/subscribe:发布订阅模式 发布订阅模式: 1.每个消费者监听自己的队列. 2.生产者将消息发给broker,由交换机将消息转发到绑定此交换机的每个队列,每个绑定交换机的队列都将接收 到消息 中间多了个交换机 一个消息生产者先发送给交换机,由交换机把消息发送给各个队列.每个队列都有不同的消费者在监听 实现了发布一个消息 多个消费者都可以接收到这个消息了 如果把下面的队列干掉.那么红色圈出的部分和工作模式是相同的.工作对垒虽然没有交换机也会有一个默认的交换机. 所以说发布于订…
简单模式: # #########################基于简单模式的 生产者 ######################### #!/usr/bin/env python import pika # 封装 socket通信实现 connection = pika.BlockingConnection(pika.ConnectionParameters(host='192.168.253.128',port=5672)) # 创建通道对象 channel = connection.c…
header模式 header模式与routing不同的地方在于,header模式取消routingkey,使用header中的 key/value(键值对)匹配 队列. 案例: 根据用户的通知设置去通知用户,设置接收Email的用户只接收Email,设置接收sms的用户只接收sms,设置两种 通知类型都接收的则两种通知都有效. 发送数据 发送的时候发送了两个key /value对 那么上面就会两个队列接收. RPC RPC即客户端远程调用服务端的方法 ,使用MQ可以实现RPC的异步调用,基于D…
路由模式: 1.每个消费者监听自己的队列,并且设置带统配符的routingkey. 2.生产者将消息发给broker,由交换机根据routingkey来转发消息到指定的队列. 创建测试用例 交换机的名称 清理场景 删除这个交换机 删除队列 再删除sms的队列 交换机的类型变成topic routingKey的变化 如果队列是inform.email.sms那么这两个队列都可以匹配上,#代表任意的字符,也可以代表是空的字符 绑定topic的交换机 发送消息 发送的routingKey是email和…
先常见生产者 复制02的代码 先改一下交换机的名称 还需要制定routingKey.因为是两个消息 所以指定了两个routingKey 这里修改为当前指定的交换机名称 交换机和队列在绑定的时候指定我们新定义的routingKey 交换机在定义的时候,类型设置为Direct 发送消息要指定routingKey.例如这里我要给email发送消息,那么就指定routingKey为Email 消费者 修改交换机的名称和交换机的类型 交换机绑定的时候指定routingKey 再创建短信的消费者 测试 运行…
队列在绑定交换机的时候可以指定routingKey, 路由模式: 1.每个消费者监听自己的队列,并且设置routingkey. 2.生产者将消息发给交换机,由交换机根据routingkey来转发消息到指定的队列. 例如下面指定的routingKey是error 下面这个设置了多个routingKey 一个是info 一个是error 还有一个是warrning routingKey 的作用,当消息发送到交换机的时候,会指定一个路由key. 假设我们在消息发送到交换机的时候指定的路由key是err…