翼度科技»论坛 编程开发 .net 查看内容

.NET为什么推荐它作为RabbitMQ消息队列的首选开发工具

7

主题

7

帖子

21

积分

新手上路

Rank: 1

积分
21
支持.Net Core(2.0及以上)/.Net Framework(4.5及以上),可以部署在Docker, Windows, Linux, Mac。
RabbitMQ作为一款主流的消息队列工具早已广受欢迎。相比于其它的MQ工具,RabbitMQ支持的语言更多、功能更完善。
 
本文提供一种市面上最/极简单的使用RabbitMQ的方式,只需要会调用以下三个方法,你就几乎可以掌握整个RabbitMQ的使用:
(1)SendMessage,发送一个消息
(2)GetMessage,获取一个消息
(3)UseMessage,使用一个消息(连续使用)
 
为了调用以上三个方法,首先需要从NuGet引用DeveloperSharp.RabbitMQ包,并在App.config/Web.config里面添加如下配置(.NET6 / VS2022中已有App.config这个单项添加):
  1.   <appSettings>
  2.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  3.   </appSettings>
复制代码
说明:上述配置中分别设置了RabbitMQ应用所在的服务器IP地址hostName、端口port、用户名userName、密码password(请把这四项的对应值修改成你自己那边的RabbitMQ的对应值)
 
下面,我们给出一个使用了上述SendMessage、GetMessage、UseMessage三个方法的示例。该示例的功能说明如下:

  • 先向RabbitMQ服务器上名为“aa”的队列发送了5个消息,
  • 然后从RabbitMQ服务器上的“aa”队列中获取,并打印出第1个消息,
  • 最后再连续从RabbitMQ服务器上的“aa”队列中获取剩余4个消息,并把它们写入名为fj.txt的文件。
代码如下:
  1. using DeveloperSharp.RabbitMQ;--------------------------  <appSettings>
  2.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  3.   </appSettings>static void Main(string[] args)  <appSettings>
  4.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  5.   </appSettings>{  <appSettings>
  6.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  7.   </appSettings>    //发送5个消息(使用SendMessage)  <appSettings>
  8.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  9.   </appSettings>    RabbitMQHelper.SendMessage("aa", "世界1,你好!");  <appSettings>
  10.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  11.   </appSettings>    RabbitMQHelper.SendMessage("aa", "世界2,你好!");  <appSettings>
  12.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  13.   </appSettings>    RabbitMQHelper.SendMessage("aa", "世界3,你好!");  <appSettings>
  14.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  15.   </appSettings>    RabbitMQHelper.SendMessage("aa", "世界4,你好!");  <appSettings>
  16.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  17.   </appSettings>    RabbitMQHelper.SendMessage("aa", "世界5,你好!");  <appSettings>
  18.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  19.   </appSettings>    //获取1个消息(使用GetMessage)  <appSettings>
  20.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  21.   </appSettings>    string OneMessage = RabbitMQHelper.GetMessage("aa").Message;  <appSettings>
  22.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  23.   </appSettings>    Console.WriteLine(OneMessage);  <appSettings>
  24.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  25.   </appSettings>    //向fj.txt这个文本文件中写入剩余的4个消息(使用UseMessage)  <appSettings>
  26.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  27.   </appSettings>    RabbitMQHelper.UseMessage("aa", t =>  <appSettings>
  28.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  29.   </appSettings>     {  <appSettings>
  30.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  31.   </appSettings>  <appSettings>
  32.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  33.   </appSettings>System.IO.File.AppendAllText("D:/fj.txt", t.Message);  <appSettings>
  34.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  35.   </appSettings>  <appSettings>
  36.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  37.   </appSettings>return true;  <appSettings>
  38.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  39.   </appSettings>    });  <appSettings>
  40.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  41.   </appSettings>}
复制代码
 
运行结果如下:
【控制台显示出】:世界1,你好!
【fj.txt文件中显示出】:世界2,你好!世界3,你好!世界4,你好!世界5,你好!
 
三个方法的详细功能说明(辅助参考):
  1. (1)发送一个消息void SendMessage(string QueueName, string Message, Dictionary Header = null)(2)获取一个消息RabbitMQMessage GetMessage(string QueueName)(3)使用一个消息(连续使用)void UseMessage(string QueueName, Func Use)附加说明:    (I)Use返回值为true时,代表当前消息已被有效处理并会被服务器删除。然后程序自动进入下一条消息的使用。  <appSettings>
  2.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  3.   </appSettings> 若Use返回值为false时,代表当前消息未被有效处理但仍会被服务器删除。然后程序自动进入下一条消息的使用。  <appSettings>
  4.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  5.   </appSettings> 若Use返回值为null时,代表当前消息会被服务器重新队列分配到其它可用的实例上再处理。然后程序自动进入下一条消息的使用。  <appSettings>
  6.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  7.   </appSettings> 若Use内部发生未被处理的异常,程序会停止。    (II)RabbitMQMessage对象定义如下:  <appSettings>
  8.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  9.   </appSettings>  public class RabbitMQMessage  <appSettings>
  10.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  11.   </appSettings>  {  <appSettings>
  12.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  13.   </appSettings>     public string Message;  <appSettings>
  14.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  15.   </appSettings>     public IDictionary Header;  <appSettings>
  16.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  17.   </appSettings>     public string Id; //此处系统自动生成的Id具有分布式唯一Id的特性。  <appSettings>
  18.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  19.   </appSettings>  }
复制代码
  
延时队列&死信队列
有些场景下,我们希望为使用的消息设定有效期。在有效期内,这些消息有效可用;但过期后,这些消息将变得无效不可用,同时,它们还将自动被丢弃进一个称之为“死信”的队列。
为了说明这些概念,我们还是来举一个具体的例子。该例子的功能说明如下:

  • 首先,在RabbitMQ服务器上定义一个名为"bbq"、且其中存放的消息会在60秒后过期失效的队列。
  • 然后,在RabbitMQ服务器上获取与"bbq"队列对应的【死信队列】。并连续从该【死信队列】中获取消息并把它们写入名为BB.txt的文件。
  • 最后,向RabbitMQ服务器上的"bbq"队列发送3个消息。
代码如下:
  1. using DeveloperSharp.RabbitMQ;//从NuGet引用DeveloperSharp.RabbitMQ包--------------------------  <appSettings>
  2.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  3.   </appSettings>    //定义bbq队列,其中存放的消息会在60秒后过期  <appSettings>
  4.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  5.   </appSettings>    var myQ = RabbitMQHelper.SetQueue("bbq", 60000);  <appSettings>
  6.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  7.   </appSettings>    //获取与bbq队列对应的【死信队列】  <appSettings>
  8.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  9.   </appSettings>    var expQ = RabbitMQHelper.GetQueue("bbq");  <appSettings>
  10.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  11.   </appSettings>    //向BB.txt这个文本文件中连续写入【死信队列】中的消息  <appSettings>
  12.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  13.   </appSettings>    expQ.UseMessage(t =>  <appSettings>
  14.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  15.   </appSettings>    {  <appSettings>
  16.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  17.   </appSettings>  <appSettings>
  18.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  19.   </appSettings>System.IO.File.AppendAllText("D:/BB.txt", t.Message);  <appSettings>
  20.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  21.   </appSettings>  <appSettings>
  22.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  23.   </appSettings>return true;  <appSettings>
  24.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  25.   </appSettings>    });  <appSettings>
  26.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  27.   </appSettings>    //向bbq队列发送3个消息  <appSettings>
  28.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  29.   </appSettings>    myQ.SendMessage("jinA");  <appSettings>
  30.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  31.   </appSettings>    myQ.SendMessage("jinB");  <appSettings>
  32.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  33.   </appSettings>    myQ.SendMessage("jinC");  <appSettings>
  34.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  35.   </appSettings>    /*  <appSettings>
  36.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  37.   </appSettings>    //【附加题】:若去掉注释让此语句执行,【死信队列】中将不会获得消息(为啥?自己推理)  <appSettings>
  38.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  39.   </appSettings>    RabbitMQHelper.UseMessage("bbq", t =>  <appSettings>
  40.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  41.   </appSettings>    {  <appSettings>
  42.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  43.   </appSettings>  <appSettings>
  44.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  45.   </appSettings>return true;//若此处返回false,【死信队列】将会获得消息  <appSettings>
  46.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  47.   </appSettings>    });  <appSettings>
  48.     <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,port=5672,userName=sa,password=aevin.gang" />
  49.   </appSettings>    */
复制代码
运行以上程序:
60秒之内,【BB.txt文件】中没有内容
60秒以后,【BB.txt文件】中显示出:jinAjinBjinC
 
通过以上例子,我们可简单预测一下,延时队列&死信队列常用在“限时消费”、“过期处理”等场景。生活中最常见示例如:订单请在10分钟内支付完毕、等等之类功能...
 
使用消息服务对解耦分布式系统、实现发布/订阅、提高系统性能、等方面都有巨大用处,相信本文会扩展你的思维认知,让你在相关技术解决方案上有更多灵活思路+联想空间!
运行有问题,需要技术支持?请添加微信:894988403
运行有问题,需要技术支持?请添加微信:894988403
服务条款:http://www.developersharp.cc/buy.html
 


来源:https://www.cnblogs.com/dotnet-college/archive/2023/02/14/17119041.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具