.Net使用RabbitMQ即时发消息Demo

前言

最近项目要使用RabbitMQ,网上已经有很多优秀的文章了,百度百科对RabbitMQ阐述也非常明确,建议去看下,还有amqp协议。必须一提的是rabbitmq是由LShift提供的一个消息队列协议(AMQP)的开源实现,由以高性能、健壮以及可伸缩性出名的Erlang写成(因此也是继承了这些优点)。

最近参考大神们的博客,自己做了一个RabbitMQ即时发消息的Demo。下面话不多说了,来一起看看详细的介绍吧。

步骤如下:

1.使用VS的NuGet安装包管理工具安装RabbitMQ.Client:

2.生产者端代码:

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.消费者端代码:

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.jb51.net/article/143499.htm

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • rabbitmq(中间消息代理)在python中的使用详解

    在之前的有关线程,进程的博客中,我们介绍了它们各自在同一个程序中的通信方法.但是不同程序,甚至不同编程语言所写的应用软件之间的通信,以前所介绍的线程.进程队列便不再适用了:此种情况便只能使用socket编程了,然而不同程序之间的通信便不再像线程进程之间的那么简单了,要考虑多种情况(比如其中一方断线另一方如何处理:消息群发,多个程序之间的通信等等),如果每遇到一次程序间的通信,便要根据不同情况编写不同的socket,还要维护.完善这个socket这会使得编程人员的工作量大大增加,也使得程序更易崩溃

  • Spring学习笔记3之消息队列(rabbitmq)发送邮件功能

    rabbitmq简介: MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们.消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术.排队指的是应用程序通过 队列来通信.队列的使用除去了接收和发送应用程序同时执行的要求.其中较为成熟的MQ产品有IBM WEBSPHERE MQ. 本节的内容是用户注册时,将邮

  • Spring Boot RabbitMQ 延迟消息实现完整版示例

    概述 曾经去网易面试的时候,面试官问了我一个问题,说 下完订单后,如果用户未支付,需要取消订单,可以怎么做 我当时的回答是,用定时任务扫描DB表即可.面试官不是很满意,提出: 用定时任务无法做到准实时通知,有没有其他办法? 我当时的回答是: 可以用队列,订单下完后,发送一个消息到队列里,并指定过期时间,时间一到,执行回调接口. 面试官听完后,就不再问了.其实我当时的思路是对的,只不过讲的不是很专业而已.专业说法是利用 延迟消息 . 其实用定时任务,确实有点问题,原本业务系统希望10分钟后,如果订

  • Java编程rabbitMQ实现消息的收发

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

  • 利用Python学习RabbitMQ消息队列

    RabbitMQ可以当做一个消息代理,它的核心原理非常简单:即接收和发送消息,可以把它想象成一个邮局:我们把信件放入邮箱,邮递员就会把信件投递到你的收件人处,RabbitMQ就是一个邮箱.邮局.投递员功能综合体,整个过程就是:邮箱接收信件,邮局转发信件,投递员投递信件到达收件人处. RabbitMQ和邮局的主要区别就是RabbitMQ接收.存储和发送的是二进制数据----消息. rabbitmq基本管理命令: 一步启动Erlang node和Rabbit应用:sudo rabbitmq-serv

  • RabbitMQ消息中间件示例详解

    前言 RabbitMQ 是使用 Erlang 语言开发的消息中间件, 其遵循了高级消息队列协议(Advanced Message Queuing Protocol, AMQP). 与 Kafka 等消息队列相比,RabbitMQ 最大的优势在于其较高的可靠性: 提供确认(ACK)和重传机制保证消息完成消费, 消费者异常不会导致消息丢失 提供消息持久化机制, broker 崩溃不会导致消息丢失 集群模式下工作, 保证高可用 因为具有较高可靠性和一致性, RabbitMQ 可以胜任订单处理.秒杀等一

  • 详解Python操作RabbitMQ服务器消息队列的远程结果返回

    先说一下笔者这里的测试环境:Ubuntu14.04 + Python 2.7.4 RabbitMQ服务器 sudo apt-get install rabbitmq-server Python使用RabbitMQ需要Pika库 sudo pip install pika 远程结果返回 消息发送端发送消息出去后没有结果返回.如果只是单纯发送消息,当然没有问题了,但是在实际中,常常会需要接收端将收到的消息进行处理之后,返回给发送端. 处理方法描述:发送端在发送信息前,产生一个接收消息的临时队列,该队

  • RabbitMQ .NET消息队列使用详解

    本文实例为大家分享了RabbitMQ .NET消息队列使用方法,供大家参考,具体内容如下 首先下载安装包,我都环境是win7 64位: 去官网下载 otp_win64_19.0.exe  和rabbitmq-server-3.6.3.exe安装好 然后开始编程了: (1)创建生产者类: class Program { private static void Main() { //建立RabbitMQ连接和通道 var connectionFactory = new ConnectionFacto

  • rabbitmq结合spring实现消息队列优先级的方法

    1.1项目背景:做一个灾情预警的消息平台,灾情检查系统需要向消息平台里面推送消息,这里是典型的异构系统的消息传递,我们需要选择一个中间件作为消息队列,调研分析了rabbitmq,zeromq,activemq,kafka等消息中间件,综合性能,安全,可持久化等角度果断选择了rabbitmq作为我们的消息中间件 (其实这里是因为rabbitmq 是spring官方支持的,开发起来方便).需求上我们有多种类型的消息,这里有紧急推送的和一般的等区分,高并发时,就会有对消息进行优先推送的情况出现,于是r

  • 消息队列 RabbitMQ 与 Spring 整合使用的实例代码

    一.什么是 RabbitMQ RabbitMQ 是实现 AMQP(高级消息队列协议)的消息中间件的一种,最初起源于金融系统,用于在分布式系统中存储转发消息,在易用性.扩展性.高可用性等方面表现不俗.消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然. RabbitMQ 是由 Erlang 语言开发,安装 RabbitMQ 服务需要先安装 Erlang 语言包. 二.如何与 Spring 集成 1. 我们都需要哪些 Jar 包? 抛开单独使用 Spring 的包不说,

随机推荐