之前提過在Windows 2003上設定MSDTC時需要注意的事項,今天又有新的發現。

依測試結果,當Client與SQL Server分處於不同AD Domain時,可能導致分散式交易失敗。現象是Connection.Open()傳回錯誤訊息: New transaction cannot enlist in the specified transaction coordinator.

問題肇因於MSDTC靠雙向的RPC管道溝通,因此SQL Server所在的主機也要有能力連回Client端,跨Domain的遇到的狀況多半是因DNS不同台導致機器名稱無法解析,因此請確定SQL Server與Client”彼此相識”! 最簡單的測試方法是開個DOS視窗,用ping serverMachineName, ping clientMachineName確認雙方可以用機器名稱解析到對方,當然用DTCPing測試也行,還可以一併測試Firewall等Issue。

如果發現某一方無法解析機器名稱時,最簡單的方法是在windows/system32/drivers/etc/lmhosts(這個檔案預設是不存在的,但可以將lmhosts.sam更名為lmhosts,直接拿來用)裡加上一列如192.168.1.1 myClient的宣告,再下個nbtstat –R,之後ping測試如果OK,問題應該就可解決囉!


Comments

Be the first to post a comment

Post a comment