栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

.NET/C#大型项目研发必备(12)--使用MQ消息队列

.NET/C#大型项目研发必备(12)--使用MQ消息队列

前言:本系列文章,旨在讲述研发一个中大型项目所需要了解的一系列“基本构件”,并提供这些“基本构件”的【最简单】、【最快速】使用方法!!(并不深究技术原理)
本系列文章适合有初/中级.NET知识的同学阅读。

相关下载:
RabbitMQ消息组件
RabbitMQ消息组件

RabbitMQ作为一款主流的消息队列工具早已广受欢迎。相比于其它的MQ工具,RabbitMQ支持的语言更多、功能更完善。

本文提供一种市面上最/极简单的使用RabbitMQ的方式,只需要会调用以下三个方法,你就几乎可以掌握整个RabbitMQ的使用:
(1) SendMessage,发送一个消息
(2) GetMessage,获取一个消息
(3) UseMessage,使用一个消息(连续使用)

为了调用以上三个方法,首先需要在项目工程中引用DeveloperSharp.RabbitMQ.dll与RabbitMQ.Client.dll两个组件,并在App.config/Web.config里面添加如下配置:

  
    
  

说明:上述配置中分别设置了RabbitMQ应用所在的服务器IP地址hostName、端口port、用户名userName、密码password(请把这四项的对应值修改成你自己那边的RabbitMQ的对应值)

下面,我们给出一个使用了上述SendMessage、GetMessage、UseMessage三个方法的示例。该示例的功能说明如下:

先向RabbitMQ服务器上名为“aa”的队列发送了5个消息,然后从RabbitMQ服务器上的“aa”队列中获取,并打印出第1个消息,最后再连续从RabbitMQ服务器上的“aa”队列中获取剩余4个消息,并把它们写入名为fj.txt的文件。
代码如下:

using DeveloperSharp.RabbitMQ;
--------------------------

        static void Main(string[] args)
        {
            //发送5个消息(使用SendMessage)
            RabbitMQHelper.SendMessage("aa", "世界1,你好!");
            RabbitMQHelper.SendMessage("aa", "世界2,你好!");
            RabbitMQHelper.SendMessage("aa", "世界3,你好!");
            RabbitMQHelper.SendMessage("aa", "世界4,你好!");
            RabbitMQHelper.SendMessage("aa", "世界5,你好!");

            //获取1个消息(使用GetMessage)
            string oneMessage = RabbitMQHelper.GetMessage("aa").Message;
            Console.WriteLine(OneMessage);

            //向fj.txt这个文本文件中写入4个消息(使用UseMessage)
            RabbitMQHelper.UseMessage("aa", t => 
            {
                System.IO.File.AppendAllText("D:/fj.txt", t.Message);
                return true;
            });
        }

运行结果如下:
【控制台显示出】:世界1,你好!
【fj.txt文件中显示出】:世界2,你好!世界3,你好!世界4,你好!世界5,你好!

三个方法的详细功能说明(辅助参考):

(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时,代表当前消息已被有效处理并会被服务器删除。然后程序自动进入下一条消息的使用。
         若Use返回值为false时,代表当前消息未被有效处理但仍会被服务器删除。然后程序自动进入下一条消息的使用。
         若Use返回值为null时,代表当前消息会被服务器重新队列分配到其它可用的实例上再处理。然后程序自动进入下一条消息的使用。
         若Use内部发生未被处理的异常,程序会停止。
    (II)RabbitMQMessage对象定义如下:
          public class RabbitMQMessage
          {
             public string Message;
             public IDictionary Header;
             public string Id; //此处系统自动生成的Id具有UUID的特性。
          }
    (III)RabbitMQMessage.Header字典中,实际值为string类型的object值,需要通过字节转换才能变为字符串。
           例如:Encoding.UTF8.GetString((byte[])p.Header["Content"])

最后说明一点:一旦调用三个方法,会与RabbitMQ服务器建立“长链接”。若要结束“长链接”,可在“任务管理器”中杀死进程。

使用消息服务对解耦分布式系统、实现发布/订阅、提高系统性能、等方面都有巨大用处,相信本文会扩展你的思维认知,让你在相关技术解决方案上有更多灵活思路+联想空间!

【附注】:文章开头给出的下载示例,均已成功运行通过。但下载示例往往只包含“核心模板”内容。有些辅助内容需要自己建立/设置(比如:数据库创建、链接字符串设置、文件配置、路径设置、参数设定、等等…)。
请在理解文章内容的基础上,再做示例实验。若遇异常报错,请仔细阅读+理解本文。
也随时欢迎联系作者,微信扫描文末二维码,获取更多技术支持!

推荐阅读

.NET/C#大型项目研发必备(1)–UUID全球通用唯一识别码.NET/C#大型项目研发必备(2)–跨域访问.NET/C#大型项目研发必备(3)–数据库的负载均衡.NET/C#大型项目研发必备(4)–数据库的读写分离.NET/C#大型项目研发必备(5)–Web服务/WebApi的负载均衡.NET/C#大型项目研发必备(6)–IUtility工具介绍.NET/C#大型项目研发必备(7)–ORM数据库访问技术.NET/C#大型项目研发必备(8)–高效分页.NET/C#大型项目研发必备(9)–http请求调用(Post与Get).NET/C#大型项目研发必备(10)–图片的裁剪、缩放、与加水印.NET/C#大型项目研发必备(11)–使用Redis缓存.NET/C#大型项目研发必备(12)–使用MQ消息队列


如果文章对你有帮助,请点赞、收藏、关注(原创内容,欢迎转载,转载请注明出处)
出处:https://developersharp.blog.csdn.net/
主页:http://www.365ey.net/
【获取专业技术支持,点击下方名片联系作者】

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/720789.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号