关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题

这篇具有很好参考价值的文章主要介绍了关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


前言

提示:大并发请求队列处理及实时聊天消息也可参考本文自行实现

随着大数据的不断发展,我们实际开发的项目也开始逐渐接触到大数据大并发造成的一些问题,由于近期项目需求要满足2000并发量,经过压测发现原项目中编写的正常逻辑读写程序很卡顿,服务器环境Windows Server 2019 32G16核,响应时间需要1-2分钟,造成程序无法正常使用;为解决这一问题,我研究了各种消息队列中间件及缓存队列,Redis、MSMQ、RabbitMQ等,最终选择了微软Windows系统自带的组件“消息队列”(以下简称:MSMQ)快速解决了此问题,本文主要讲述MSMQ的简单应用。

注意:MSMQ只支持Windows操作系统,其他操作系统暂不支持!!!


一、MSMQ是什么?

MicroSoft Message Queuing(微软消息队列)是在多个不同的应用之间实现相互通信的一种异步传输模式,相互通信的应用可以分布于同一台机器上,也可以分布于相连的网络空间中的任一位置。它的实现原理是:消息的发送者把自己想要发送的信息放入一个容器中(我们称之为Message),然后把它保存至一个系统公用空间的消息队列(Message Queue)中;本地或者是异地的消息接收程序再从该队列中取出发给它的消息进行处理。详细描述请参考此链接

二、安装步骤

1.Windows系统

1)首先找到:开始》控制面板》程序》程序和功能》启用或关闭Windows功能。点击打开,如下图:
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
2)勾选好下图圈出功能,点击确定安装。
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
3)安装完成后,可打开计算机管理功能(cmd命令打开方式:compmgmt.msc)查看是否安装成功,安装成功则如下图出现“消息队列”栏,也可在系统服务(cmd命令打开方式:services.msc)中查看是否有名称为“消息队列(Message Queuing)”服务正在运行。
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题

2.Windows Server系统

1)首先打开:服务器管理器,找到 管理》添加角色和功能》功能》消息队列,全选“消息队列”下所有功能,“下一页”》“安装”,如下图:
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
2)安装完成后,可打开计算机管理功能(cmd命令打开方式:compmgmt.msc)查看是否安装成功,安装成功则如下图出现“消息队列”栏,也可在系统服务(cmd命令打开方式:services.msc)中查看是否有名称为“Message Queuing(消息队列)”服务正在运行(同上面Windows操作方式)。
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题

三、使用步骤

1.引入库

首先新建类“MessageHandle”,搜索并引用系统dll程序集:System.Messaging,如下图:
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题

2.封装读写消息类

插入以下封装好的代码到刚建的类“MessageHandle”:

	/// <summary>
    /// 消息处理类
    /// </summary>
    public class MessageHandle
    {
        /// <summary>
        /// 判断队列是否存在
        /// </summary>
        /// <param name="name">队列名称</param>
        public static bool ExistsQueue(string name)
        {
            if (System.Messaging.MessageQueue.Exists(".\\private$\\" + name))//检查是否已经存在同名的消息队列
            {
                return true;
            }
            else
            {
                return false;
            }
        }

        /// <summary>
        /// 创建队列
        /// </summary>
        /// <param name="name">队列名称</param>
        public static string CreateNewQueue(string name)
        {
            if (!ExistsQueue(name))//检查是否已经存在同名的消息队列
            {
                System.Messaging.MessageQueue mq = System.Messaging.MessageQueue.Create(".\\private$\\" + name);
                mq.Label = name;
                return name + " 创建成功";
            }
            else
            {
                return "已经存在";
            }
        }

        /// <summary>
        /// 删除队列
        /// </summary>
        /// <param name="name">队列名称</param>
        public static string DeleteQueue(string name)
        {
            if (ExistsQueue(name))//检查是否已经存在同名的消息队列
            {
                System.Messaging.MessageQueue.Delete(".\\private$\\" + name);
                return name + " 删除成功";
            }
            else
            {
                return "不存在,无需删除";
            }
        }

        /// <summary>
        /// 同步发送消息
        /// </summary>
        /// <param name="input">发送的内容</param>
        /// <param name="queueName">发送到哪个消息队列中</param>
        public static void SendMsg(string input, string queueName)
        {
            CreateNewQueue(queueName);//先创建队列,避免无此队列时报错
            System.Messaging.MessageQueue mq = new System.Messaging.MessageQueue(".\\private$\\" + queueName);
            System.Messaging.Message message = new System.Messaging.Message();
            message.Body = input;
            message.Formatter = new System.Messaging.XmlMessageFormatter(new Type[] { typeof(string) });
            mq.Send(message);
        }

        /// <summary>
        /// 同步接收消息
        /// </summary>
        /// <param name="queueName">从哪个消息队列读取消息</param>
        /// <returns>返回读取到的消息内容字符串</returns>
        public static string ReceiveMsg(string queueName)
        {
            System.Messaging.MessageQueue mq = new System.Messaging.MessageQueue(".\\private$\\" + queueName);
            if (mq.GetAllMessages().Length == 0)//判断是否还有消息,如果没有消息的话Receive方法会一直独占进程直到有消息为止,所以必须判断
            {
                return null;
            }
            else
            {
                System.Messaging.Message m = mq.Receive();
                m.Formatter = new System.Messaging.XmlMessageFormatter(new Type[] { typeof(string) });
                return m.Body.ToString();
            }
        }
    }

其他用法及扩展请参考微软官方示例:点击进入 MessageQueue 类

3.发送业务消息数据到队列

1)根据自己业务需求,如果业务有多字段内容时可封装消息内容到实体(如下代码类),后续再把实体对象转换为json字符串发送到队列;如果业务只有一个字段,可直接使用string,无需封装实体。

	/// <summary>
    /// 消息队列使用的消息内容类(可自行封装其他业务类或直接用字符串)
    /// </summary>
    public class MQ_msgdata
    {
        /// <summary>
        /// 用户id
        /// </summary>
        public int UserId { get; set; }
        /// <summary>
        /// 数据内容
        /// </summary>
        public string Msg{ get; set; }
    }

2)组装消息内容发送到“TestMQ”队列,如下代码:

#region 添加业务请求内容到消息队列异步处理
#region 组装消息内容实体
	MQ_msgdata mQMsg = new MQ_msgdata();
	mQMsg.UserId = 1;
	mQMsg.Msg= "测试消息内容";
#endregion

	string mqMsg = Newtonsoft.Json.JsonConvert.SerializeObject(mQMsg);//转json字符串(此处不一定要封装到对象再转json字符串存储,可根据业务需要直接存储字符串内容,如下一行注释代码)
	//string mqMsg = "测试消息内容";//字符串内容
	string qname = "TestMQ";//队列名称(可自行定义队列命名规则)
	MessageHandle.SendMsg(mqMsg, qname);//发送消息(内部已有创建队列逻辑)
#endregion

4.接收队列中的业务消息数据并处理

1)创建一个控制台应用程序(也可是其他定时任务程序,可根据自己业务需求选择),配置好自己业务需要的其他配置,此处就不讲解了(如数据库连接、缓存、公用库等),然后打开Program.cs类。
注意:这个程序要引用之前封装的消息处理类“MessageHandle”,或能调用此类,或直接拷贝此类到这个新建程序里,供使用!
关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题
2)拷贝以下代码到Main入口,以接收前面业务程序发送到队列“TestMQ”的消息。
注意:HandleData需要自己根据自己业务需求写自己的业务处理逻辑代码,前面的msg即为业务发送的消息内容字符串,如果是json字符串则需要解析成实体对象。

	//控制台程序入口
	static void Main(string[] args)
        {
            Console.WriteLine("消息队列处理已启动");
            string _qname = "TestMQ";//队列名称(与前面发送消息创建的队列名称要一致)
            if (!MessageHandle.ExistsQueue(_qname))
            {//判断队列是否存在
                Console.WriteLine("开始创建【" + _qname + "】消息队列");
                MessageHandle.CreateNewQueue(_qname);//创建队列
                Console.WriteLine("【" + _qname + "】创建完成");
            }
            Task.Run(async () =>
            {
                Console.WriteLine("【" + _qname + "】开始接收…");
                while (true)
                {//循环一直接收
                    #region 处理接收数据
                    string msg = MessageHandle.ReceiveMsg(_qname);//获取此队列中的消息
                    if (!string.IsNullOrWhiteSpace(msg))
                    {//空消息过滤
                        Console.WriteLine("【" + _qname + "】在【" + DateTime.Now + "】收到队列消息:{0}", msg);
                    	//MQ_msgdata modelmsg = Newtonsoft.Json.JsonConvert.DeserializeObject<MQ_msgdata>(msg);//json字符串解析为实体对象
                        HandleData(_qname, msg);//处理数据(自行解析msg内容根据业务再处理存库等)
                    }
                    #endregion
                }
            });
            Console.Read();
        }

3)运行上面的控制台程序即可开始实时接收处理前面发送的业务消息了。


总结

注意:消息发送和消息接收是异步的,发送了一条,未接收(消耗)的情况下,消息是一直存在队列中的,直到被接收(消耗)处理。
以上就是今天要讲的内容,本文仅仅简单介绍MSMQ的基本应用,大家可以根据自己的业务需要灵活运用,有不清楚的或不对的可评论留言,看即回!文章来源地址https://www.toymoban.com/news/detail-458845.html

到了这里,关于关于MSMQ(System.Messaging.MessageQueue)安装及在.NET Framework框架下的简单应用实现,以解决大并发请求问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • .NET6 System.Drawing.Common 通用解决办法

            最近有不少小伙伴在升级 .NET 6 时遇到了 System.Drawing.Common 的问题,同时很多库的依赖还都是 System.Drawing.Common ,而 .NET 6 默认情况下只在 Windows 上支持使用,Linux 上默认不支持这就导致在 Linux 环境上使用会有问题,所以介绍下 .NET 6 中 Linux 上使用System.Drawing.Commo

    2024年02月12日
    浏览(21)
  • .NET Core 使用 System.Threading.Channels消息队列

    System.Threading.Channels 是 .NET Core 中的一个新的同步通信机制,它提供了一种高效的方法来在多个线程之间共享数据。它比使用锁或信号量等传统同步机制更灵活、更高效,并且可以帮助您避免许多并发问题。下面是一个简单的示例,演示如何使用 Channels 实现生产者-消费者模型

    2024年02月06日
    浏览(32)
  • .NET6.0 System.Drawing.Common 通用解决办法

            最近有不少小伙伴在升级 .NET 6 时遇到了 System.Drawing.Common 的问题,同时很多库的依赖还都是 System.Drawing.Common ,而 .NET 6 默认情况下只在 Windows 上支持使用,Linux 上默认不支持这就导致在 Linux 环境上使用会有问题,所以介绍下 .NET 6 中 Linux 上使用System.Drawing.Commo

    2024年02月11日
    浏览(23)
  • Mac安装配置typescript及在VSCode上运行ts

    测试一下:出现Version则证明安装成功 新建一个xxx.ts文件,测试能否运行   运行报错:ts-node: command not found 再安装ts-node   运行报错:TypeError [ERR_UNKNOWN_FILE_EXTENSION]: Unknown file extension \\\".ts\\\"  在终端上输入 显示创建了一个tsconfig.json文件 修改文件 加上\\\"ts-node\\\": {\\\"esm\\\": true}, 注意不要

    2024年01月18日
    浏览(34)
  • .net 6 C#中System.IO.Path类的用法

    2024年04月22日
    浏览(21)
  • .Net 加密解密组件工具类 System.Security.Cryptography.Algorith

            在.NET Framework出现之前,如果我们需要进行加密的话,我们只有各种较底层的技术可以选择,如Microsoft Crypto API、Crypto++、Openssl等等,其用法相当复杂。而在 .NET Framework中,这些复杂内容(原来独立的API和SDK)已经被封装合并在一个.NET框架类中,这对于程序开发人员

    2024年02月04日
    浏览(27)
  • Microsoft Message Queue(MSMQ:微软消息队列)简介

    最近在安装公司的一个产品时,接触到了MSMQ,在此对MSMQ做一个简单的介绍,以便各位能对它有一个快速、直观的认识。本文针对于Microsoft Message Queue,以下提到的消息队列均指代Microsoft Message Queue。 2.1、消息队列是什么 MSMQ是一个Windows上的功能。主要用于多个应用之间实现相

    2024年02月09日
    浏览(42)
  • Node.js安装教程及在vscode中的配置(超详细)

    超详细的Node. js安装教程及在vscode中的配置 如果教程中出现了错误或者有其他问题,欢迎指正,我会积极改正的,希望能帮到你们。 一、Node . js 下载安装教程 1、下载安装 进入nodejs官网,下载18.15.0长期维护版。 下载网址链接:Node.js (nodejs.org)​​​​​​   2、下载后双击

    2024年02月03日
    浏览(40)
  • System.Net.WebException:“请求被中止: 未能创建 SSL/TLS 安全通道。”

    一、问题描述 当使用 HttpWebRequest.GetResponse() 方法进行 HTTPS 请求时,有可能会出现 System.Net.WebException: 请求被中止: 未能创建 SSL/TLS 安全通道的异常,这通常是因为客户端和服务器之间的 TLS 版本不兼容造成的。 二、解决方案 1.指定 TLS 版本 :可以通过在代码中设置 ServicePoin

    2024年02月11日
    浏览(27)
  • System.Net.WebException: 请求被中止: 未能创建 SSL/TLS 安全通道。

    System.Net.WebException: 请求被中止: 未能创建 SSL/TLS 安全通道。 客户端执行https请求时,报出“System.Net.WebException: 请求被中止: 未能创建 SSL/TLS 安全通道。”的问题。原因是:服务端更改了安全协议,而执行的客户端并未注册该协议。 如果客户端的.net framework版本低于4.0,协议类

    2024年02月04日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包