English 中文(简体)
Biztalk - how do I set up MSMQ load balancing and high availability?
原标题:

From what I understand, in order to achieve MSMQ load-balancing, one must use a technology such as NLB.

And in order to achieve MSMQ high-availability, one must cluster the related Biztalk Host (and hence the underlying servers have to be in a cluster themselves).

Yet, according to Microsoft Documentation, NLB and FailOver Clustering technologies are not compatible. See this link for reference: http://support.microsoft.com/kb/235305

Can anyone PLEASE explain to me how MSMQ load-balancing and high-availability can be achieved?

thank you in advance,

M

最佳回答

I ve edited my original answer because on reflection, I think I was talking nonsense.

I don t believe that it is possible to achieve both load balancing and high availability in a BizTalk transactional scenario. Have a look at the section "Migration considerations for moving from MSMQ/T to MSMQ adapter in BizTalk 2006" on the following site http://blogs.msdn.com/eldarm/

To summarise that post, there are a couple of scenarios:

High Availability (Non-transactional)

You simply have MSMQ on more than one BizTalk server behind NLB

High Availability (Transactional)

For this you need to have a clustered MSMQ host, which means that you can t do any sort of load balancing upon a single queue.

One possible halfway solution is to create two MSMQ adapters, on different clustered hosts, each handling different queues. Doesn t sound too nice to me though.

A key point is understanding the reasons why you would want transactional, clustered behaviour - you need this for ordered delivery and to ensure no duplicates.


In general I wouldn t go to the trouble of load balancing MSMQ - BizTalk itself is load balanced once messages have reached the MessageBox database. While it is true that you will see asymmetric load due to the queue processing happening on one machine, in the overall context of your BizTalk environment this should not be significant.

Again, it is worth remembering that you are clustering MSMQ for reasons beyond simple high availability:

MSMQ adapter receive handler - MSMQ does not support remote transactional reads; only local transactional reads are supported. The MSMQ adapter receive handler must run in a host instance that is local to the clustered MSMQ service in order to complete local transactional reads with the MSMQ adapter.

That was from the following MSDN page.

I hope this edited answer helps - I don t think it was what you were after, maybe I m wrong and you ll find a workable solution for NLB and transactional MSMQ, but the more I think about it the more it seems that the two scenarios are not compatible.

A final thought is that you could try posting a similar question on Server Fault - you get a few BizTalk devs on Stack Overflow, including at least two MVPs, but at least where I work this is that sort of question I d be passing on to my networking team.

问题回答

暂无回答




相关问题
BizTalk server problem

we have a biztalk server (a virtual one (1!)...) at our company, and an sql server where the data is being kept. Now we have a lot of data traffic. I m talking about hundred of thousands. So I m ...

Create key pair for BizTalk AS2 connection

I need to create an AS2 connection in BizTalk Server 2006 R2 to communicate with a business partner. I ve worked with BizTalk AS2 config before and the BizTalk docs have pretty good walkthroughs about ...

BizTalk mapper and the [ThreadStatic] attribute

I ve recently encountered an issue with the multi-threaded nature of the BizTalk Mapper and how it handles external assemblies. As this quote from MSDN indicates: Important Any code written in an ...

女士们:

我正在分析一项BizTalk(ka orchestration)申请,该申请正在由MSMQ与一个WCF服务机构进行沟通。 我不禁要问,为什么世界气候基金的一个服务执行项目有一个小参数。

热门标签