博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
.Net下RabbitMQ的使用(2) -- 发送接收消息
阅读量:6859 次
发布时间:2019-06-26

本文共 2450 字,大约阅读时间需要 8 分钟。

在安装和配置完成RabbitMQ之后,我们就可以尝试做一个最简单的例子:发送和接收消息。

 

我们先来看客户端也就是发送者的代码:

 

public class RabbitClient
{
//定义连接工厂
ConnectionFactory factory = new ConnectionFactory();
 
public RabbitClient()
{
//指定要连接的RabbitMQ服务地址
factory.HostName = "localhost";
}
 
public void Send()
{
//定义要发送的数据
RequestMessage message = new RequestMessage() { MessageId = Guid.NewGuid(), Message = "this is a 请求。" };
 
//创建一个 AMQP 连接
using (IConnection connection = factory.CreateConnection())
{
using (IModel channel = connection.CreateModel())
{
//在MQ上定义一个队列
channel.QueueDeclare("esbtest.rmq.consoleserver", false, false, false, null);
 
//序列化消息对象,RabbitMQ并不支持复杂对象的序列化,所以对于自定义的类型需要自己序列化
XmlSerializer xs = new XmlSerializer(typeof(RequestMessage));
using (MemoryStream ms = new MemoryStream())
{
xs.Serialize(ms, message);
byte[] bytes = ms.ToArray();
//指定发送的路由,通过默认的exchange直接发送到指定的队列中。
channel.BasicPublish("", "esbtest.rmq.consoleserver", null, bytes);
}
 
Console.WriteLine(string.Format("Request Message Sent, Id:{0}, Message:{1}", message.MessageId, message.Message));
}
}
}
}

 

在方法
channel.BasicPublish("", "esbtest.rmq.consoleserver", null, bytes);
中的第一个参数是需要输入一个exchange。在RabbitMQ中,所有的消息都必须要通过exchange发送到各个queue里面去。发送者发送消息,其实也就是把消息放到exchange中去。而exchange知道应该把消息放到哪里去。在这个方法中,我们没有输入exchange的名称,只是定义了一个空的echange,而在第二个参数routeKey中输入了我们目标队列的名称。RabbitMQ会帮我定义一个默认的exchange,这个exchange会把消息直接投递到
我们输入的队列中,这样服务端只需要直接去这个定义了的队列中获取消息就可以了。
 

服务端的代码:

 

public class RabbitServer
{
ConnectionFactory factory = null;
 
public void Listen()
{
factory = new ConnectionFactory();
factory.HostName = "localhost";
 
using (IConnection connection = factory.CreateConnection())
{
using (IModel channel = connection.CreateModel())
{
//在MQ上定义一个队列,如果名称相同不会重复创建
channel.QueueDeclare("esbtest.rmq.consoleserver", false, false, false, null);
 
Console.WriteLine("Listening...");
 
//在队列上定义一个消费者
QueueingBasicConsumer consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume("esbtest.rmq.consoleserver", true, consumer);
 
while (true)
{
//阻塞函数,获取队列中的消息
BasicDeliverEventArgs ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
 
byte[] body = ea.Body;
 
XmlSerializer xs = new XmlSerializer(typeof(RequestMessage));
using (MemoryStream ms = new MemoryStream(body))
{
RequestMessage message = (RequestMessage)xs.Deserialize(ms);
Console.WriteLine("Receive a Message, Id:" + message.MessageId + " Message:" + message.Message);
}
}
}
}
}
}

 

至此,简单的发送接收程序就可以运行了,运行RabbitMQ,然后分别运行客户端和服务端。运行结果如图:

客户端:

 

服务端:

 

 

代码可以从下载。

 

 

转载地址:http://letyl.baihongyu.com/

你可能感兴趣的文章
第一章 起步
查看>>
socket和http有什么区别?
查看>>
vue+element刷新当前路由
查看>>
关于“机器人离线编程”国内外近三年的研究
查看>>
计算机网络
查看>>
[04]javascript的数据类型
查看>>
[CC-SEABUB]Sereja and Bubble Sort
查看>>
JS设置cookie、读取cookie、删除cookie
查看>>
我的博客园的CSS和html设置
查看>>
数论基础(维诺格拉多夫著,裘光明译) 勘误
查看>>
vue-cookies的使用
查看>>
Code Signal_练习题_Make Array Consecutive2
查看>>
双向循环链表 初始化 插入 删除
查看>>
C#设计模式:职责链模式(Chain of Responsibility)
查看>>
Knockout.js随手记(2)
查看>>
条件注释判断IE浏览器
查看>>
Hibernate,删除对象时错误。
查看>>
C#中Cookies的读取
查看>>
冬季养生进补20招
查看>>
20179311《网络攻防实践》第四周作业
查看>>