在C#中使用消息队列RabbitMQ

参考文章:http://www.cnblogs.com/qy1141/p/4054135.html

开发环境&工具: VS2017 RabbitMq Erlang运行环境

先安装Erlang运行环境然后再安装RabbitMq

安装和配置就不说了

默认安装路径:C:\Program Files\RabbitMQ Server,在rabbitmq_server-3.6.11\sbin文件夹下有bat文件

默认配置文件路径: C:\Users\wangshibang\AppData\Roaming\RabbitMQ\rabbitmq.config

下面直接说代码

客户端Client把发送的消息储存到RabbitMq中,服务器开启的时候会从Rabbitmq中读取储存的消息

项目结构图

Clinet端代码(记得添加 RabbitMQ.Client的Nuget包)

 1 using Newtonsoft.Json;
 2 using RabbitMQ.Client;
 3 using System;
 4 using System.Text;
 5 using RabbitMqLib;
 6
 7 namespace RabbitMqClient
 8 {
 9     class Program
10     {
11         static void Main(string[] args)
12         {
13             try
14             {
15                 ConnectionFactory factory = new ConnectionFactory();
16                 factory.HostName = Constants.MqHost;
17                 factory.Port = Constants.MqPort;
18                 factory.UserName = Constants.MqPwd;
19                 using (IConnection conn = factory.CreateConnection())
20                 {
21                     using (IModel channel = conn.CreateModel())
22                     {
23                         channel.QueueDeclare("MyFirstQueue", true, false, false, null);
24                         while (true)
25                         {
26                             string customStr = Console.ReadLine();
27                             RequestMsg requestMsg = new RequestMsg
28                             {
29                                 Name = $"Name_{customStr}",
30                                 Code = $"Code_{customStr}"
31                             };
32                             string jsonStr = JsonConvert.SerializeObject(requestMsg);
33                             byte[] bytes = Encoding.UTF8.GetBytes(jsonStr);
34
35                             //设置消息持久化
36                             IBasicProperties properties = channel.CreateBasicProperties();
37                             properties.DeliveryMode = 2;
38                             channel.BasicPublish("", "MyFirstQueue", properties, bytes);
39
40                             Console.WriteLine("消息已经发送:" + requestMsg.ToString());
41                         }
42                     }
43                 }
44             }
45             catch (Exception ex)
46             {
47                 Console.WriteLine(ex.ToString());
48             }
49             Console.ReadLine();
50         }
51     }
52 }

Server端代码(记得添加 RabbitMQ.Client Nuget包)

 1 using Newtonsoft.Json;
 2 using RabbitMQ.Client;
 3 using RabbitMQ.Client.Events;
 4 using RabbitMqLib;
 5 using System;
 6 using System.Text;
 7
 8 namespace RabbitMqServer
 9 {
10     class Program
11     {
12         static void Main(string[] args)
13         {
14             try
15             {
16                 ConnectionFactory factory = new ConnectionFactory();
17                 factory.HostName = Constants.MqHost;
18                 factory.Port = Constants.MqPort;
19                 factory.UserName = Constants.MqUserName;
20                 factory.Password = Constants.MqPwd;
21                 using (IConnection conn = factory.CreateConnection())
22                 {
23                     using (IModel channel = conn.CreateModel())
24                     {
25                         //在MQ上定义一个持久化队列,如果名称相同不会重复创建
26                         channel.QueueDeclare("MyFirstQueue", true, false, false, null);
27                         //输入1,那如果接收一个消息,但是没有应答,则客户端不会收到下一个消息
28                         channel.BasicQos(0, 1, false);
29                         Console.WriteLine("Listening...");
30                         //在队列上定义一个消费者
31                         QueueingBasicConsumer consumer = new QueueingBasicConsumer(channel);
32                         //消费队列,并设置应答模式为程序主动应答
33                         channel.BasicConsume("MyFirstQueue", false, consumer);
34
35                         while (true)
36                         {
37                             //阻塞函数,获取队列中的消息
38                             BasicDeliverEventArgs ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
39                             byte[] bytes = ea.Body;
40                             string str = Encoding.UTF8.GetString(bytes);
41                             RequestMsg msg = JsonConvert.DeserializeObject<RequestMsg>(str);
42                             Console.WriteLine("HandleMsg:" + msg.ToString());
43                             //回复确认
44                             channel.BasicAck(ea.DeliveryTag, false);
45                         }
46                     }
47                 }
48             }
49             catch (Exception ex)
50             {
51                 Console.WriteLine(ex.ToString());
52             }
53             Console.ReadLine();
54         }
55     }
56 }

客户端显示效果

服务端显示效果

最后还有类库的两个类

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Text;
 5 using System.Threading.Tasks;
 6
 7 namespace RabbitMqLib
 8 {
 9     public static class Constants
10     {
11         public static string MqHost { get; } = "localhost";
12
13         public static int MqPort { get; } = 5672;
14
15         public static string MqPwd { get; } = "guest";
16
17         public static string MqUserName { get; } = "guest";
18     }
19 }
 1 namespace RabbitMqLib
 2 {
 3     public class RequestMsg
 4     {
 5         public string Name { get; set; }
 6
 7         public string Code { get; set; }
 8
 9         public override string ToString()
10         {
11             return $"Name: {Name}, Code: {Code}";
12         }
13     }
14 }

Constants的具体配置可以参考这篇文章

http://www.rabbitmq.com/dotnet-api-guide.html

时间: 2024-12-05 06:00:21

在C#中使用消息队列RabbitMQ的相关文章

消息队列RabbitMQ

消息队列RabbitMQ 一.RabbitMQ是什么? AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计.消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然.AMQP的主要特征是面向消息.队列.路由(包括点对点和发布/订阅).可靠性.安全.RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby..NET.J

消息队列--RabbitMQ(一)

1.消息队列概述 可以理解为保存消息的一个媒介/或者是个容器,与之相关有两个概念(即生产者(Publish)与消费者(Consumer)).所谓生产者,就是生产创造消息的一方,那么,消费者便是从队列中取出消息,完成相应的某种目的.总而言之,消息队列是搭建生产者与消费者沟通的一座桥梁. 消息队列的产品也很多,作用也各有千秋.常见的消息队列有RabbitMQ.RocketMq.KafKa,本系列文章将以(RabbitMQ+C#客户端+Windonw)为例去探索消息队列的基本用途及相关使用.闲话不说,

ASP.NET Core消息队列RabbitMQ基础入门实战演练

一.课程介绍 人生苦短,我用.NET Core!消息队列RabbitMQ大家相比都不陌生,本次分享课程阿笨将给大家分享一下在一般项目中99%都会用到的消息队列MQ的一个实战业务运用场景.本次分享课程不是零基础教学,课程内容的侧重点是讲解的RabbitMQ的最实用.最简单的实战运用场景:Publish/Subscrib(发布/订阅)模式,发送端发送消息,单个接收端接收处理消息. 学完本次"是猴子都看的懂的消息队列RabbitMQ实战课程"后,阿笨带直接让你也能如此优雅简单的上手使用Rab

消息队列rabbitmq的五种工作模式(go语言版本)

前言:如果你对rabbitmq基本概念都不懂,可以移步此篇博文查阅消息队列RabbitMQ 一.单发单收 二.工作队列Work Queue 三.发布/订阅 Publish/Subscribe 四.路由Routing 五.Topic类型的exchange 六.rabbitmq部分封装代码及装备工作 一.单发单收 在下图中,“ P”是我们的生产者,“ C”是我们的消费者.中间的框是一个队列-RabbitMQ代表使用者保留的消息缓冲区. 单发单收模式下:一发一收 发送端只需要创建队列,然后向队列发送消

UCOS中的消息队列并不是真正意义上的队列

UCOS中的消息队列并不是真正意义上的队列,它只是发送了想要发送数据的指针,这个时候,如果发送多个同一个变量的不同数据,那么数据就相当于被覆盖了. 解决办法: 定义一个缓存数组buffer[i]; 更改变量i的数值,就可以实现一个变相的FIFO,因为每次发送的变量的指针是不同的. i++; i %= bufsize; buffer[ ( i + bufsize - 1 ) % bufsize ]; //此处是取的上一个数据,当前数据直接取buffer[i]即可.

python中消息队列RabbitMQ的使用

1,简介 RabbitMQ(Rabbit Message Queue)是流行的开源消息队列系统,用erlang语言开发. 1.1关键词说明: Broker:消息队列服务器实体.Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列.Queue:消息队列载体,每个消息都会被投入到一个或多个队列.Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来.Routing Key:路由关键字,exchange根据这个关键字进行消息投递.vhost:虚拟主机,一个b

(转)(二)RabbitMQ消息队列-RabbitMQ消息队列架构与基本概念

http://blog.csdn.net/super_rd/article/details/70238869 没错我还是没有讲怎么安装和写一个HelloWord,不过快了,这一章我们先了解下RabbitMQ的基本概念. RabbitMQ架构 说是架构其实更像是应用场景下的架构(自己画的有点丑,勿嫌弃) 从图中可以看出RabbitMQ主要由Exchange和Queue两部分组成,然后通过RoutingKey关联起来,消息投递到Exchange然后通过Queue接收. RabbitMQ消息队列基本概

消息队列 RabbitMQ

前言 市面上的消息队列产品有很多,比如老牌的 ActiveMQ.RabbitMQ ,目前我看最火的 Kafka ,还有 ZeroMQ ,阿里巴巴捐赠给 Apache 的 RocketMQ ,连 redis 这样的 NoSQL 数据库也支持 MQ 功能.总之这块知名的产品就有十几种. 什么是rabbitMQ RabbitMQ 是一个由 Erlang 语言开发的 AMQP 的开源实现.一款基于AMQP协议的消息中间件,它能够在应用之间提供可靠的消息传输.在易用性,扩展性,高可用性上表现优秀.而且使用

自动化运维Python系列之消息队列RabbitMQ

RabbitMQ RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消息通讯的世界里有很多公开标准(如 COBAR的 IIOP ,或者是 SOAP 等),但是在异步消息处理中却不是这样,只有大企业有一些商业实现(如微软的 MSMQ ,IBM 的 Websphere MQ 等),因此,在 2006 年的 6 月,Cisco .Redhat.iMatix 等联合制定了 AMQP 的