//durable = true 代表持久化 交换机和队列都要为true ,持久代表服务重启,没有处理的消息依然存在
//topic 根据不同的routkey 发送和接收信息

//fanout 广播模式

//广播模式,代表每个消费者都会收到消息,每一个收到的都是1,2,3,4,5,6

//轮询模式,当两个消费者时候,每个消费者都会挨个接收消息 比如第一个接收1,2,3 第二个接收到的消息是2,4,6

using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace IOT_DeviceSocket
{
	public partial class FormRabbmitMQ : Form
	{
		public FormRabbmitMQ()
		{
			InitializeComponent();
		}
		string EXCHANGE_NAME = "EXCHANGE_NAME1111";
		string queuename = "queuename1111";
		private void button1_Click(object sender, EventArgs e)
		{
			//TOPIC发送();
			轮询发送();
		}

		private void button2_Click(object sender, EventArgs e)
		{
			//TOPIC接收();
			轮询接收();
		}

		public void 轮询发送()
		{
			#region 轮询
			var factory = new ConnectionFactory();
			factory.HostName = "127.0.0.1";
			factory.UserName = "Teld";
			factory.Password = "Teld@Teld.cn";
			//队列名称

			using (var connection = factory.CreateConnection())
			{
				using (var channel = connection.CreateModel())
				{
					//durable = true 代表持久化 交换机和队列都要为true
					//topic 轮询模式 fanout 广播模式
					//轮询模式,当两个消费者时候,每个消费者都会挨个接收消息 比如第一个接收1,2,3 第二个接收到的消息是2,4,6
					//广播模式,代表每个消费者都会收到消息,每一个收到的都是1,2,3,4,5,6

					//申明交换机并指定交换机类型 可以删除,也可以topic改为fanout模式
					channel.ExchangeDeclare(EXCHANGE_NAME, "topic", true);//申明交换机并指定交换机类型
					channel.QueueDeclare(queuename, true, false, false, null);
					//公平分发
					//channel.BasicQos(0, 1, false);
					var properties = channel.CreateBasicProperties();
					properties.DeliveryMode = 2; //持久化
					for (int i = 0; i < 1; i++)
					{
						var body = Encoding.UTF8.GetBytes(textBox1.Text);
						channel.BasicPublish("", queuename, properties, body);
					}

				}
			}
			#endregion
		}
		public void 轮询接收()
		{
			for (int i = 0; i < 2; i++)
			{
				var s = i;
				#region 轮询
				var factory = new ConnectionFactory();
				factory.HostName = "127.0.0.1";
				factory.UserName = "Teld";
				factory.Password = "Teld@Teld.cn";
				var connection = factory.CreateConnection();
				var channel = connection.CreateModel();
				var consumer = new EventingBasicConsumer(channel);
				//申明交换机并指定交换机类型 可以删除,也可以topic改为fanout模式
				channel.ExchangeDeclare(EXCHANGE_NAME, "topic", true);
				var queuenames = channel.QueueDeclare().QueueName;
				channel.QueueBind(queuenames, EXCHANGE_NAME, "");
				consumer.Received += (model, ea) =>
				{
					var body = ea.Body;
					try
					{
						//处理消息
						textBox2.Invoke(new EventHandler(delegate
						{
							textBox2.Text += s.ToString() + ":" + Encoding.Default.GetString(body) + "\r\n";
						}));
					}
					catch (Exception ex)
					{

					}
					finally
					{
						//确认完成
						channel.BasicAck(ea.DeliveryTag, false);
					}
				};
				//设置手动完成确认(noAck)
				channel.BasicConsume(queuename, false, consumer);
				#endregion

			}
		}

		public void 广播发送()
		{
			#region 广播
			var factory = new ConnectionFactory();
			factory.HostName = "127.0.0.1";
			factory.UserName = "Teld";
			factory.Password = "Teld@Teld.cn";
			var EXCHANGE_NAME = "eee";
			using (var connection = factory.CreateConnection())
			{
				using (var channel = connection.CreateModel())
				{
					// 声明该channel是fanout类型
					channel.ExchangeDeclare(EXCHANGE_NAME, "fanout");

					// 将消息发送给exchange
					//channel.basicPublish(EXCHANGE_NAME, "", null, msg.getBytes());
					var body = Encoding.UTF8.GetBytes(textBox1.Text);
					channel.BasicPublish(EXCHANGE_NAME, "", null, body);
				}
			}
			#endregion
		}

		public void 广播接收()
		{
			for (int i = 0; i < 2; i++)
			{
				var s = i;
				#region 广播
				// 创建连接和channel
				ConnectionFactory factory = new ConnectionFactory();
				factory.HostName = "127.0.0.1";
				factory.UserName = "Teld";
				factory.Password = "Teld@Teld.cn";
				var connection = factory.CreateConnection();
				var channel = connection.CreateModel();
				channel.ExchangeDeclare(EXCHANGE_NAME, "fanout");
				// 由RabbitMQ自行创建的临时队列,唯一且随消费者的中止而自动删除的队列
				String queueName = channel.QueueDeclare().QueueName;
				// binding
				channel.QueueBind(queueName, EXCHANGE_NAME, "");

				var consumer = new EventingBasicConsumer(channel);
				// 指定队列消费者
				channel.BasicConsume(queueName, true, consumer);
				consumer.Received += (model, ea) =>
				{
					var body = ea.Body;
					try
					{
						//处理消息
						textBox2.Invoke(new EventHandler(delegate
						{
							textBox2.Text += s.ToString() + ":" + Encoding.Default.GetString(body) + "\r\n";
						}));
					}
					catch (Exception ex)
					{

					}
					finally
					{

					}
				};
				#endregion
			}
		}

		String exchangeName = "wytExchangeTopic";
		String routeKeyName1 = "black.critical.high";
		String routeKeyName2 = "red.critical.high";
		String routeKeyName3 = "white.critical.high";

		public void TOPIC发送()
		{
			var factory = new ConnectionFactory();
			factory.HostName = "127.0.0.1";
			factory.UserName = "Teld";
			factory.Password = "Teld@Teld.cn";
			//队列名称

			using (var connection = factory.CreateConnection())
			{
				using (var channel = connection.CreateModel())
				{
					//durable = true 代表持久化 交换机和队列都要为true
					//topic 轮询模式 fanout 广播模式
					//轮询模式,当两个消费者时候,每个消费者都会挨个接收消息 比如第一个接收1,2,3 第二个接收到的消息是2,4,6
					//广播模式,代表每个消费者都会收到消息,每一个收到的都是1,2,3,4,5,6
					channel.ExchangeDeclare(exchangeName, "topic", true);//申明交换机并指定交换机类型
					var properties = channel.CreateBasicProperties();
					properties.DeliveryMode = 2; //持久化
					properties.Persistent = true;
					for (int i = 0; i < 1; i++)
					{
						//发送的消息
						var body = Encoding.UTF8.GetBytes(textBox1.Text);

						//给相应的routingKey 的推送消息,模拟给三个不同的key发送同一个消息,也可以给一个key发送消息
						//消息推送routeKeyName1
						channel.BasicPublish(exchange: exchangeName, routingKey: routeKeyName1, basicProperties: properties, body: body);
						////消息推送routeKeyName2
						//channel.BasicPublish(exchange: exchangeName, routingKey: routeKeyName2, basicProperties: properties, body: body);
						////消息推送routeKeyName3
						//channel.BasicPublish(exchange: exchangeName, routingKey: routeKeyName3, basicProperties: properties, body: body);
					}

				}
			}
		}

		public void TOPIC接收()
		{
			#region   topic模式 根据routingkey

			for (int i = 0; i < 2; i++)
			{
				var s = i;

				var factory = new ConnectionFactory();
				factory.HostName = "127.0.0.1";
				factory.UserName = "Teld";
				factory.Password = "Teld@Teld.cn";

				var connection = factory.CreateConnection();
				var channel = connection.CreateModel();
				var consumer = new EventingBasicConsumer(channel);
				channel.ExchangeDeclare(exchange: exchangeName, type: "topic", durable: true, autoDelete: false, arguments: null);

				String queueName = channel.QueueDeclare().QueueName;

				//接收一种就绑定一种routeKey
				channel.QueueBind(queue: queueName, exchange: exchangeName, routingKey: routeKeyName1, arguments: null);
				//channel.QueueBind(queue: queueName, exchange: exchangeName, routingKey: routeKeyName2, arguments: null);

				consumer.Received += (model, ea) =>
				{
					var body = ea.Body;
					try
					{
					//处理消息
					textBox2.Invoke(new EventHandler(delegate
						{
							textBox2.Text += s.ToString() + ":" + Encoding.Default.GetString(body) + "\r\n";
						}));
					}
					catch (Exception ex)
					{

					}
					finally
					{
					//确认完成
					channel.BasicAck(ea.DeliveryTag, false);
					}
				};
				//设置手动完成确认(noAck)
				channel.BasicConsume(queueName, false, consumer);
			}
			#endregion

		}
	}
}

  

demo rabbitmq topic(主题模式),fanout(广播模式),轮询分发,确认接收Ack处理的更多相关文章

  1. RabbitMQ学习第二记:工作队列的两种分发方式,轮询分发(Round-robin)和 公平分发(Fair dispatch)

    1.什么是RabbitMQ工作队列 我们在应用程序使用消息系统时,一般情况下生产者往队列里插入数据时速度是比较快的,但是消费者消费数据往往涉及到一些业务逻辑处理导致速度跟不上生产者生产数据.因此如果一 ...

  2. rabbitmq 交换机模式一 广播模式 fanout

    <?php require_once "./vendor/autoload.php"; use PhpAmqpLib\Connection\AMQPStreamConnect ...

  3. python---RabbitMQ(2)exchange中订阅者模式fanout<广播>,(一对多,发布一条消息,多人同时接收)

    fanout:广播:所有bind到此exchange的queue都可以接受到消息 生产者: # coding:utf8 # __author: Administrator # date: // # / ...

  4. python rabbitMQ 发送端和接收端广播模式。

    消费者模型: import pika,time consumer = pika.BlockingConnection\ (pika.ConnectionParameters('localhost')) ...

  5. 2017年5月17日20:14:29 rabbitmq 消费 异常信息无法处理 导致轮询

    同事说如果同步的配置的正确的话不会出现这种问题 只有异常的情况下才会,但是 我就真的出现了//TODO 等我有时间的时候再查查看. 如果是异步的出现这种问题的话 包进AmqpRejectAndDont ...

  6. RabbitMQ (三) 工作队列之轮询分发

    上一篇讲了简单队列,实际工作中,这种队列应该很少用到,因为生产者发送消息的耗时一般都很短,但是消费者收到消息后,往往伴随着对高消息的业务逻辑处理,是个耗时的过程,这势必会导致大量的消息积压在一个消费者 ...

  7. RabbitMQ广播模式

    广播模式:1对多,produce发送一则消息多个consumer同时收到.注意:广播是实时的,produce只负责发出去,不会管对端是否收到,若发送的时刻没有对端接收,那消息就没了,因此在广播模式下设 ...

  8. RabbitMQ基本用法、消息分发模式、消息持久化、广播模式

    RabbitMQ基本用法 进程queue用于同一父进程创建的子进程间的通信 而RabbitMQ可以在不同父进程间通信(例如在word和QQ间通信) 示例代码 生产端(发送) import pika c ...

  9. SpringCloudStream学习(二)RabbitMQ中的交换机跟工作模式

    知识储备: 交换机: ​ RabbitMQ中有4中交换机,分别是 (FANOUT)扇形交换机: 扇形交换机是最基本的交换机类型,它所能做的事情非常简单---广播消息.扇形交换机会把能接收到的消息全部发 ...

随机推荐

  1. js手机点击图片放大

    点击每个图片获取到对应的img的url链接,再把链接给一个空img以此来实现 最终效果:

  2. 61、springmvc-异步请求-返回DeferredResult

    61.springmvc-异步请求-返回DeferredResult 61.1 DeferredResult 官方文案 61.2 使用 /** * 创建订单加入 订单处理队列 * * @return ...

  3. Kylin介绍 (很有用)

    转:http://blog.csdn.net/yu616568/article/details/48103415 Kylin是ebay开发的一套OLAP系统,与Mondrian不同的是,它是一个MOL ...

  4. OTFS Research Notes

    △f = f·v·cosθ/c,f表示载波频率,5G/B5G朝着毫米波等高频段方向发展,因此多普勒拓展的影响将更显著.此外,Masssive MIMO的现有规模已达256维度,并将朝着上千的规模发展. ...

  5. [NOI2019]序列(模拟费用流)

    题意: 有两个长度为n的序列,要求从每个序列中选k个,并且满足至少有l个位置都被选,问总和最大是多少. \(1\leq l\leq k\leq n\leq 2*10^5\). 首先,记录当前考虑到的位 ...

  6. MongoDB journal 与 oplog,究竟谁先写入?

    MongoDB journal 与 oplog,谁先写入?最近经常被人问到,本文主要科普一下 MongoDB 里 oplog 以及 journal 这两个概念. journal journal 是 M ...

  7. java上传文件夹文件

    这里只写后端的代码,基本的思想就是,前端将文件分片,然后每次访问上传接口的时候,向后端传入参数:当前为第几块文件,和分片总数 下面直接贴代码吧,一些难懂的我大部分都加上注释了: 上传文件实体类: 看得 ...

  8. SPOJ 2939 QTREE5 LCT

    维护信息的方式十分巧妙~ 维护每一棵 splay 中深度最浅,深度最深的点距离最近的白点. 这样非常方便维护,进行区间合并,进行子树维护 很多时候在维护东西的时候最大/最小/深度最小/深度最大会相对容 ...

  9. codeforces425C

    http://codeforces.com/contest/425/problem/C 题意:两数列a[],b[],进行若干轮操作,每次操作花费e, 将a的一个前缀和b的一个前缀(两前缀的最后一个数字 ...

  10. ZR#999

    ZR#999 解法: 一道计数题,看到要求必须 $ m $ 个标号,所有标号至少出现一次的方案. 很容易想到可以容斥,但容斥这个东西是一种很神奇的东西,你可以看出来一道题需要容斥,但你就是不知道怎么容 ...