MSDTC and Exchange clusters
Over the years, the best practice recommendations on where to place the MS Distributed Transaction Coordinator (MSDTC) resource in Exchange cluster has bounced between two differing views. One camp thought it was unadvisable to place this resource in the cluster group occupied by the quorum resource, while others noted that Exchange doesn't really use DTC and its wasteful to dedicate a whole group (with IP and disk) to this resource.
Let's address this from the bottom up:
Why does Clustered Exchange 200x need a MSDTC resource anyways?
Exchange provides support for a workflow function, and this capability is installed on all Exchange 200x servers by the Exchange setup. This functionality is encapsulated in the CDOWFEVT.DLL binary. This workflow functionality requires various components to be registered with COM+ to function. COM+ requires DTC to be running. And on Clustered Windows, DTC won't initialize unless it's configured for the cluster -- ala MSDTC resource. Perhaps this domino-effect failure is familiar, particularly if you've run into the problem described in KB.312316!
So, does Exchange 200x workflow use MSDTC extensively?
Nope. Essentially just for the setup/upgrade steps, particularly if you've not actively implemented workflow applications.
When, then, do some folks recommend to not put MSDTC into the default cluster group?
KB.168948 says pretty clearly not to put anything in the default cluster group that doesn't need to be there. This is a very important group, and anything placed in this group can contribute to lowered availability of the cluster.
But doesn't the old COMCLUST.EXE program put it there automatically?
Yes. Typically. Unless you follow the wacky steps in KB.290624. This is a big part of what leads to this confusion, because in Windows 2003 you don't use Comclust anymore, instead following the steps in KB.301600 so we see lots of variation with customers here based on which method they followed.
Ok, that makes sense... so why do others say DO put it in that group for Exchange 200x clusters?
Here's where it gets interesting. Consider the characteristics of a typical, real-world Exchange 200x cluster server: heavily-loaded, never enough disk spindles, etc. If you follow this path of recommendations, now all of a sudden you need to add AT LEAST one extra IP, one extra network name, and one extra physical disk. Just to support this MSDTC resource that 99% of Exchange clusters only need for setup/upgrade purposes. If you have to choose between allocating this extra disk spindle to an underutilized MSDTC resource or to an underprovisioned database store LUN, most Exchange design architects will choose the second!
Now, here's the meat of this posting: Microsoft has long advocated the first option (dedicated group/disk/etc for MSDTC) as a best practice, since it maintains the cluster group containing the quorum disk untouched. Pretty much all of the documentation and KBs currently state this position. However, after a bunch of internal discussion and debate, this recommendation has been changed. See the "updated" info at the end of the post for link to the updated Deployment Guide.
So, if you have long ignored this recommendation and placed the MSDTC resource in the cluster group containing the quorum... you're fine. Exchange so minimally utilizes DTC that the performance hit and impact to cluster availability are negligible and generally not worth allocating the additional resources. Put that extra disk toward your Exchange data storage instead (see previous postings here, here, and here for more). Additionally, it is recommended that you remove (uncheck) the option to "Affect the Group" from this MSDTC resource, so that if it does ever fail it will not impact the cluster group containing the quorum resource.
Note that this recommendation change does NOT apply if you are running SQL or some other application that utilizes MSDTC extensively. If your MSDTC is being utilized, you definitely still should keep this resource out of the cluster group containing the quorum to avoid any possible negative effect on cluster availability.
Updated Jan 17, 2005 with two more questions and posted to EHLO:
OK, so – if that is the case – can we take the MSDTC resource offline and keep it that way on our clustered Exchange server?
If you are not using workflow applications on your clustered Exchange server – that is fine, the MSDTC resource can be kept offline. You do need to remember to bring the resource ONLINE though when running Setup of Exchange service packs or hotfixes.
What about deleting the MSDTC resource and then recreating it when having to run Setup?
This has not been tested and therefore we can not recommend it.
Updated again on June 3, 2005:
The Deployment guide has now been revised to include this updated recommendation: https://www.microsoft.com/technet/prodtechnol/exchange/guides/Ex2k3DepGuide/be6c39e1-7432-4a5e-b638-57a7826f13f1.mspx
Comments
- Anonymous
January 01, 2003
The Exchange 2003 Deployment Guide has just been updated (at this link) to reflect the best practice... - Anonymous
January 01, 2003
The Exchange 2003 Deployment Guide has just been updated (at this link) to reflect the best practice... - Anonymous
January 01, 2003
Still catching up on my queue of blog posts, I think that all of the documentation around MSDTC and Exchange... - Anonymous
January 01, 2003
Still catching up on my queue of blog posts, I think that all of the documentation around MSDTC and Exchange... - Anonymous
November 25, 2004
Thx Evan...Great Information!! - Anonymous
November 25, 2004
Thanks for the information, great work ! - Anonymous
November 25, 2004
Finally. I remember having to get an MCS guys involved in answering this one for us. Arguments both ways didn't help at the time. But his information was exactly what you've said here. - Anonymous
November 30, 2004
Thanks for this info,
I'm just building an Exchange Cluster to Migrate our Domino mail over to it. and this is good info on the Clustering
Thanks
Mike - Anonymous
December 05, 2004
At least! great!
Please post the updated KB number here when available