前言
最近项目要使用RabbitMQ,网上已经有很多优秀的文章了,百度百科对RabbitMQ阐述也非常明确,建议去看下,还有amqp协议。必须一提的是rabbitmq是由LShift提供的一个消息队列协议(AMQP)的开源实现,由以高性能、健壮以及可伸缩性出名的Erlang写成(因此也是继承了这些优点)。
最近参考大神们的博客,自己做了一个RabbitMQ即时发消息的Demo。下面话不多说了,来一起看看详细的介绍吧。
步骤如下:
1.使用VS的NuGet安装包管理工具安装RabbitMQ.Client:
2.生产者端代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using RabbitMQ.Client; namespace RabbitMQ.Producter { class Program { /// <summary> /// 连接配置 /// </summary> private static readonly ConnectionFactory rabbitMqFactory = new ConnectionFactory() { HostName= "localhost" , UserName = "guest" , Password = "guest" , Port = 5672, //VirtualHost = "JentVirtualHost" }; /// <summary> /// 路由名称 /// </summary> const string ExchangeName = "Jent.Exchange" ; /// <summary> /// 队列名称 /// </summary> const string QueueName = "Jent.Queue" ; static void Main( string [] args) { DirectExchangeSendMsg(); Console.WriteLine( "按任意键退出程序!" ); Console.ReadKey(); } /// <summary> /// 单点精确路由模式 /// </summary> private static void DirectExchangeSendMsg() { using (IConnection conn = rabbitMqFactory.CreateConnection()) { using (IModel channel = conn.CreateModel()) { channel.ExchangeDeclare(ExchangeName, "direct" , durable: true , autoDelete: false , arguments: null ); channel.QueueDeclare(QueueName, durable: true , exclusive: false , autoDelete: false , arguments: null ); channel.QueueBind(QueueName, ExchangeName, routingKey: QueueName); var props = channel.CreateBasicProperties(); props.Persistent = true ; Console.WriteLine( "请输入需要发送的消息:" ); string vadata = Console.ReadLine(); while (vadata != "exit" ) { var msgBody = Encoding.UTF8.GetBytes(vadata); channel.BasicPublish(exchange: ExchangeName, routingKey: QueueName, basicProperties: props, body: msgBody); Console.WriteLine( string .Format( "发送时间:{0},发送完毕,输入exit退出消息发送" , DateTime.Now.ToString( "yyyy-MM-dd HH:mm:ss" ))); vadata = Console.ReadLine(); } } } } } } |
3.消费者端代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using RabbitMQ.Client; namespace RabbitMQ.Consumer { class Program { /// <summary> /// 连接配置 /// </summary> private static readonly ConnectionFactory rabbitMqFactory = new ConnectionFactory() { HostName = "127.0.0.1" , UserName = "guest" , Password = "guest" , Port = 5672, //VirtualHost = "JentVirtualHost" }; /// <summary> /// 路由名称 /// </summary> const string ExchangeName = "Jent.Exchange" ; /// <summary> /// 队列名称 /// </summary> const string QueueName = "Jent.Queue" ; static void Main( string [] args) { DirectAcceptExchange(); Console.WriteLine( "输入任意值退出程序!" ); Console.ReadKey(); } private static void DirectAcceptExchange() { using (IConnection conn = rabbitMqFactory.CreateConnection()) { using (IModel channel = conn.CreateModel()) { channel.ExchangeDeclare(ExchangeName, "direct" , durable: true , autoDelete: false , arguments: null ); channel.QueueDeclare(QueueName, durable: true , exclusive: false , autoDelete: false , arguments: null ); channel.QueueBind(QueueName, ExchangeName, routingKey: QueueName); while ( true ) { BasicGetResult msgResponse = channel.BasicGet(QueueName, autoAck: false ); if (msgResponse != null ) { var msgBody = Encoding.UTF8.GetString(msgResponse.Body); Console.WriteLine( string .Format( "接收时间:{0},消息内容:{1}" , DateTime.Now.ToString( "yyyy-MM-dd HH:mm:ss" ), msgBody)); } //System.Threading.Thread.Sleep(TimeSpan.FromSeconds(1)); } } } } } } |
4.程序结果:
注:在第一步之前,你需要安装RabbitMQ客户端,可从http://www.rabbitmq.com/download.html下载,
但是RabbitMQ又是依赖于Erlang OTP平台,所以,安装RabbitMQ之前,需要先从http://www.erlang.org/download.html下载安装erlang
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:https://www.cnblogs.com/JentZhang/archive/2018/07/09/9283964.html