MSMQ
在多个不同的应用之间实现相互通信的异步传输模式
微软消息队列(MSMQ)是微软开发的异步消息传输技术,支持分布式应用间跨环境的通信,通过将消息存入队列实现生产与消费的解耦。其提供公共队列和私有队列两种类型,支持内存暂存与磁盘持久化传输模式,确保网络中断或系统故障时消息的完整性。MSMQ服务器负责接收、存储和转发消息,支持事务处理、消息排序及安全性控制。该系统支持消息队列4.0与3.0版本,适配Windows Server 2008/R2、Windows Server 2003Windows XP等操作系统。MSMQ适配器集成于BizTalk Server,可配置接收/发送处理程序以实现可靠消息传送。在网络负载均衡环境中,MSMQ支持三种非事务性协议(TCP/OS/HTTP),并需通过注册表调整实现Direct=OS传递。2024年披露的CVE-2024-49122等漏洞涉及远程代码执行风险,需通过补丁修复。在Windows进程激活服务中,NetMsmqActivator基于队列消息触发应用激活,配合netMsmqBinding实现双向通信。MSMQ传输涉及21类异常场景,包含队列配置冲突、序列化错误及事务关联问题。
已知问题
2025年12月,微软Windows 10扩展安全更新补丁存在Bug,导致MSMQ功能瘫痪,受影响系统包括Windows 10 22H2、Windows Server 2019Windows Server 2016,涉及更新补丁编号为KB5071546、KB5071544和KB5071543,症状包括IIS网站频繁弹出“资源不足”错误和虚假警告,即使硬件资源充足,微软正在调查但未给出修复补丁的明确发布时间,管理员可能需回滚更新但面临已知安全漏洞风险。
实质
在消息传递机制中,有两个比较重要的概念。一个是消息,一个是队列。消息是由通信的双方所需要传递的信息,它可以是各式各样的媒体,如文本、声音、图象等等。消息最终的理解方式,为消息传递的双方事先商定,这样做的好处是,一是相当于对数据进行了简单的加密,二则采用自己定义的格式可以节省通信的传递量。消息可以含有发送和接收者的标识,这样只有指定的用户才能看到只传递给他的信息和返回是否操作成功的回执。消息也可以含有时间戳,以便于接收方对某些与时间相关的应用进行处理。消息还可以含有到期时间,它表明如果在指定时间内消息还未到达则作废,这主要应用与时间性关联较为紧密的应用。
消息队列是发送和接收消息的公用存储空间,它可以存在于内存中或者是物理文件中。消息可以以两种方式发送,即快递方式(express)和可恢复模式(recoverable),它们的区别在于,快递方式为了消息的快速传递,把消息放置于内存中,而不放于物理磁盘上,以获取较高的处理能力;可恢复模式在传送过程的每一步骤中,都把消息写入物理磁盘中,以得到较好的故障恢复能力。消息队列可以放置在发送方、接收方所在的机器上,也可以单独放置在另外一台机器上。正是由于消息队列在放置方式上的灵活性,形成了消息传送机制的可靠性。当保存消息队列的机器发生故障而重新启动以后,以可恢复模式发送的消息可以恢复到故障发生之前的状态,而以快递方式发送的消息则丢失了。另一方面,采用消息传递机制,发送方不必要再担心接收方是否启动、是否发生故障等等非必要因素,只要消息成功发送出去,就可以认为处理完成,而实际上对方可能甚至未曾开机,或者实际完成交易时可能已经是第二天了。
作用
采用MSMQ带来的好处是:由于是异步通信,无论是发送方还是接收方都不用等待对方返回成功消息,就可以执行余下的代码,因而大大地提高了事物处理的能力;当信息传送过程中,信息发送机制具有一定功能的故障恢复能力;MSMQ的消息传递机制使得消息通信的双方具有不同的物理平台成为可能。
在微软的.net平台上利用其提供的MSMQ功能,可以轻松创建或者删除消息队列、发送或者接收消息、甚至于对消息队列进行管理。
最新修订时间:2025-12-16 19:30
目录
概述
已知问题
实质
参考资料