MSMQ 与ESB

企业应用中,对于面向服务的基础设施体现为ESB, 面向服务的消息机制有一种是One-way, 一种是Request/response, 一种是Pub/sub 这三种模式其实可以同分为两类,同步和异步. 对于异步而言, 可能存在一个很复杂的环境中. 客户端跟服务端需要一个可靠的消息传递机制.他们要解决网络时断时续,机器不能100%可靠等问题.这种传递机制微软的平台是MSMQ, 最近SQL 2005 也提供了个数据库段到数据库段的可靠消息传递机制.SQL Service Broker

MSMQ允许双方在离线的状态下进行通信,且它提供了一整套易于使用的API,并已经集成到了.NET框架中,这一点要比Service Broker好得多。

MSMQ从NT开发就有了,最新版本是4.0,MSMQ 在各个操作系统的对应版本:

MSMQ版本

操作系统

1.0

Windows NT4, Windows 95/98/Me

2.0

Windows 2000

3.0

Windows XP, Windows 2003

4.0

Windows Vista, Windows Server 2008

我们目前的应用一般都是msmq 3.0 ,他有一些特性,比如有触发器, http 转发等特性.对于事务的支持, msmq 支持一下两种类型的事务. 1. 发送消息, 目前可以在不同的机器之间开启一个事务. 可靠的发送消息. 2. 接受消息,目前只支持同一个机器上,不同程序之间的事务中接受消息,这个也是msmq 3.0 的一大不足. 因为这也限制,往往会要求处理程序跟队列在一个机器上.

MSMQ4.0在事务支持方面的得到了改进,它允许在不同的机器之间使用事务来接受消息. 多了一个subqueue,子队列,对多个in order消息的处理改进等

MSMQ 4.0新特性参看http://msdn2.microsoft.com/zh-cn/library/ms701784(en-us).aspx

MSDN Code 上有一个SOA'izing MSMQ with WCF (and Why It's Worth It),是学习WCF和MSMQ的一个我所看到的最好的教程。

ESB使用的消息通信采用MSMQ对于保证消息的可靠性,离线性方面的支持最好的,支持离线通信是任何SOA基础框架都必须考虑的关键部分。

A comprehensive guide to using MsmqIntegrationBinding with MSMQ 3.0 in WCF http://blogs.conchango.com/simonevans/archive/2007/09/17/A-comprehensive-guide-to-using-MsmqIntegrationBinding-with-MSMQ-3.0-in-WCF.aspx

Yoel's Microsoft Message Queue (MSMQ) space http://msmq.spaces.live.com/

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python中文社区

Python爬虫:模拟登录知乎完全详解

專 欄 ❈ sunhaiyu,Python中文社区专栏作者 专栏地址: http://www.jianshu.com/u/4943cb2c6ea4 ❈ 这几天...

7789
来自专栏菩提树下的杨过

elastic-job 新手指南

9014
来自专栏Linyb极客之路

分布式系统唯一ID生成方案汇总

系统唯一ID是我们在设计一个系统的时候常常会遇见的问题,也常常为这个问题而纠结。生成ID的方法有很多,适应不同的场景、需求以及性能要求。所以有些比较复杂的系统会...

2502
来自专栏JavaEdge

项目开发中正确的打日志姿势ERROR:WARNINFO:TRACE

使用slf4j 使用门面模式的日志框架,有利于维护和各个类的日志处理方式统一。 实现方式统一使用: Logback框架 打日志的正确方式 什么时候应该打...

662
来自专栏Albert陈凯

分布式通信的几种方式(EJB、RMI、RPC、JMS、web service杂谈)

http://blog.csdn.net/jiaolong724/article/details/21089347 RPC(remote produce cal...

4808
来自专栏嵌入式程序猿

进入main之前,都干了什么,老实招来

经常有程序猿会说软件上电后从main函数开始执行,其实是不对的,在进入main之前,经历了好多,今天就带你来熟识下IAR环境下,应用软件系统的main函数之前的...

31010
来自专栏c#开发者

asp.net MVC 5 Scaffolding多层架构代码生成向导开源项目(邀请你的参与)

Visual Studio.net 2013 asp.net MVC 5 Scaffolding代码生成向导开源项目 提高开发效率,规范代码编写,最好的方式就是...

3677
来自专栏Java3y

COW奶牛!Copy On Write机制了解一下

触及到知识的盲区了,于是就去搜了一下copy-on-write写时复制这个技术究竟是怎么样的。发现涉及的东西蛮多的,也挺难读懂的。于是就写下这篇笔记来记录一下我...

2173
来自专栏酷玩时刻

微信公众号开发之模板消息

其实这个问题很简单,在【微信公众平台】现在已经可以直接查看自己的公众号都能使用那些接口。

3223
来自专栏瓜大三哥

Auraro UFC(用户流量控制)

UFC 接口是在启用UFC 生成IPCORE 时创建的。UFCs_axi_ufc_tx_tvalid 和TX 侧的s_axi_ufc_tx_tready 端口启...

1673

扫码关注云+社区

领取腾讯云代金券