1. 说明
在企业应用系统领域,会面对不同系统之间的通信、集成与整合,尤其当面临异构系统时,这种分布式的调用与通信变得越发重要。其次,系统中一般会有很多对实时性要求不高的但是执行起来比较较耗时的地方,比如发送短信,邮件提醒,更新文章阅读计数,记录用户操作日志等等,如果实时处理的话,在用户访问量比较大的情况下,对系统压力比较大。
面对这些问题,我们一般会将这些请求,放在消息队列MQ中处理;异构系统之间使用消息进行通讯。
MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过 队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。
MQ是消费-生产者模型的一个典型的代表,一端往消息队列中不断写入消息,而另一端则可以读取或者订阅队列中的消息。
RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统。他遵循Mozilla Public License开源协议。
消息传递相较文件传递与远程过程调用(RPC)而言,似乎更胜一筹,因为它具有更好的平台无关性,并能够很好地支持并发与异步调用。所以如果系统中出现了如下情况:
- 对操作的实时性要求不高,而需要执行的任务极为耗时;
- 存在异构系统间的整合;
一般的可以考虑引入消息队列。对于第一种情况,常常会选择消息队列来处理执行时间较长的任务。引入的消息队列就成了消息处理的缓冲区。消息队列引入的异步通信机制,使得发送方和接收方都不用等待对方返回成功消息,就可以继续执行下面的代码,从而提高了数据处理的能力。尤其是当访问量和数据流量较大的情况下,就可以结合消息队列与后台任务,通过避开高峰期对大数据进行处理,就可以有效降低数据库处理数据的负荷。
本文简单介绍在RabbitMQ这一消息代理工具,以及在.NET中如何使用RabbitMQ.
2. 搭建环境
2.1 安装Erlang语言运行环境
由于RabbitMQ使用Erlang语言编写,所以先安装Erlang语言运行环境。具体移步博客:windows配置Erlang环境
2.2 安装RabbitMQ服务端
地址 http://www.rabbitmq.com/
下载安装。
使RabbitMQ以Windows Service的方式在后台运行:打开cmd切换到sbin目录下执行
rabbitmq-service install rabbitmq-service enable rabbitmq-service start
现在RabbitMQ的服务端已经启动起来了。
要查看和控制RabbitMQ服务端的状态,可以用rabbitmqctl这个脚本。
比如查看状态:
rabbitmqctl status
假如显示node没有连接上,需要到C:\Windows目录下,将.erlang.cookie文件,拷贝到用户目录下 C:\Users\{用户名},这是Erlang的Cookie文件,允许与Erlang进行交互。
使用命令查看用户:
rabbitmqctl list_users
RabbitMQ会为我们创建默认的用户名guest和密码guest,guest默认拥有RabbitMQ的所有权限。
一般的,我们需要新建一个我们自己的用户,设置密码,并授予权限,并将其设置为管理员,可以使用下面的命令来执行这一操作:
rabbitmqctl add_user JC JayChou //创建用户JC密码为JayChou rabbitmqctl set_permissions JC ".*" ".*" ".*" //赋予JC读写所有消息队列的权限 rabbitmqctl set_user_tags JC administrator //分配用户组
修改JC密码为123:
rabbitmqctl change_password JC 123
删除用户JC:
rabbitmqctl delete_user JC
也可以开启rabbitmq_management插件,在web界面查看和管理RabbitMQ服务
rabbitmq-plugins enable rabbitmq_management
2.3下载RabbitMQ的Client端dll
下载地址:http://www.rabbitmq.com/releases/rabbitmq-dotnet-client/
本人下载了这个 rabbitmq-dotnet-client-3.6.6-dotnet-4.5.zip
解压,我们需要的是这个文件,以后会引用到vs的项目中:
3.使用
3.1在使用RabitMQ之前,先对几个概念做一下说明
RabbitMQ是一个消息代理。他从消息生产者(producers)那里接收消息,然后把消息送给消息消费者(consumer)在发送和接受之间,他能够根据设置的规则进行路由,缓存和持久化。
一般提到RabbitMQ和消息,都用到一些专有名词。
- 生产(Producing)意思就是发送。发送消息的程序就是一个生产者(producer)。我们一般用"P"来表示:
- 队列(queue)就是邮箱的名称。消息通过你的应用程序和RabbitMQ进行传输,它们只能存储在队列(queue)中。 队列(queue)容量没有限制,你要存储多少消息都可以——基本上是一个无限的缓冲区。多个生产者(producers)能够把消息发送给同一个队列,同样,多个消费者(consumers)也能从同一个队列(queue)中获取数据。队列可以画成这样(图上是队列的名称):
- 消费(Consuming)和获取消息是一样的意思。一个消费者(consumer)就是一个等待获取消息的程序。我们把它画作"C":
通常,消息生产者,消息消费者和消息代理不在同一台机器上。
3.2 Hello Word
下面来展示简单的RabbitMQ的使用:
3.2.1 首先创建名为ProjectSend的控制台项目,需要引用RabbitMQ.Client.dll。这个程序作为Producer生产者,用来发送数据:
static void Main(string[] args) { var factory = new ConnectionFactory(); factory.HostName = "localhost";//RabbitMQ服务在本地运行 factory.UserName = "guest";//用户名 factory.Password = "guest";//密码using (var connection = factory.CreateConnection()) { using (var channel = connection.CreateModel()) { channel.QueueDeclare("hello", false, false, false, null);//创建一个名称为hello的消息队列 string message = "Hello World"; //传递的消息内容 var body = Encoding.UTF8.GetBytes(message); channel.BasicPublish("", "hello", null, body); //开始传递 Console.WriteLine("已发送: {0}", message);<br> Console.ReadLine(); } } }</pre>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12