热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

RabbitMQ.NET消息队列使用详解

这篇文章主要为大家详细介绍了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 ConnectionFactory 
     { 
       HostName = "127.0.0.1", 
       Port = 5672, 
       UserName = "guest", 
       Password = "guest", 
       Protocol = Protocols.DefaultProtocol, 
       AutomaticRecoveryEnabled = true, //自动重连 
       RequestedFrameMax = UInt32.MaxValue, 
       RequestedHeartbeat = UInt16.MaxValue //心跳超时时间 
     }; 
     try 
     { 
       using (var cOnnection= connectionFactory.CreateConnection()) 
       { 
         using (var channel = connection.CreateModel()) 
         { 
           //创建一个新的,持久的交换区 
           channel.ExchangeDeclare("SISOExchange", ExchangeType.Direct, true, false, null); 
           //创建一个新的,持久的队列, 没有排他性,与不自动删除 
           channel.QueueDeclare("SISOqueue", true, false, false, null); 
           // 绑定队列到交换区 
           channel.QueueBind("SISOqueue", "SISOExchange", "optionalRoutingKey"); 
 
           // 设置消息属性 
           var properties = channel.CreateBasicProperties(); 
           properties.DeliveryMode = 2; //消息是持久的,存在并不会受服务器重启影响  
 
           //准备开始推送 
           //发布的消息可以是任何一个(可以被序列化的)字节数组,如序列化对象,一个实体的ID,或只是一个字符串 
           var encoding = new UTF8Encoding(); 
           for (var i = 0; i <10; i++) 
           { 
             var msg = string.Format("这是消息 #{0}&#63;", i + 1); 
             var msgBytes = encoding.GetBytes(msg); 
             //RabbitMQ消息模型的核心思想就是,生产者不把消息直接发送给队列。实际上,生产者在很多情况下都不知道消息是否会被发送到一个队列中。取而代之的是,生产者将消息发送到交换区。交换区是一个非常简单的东西,它一端接受生产者的消息,另一端将他们推送到队列中。交换区必须要明确的指导如何处理它接受到的消息。是放到一个队列中,还是放到多个队列中,亦或是被丢弃。这些规则可以通过交换区的类型来定义。 
             //可用的交换区类型有:direct,topic,headers,fanout。 
             //Exchange:用于接收消息生产者发送的消息,有三种类型的exchange:direct, fanout,topic,不同类型实现了不同的路由算法; 
             //RoutingKey:是RabbitMQ实现路由分发到各个队列的规则,并结合Binging提供于Exchange使用将消息推送入队列; 
             //Queue:是消息队列,可以根据需要定义多个队列,设置队列的属性,比如:消息移除、消息缓存、回调机制等设置,实现与Consumer通信; 
             channel.BasicPublish("SISOExchange", "optionalRoutingKey", properties, msgBytes); 
           } 
           channel.Close(); 
         } 
       } 
     } 
     catch (Exception ex) 
     { 
       Console.WriteLine(ex.Message); 
     } 
 
     Console.WriteLine("消息发布!"); 
     Console.ReadKey(true); 
   } 
 } 

(1)创建消费者类:

class Program 
  { 
    private static void Main() 
    { 
      // 建立RabbitMQ连接和通道 
      var cOnnectionFactory= new ConnectionFactory 
      { 
        HostName = "127.0.0.1", 
        Port = 5672, 
        UserName = "guest", 
        Password = "guest", 
        Protocol = Protocols.AMQP_0_9_1, 
        RequestedFrameMax = UInt32.MaxValue, 
        RequestedHeartbeat = UInt16.MaxValue 
      }; 
 
      using (var cOnnection= connectionFactory.CreateConnection()) 
      using (var channel = connection.CreateModel()) 
      { 
        // 这指示通道不预取超过1个消息 
        channel.BasicQos(0, 1, false); 
 
        //创建一个新的,持久的交换区 
        channel.ExchangeDeclare("SISOExchange", ExchangeType.Direct, true, false, null); 
        //创建一个新的,持久的队列 
        channel.QueueDeclare("sample-queue", true, false, false, null); 
        //绑定队列到交换区 
        channel.QueueBind("SISOqueue", "SISOExchange", "optionalRoutingKey"); 
        using (var subscription = new Subscription(channel, "SISOqueue", false)) 
        { 
          Console.WriteLine("等待消息..."); 
          var encoding = new UTF8Encoding(); 
          while (channel.IsOpen) 
          { 
            BasicDeliverEventArgs eventArgs; 
            var success = subscription.Next(2000, out eventArgs); 
            if (success == false) continue; 
            var msgBytes = eventArgs.Body; 
            var message = encoding.GetString(msgBytes); 
            Console.WriteLine(message); 
            channel.BasicAck(eventArgs.DeliveryTag, false); 
          } 
        } 
      } 
    } 
  } 

消费者--结果如图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 计算机网络复习:第五章 网络层控制平面
    本文探讨了网络层的控制平面,包括转发和路由选择的基本原理。转发在数据平面上实现,通过配置路由器中的转发表完成;而路由选择则在控制平面上进行,涉及路由器中路由表的配置与更新。此外,文章还介绍了ICMP协议、两种控制平面的实现方法、路由选择算法及其分类等内容。 ... [详细]
  • 线性Kalman滤波器在多自由度车辆悬架主动控制中的应用研究
    本文探讨了线性Kalman滤波器(LKF)在不同自由度(2、4、7)的车辆悬架系统中进行主动控制的应用。通过详细的仿真分析,展示了LKF在提升悬架性能方面的潜力,并总结了调参过程中的关键要点。 ... [详细]
  • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 探讨一个显示数字的故障计算器,它支持两种操作:将当前数字乘以2或减去1。本文将详细介绍如何用最少的操作次数将初始值X转换为目标值Y。 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • 深入解析:手把手教你构建决策树算法
    本文详细介绍了机器学习中广泛应用的决策树算法,通过天气数据集的实例演示了ID3和CART算法的手动推导过程。文章长度约2000字,建议阅读时间5分钟。 ... [详细]
author-avatar
wwwmanbj_796_897
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有