MS-SQLSERVER中的MSDTC不可用解決方法

qq34352631發表於2009-09-10
今天在本地機直接在觸發器裡更新另一臺伺服器資料時出現: MSDTC不可用解決辦法: 在windows控制面版--&gt管理工具--&gt服務--&gtDistributed Transaction Coordinator--&gt屬性--&gt啟動[@more@]

今天在本地機直接在觸發器裡更新另一臺伺服器資料時出現: MSDTC不可用解決辦法: 在windows控制面版--&gt管理工具--&gt服務--&gtDistributed Transaction Coordinator--&gt屬性--&gt啟動

分析

1. A.不用事務,光用SELECT 語句.是否可以分散式查詢?

B.LINKSERVER 在做分散式更新事務時不能對本機操作.(就是不能環回分散式事務)

C.DBCC TRACEON (3604, 7300)--用跟蹤看更詳細錯誤資訊.

D.下載MS提供的DTCPing.exe 分裝在兩臺機上,按README說明來執行它.看出錯資訊.

2. 兩臺機的MSDTC是否都開啟了.

3. MSDTC設定是否正確.

1).開啟命令提示,執行"net stop msdtc",然後執行"net start msdtc"。 (透過本條解決了問題)

2).轉至"元件服務管理工具"。

3).瀏覽至"啟動管理工具"。

4).選擇"元件服務"。

a.展開"元件服務"樹,然後展開"我的電腦"。

b.右鍵單擊"我的電腦",然後選擇"屬性"。

c.在MSDTC選項卡中,確保選中了下列選項: 網路 DTC 訪問 網路管理 網路事務 XA 事務 e.另外,"DTC登入帳戶"一定要設定為"NT AuthorityNetworkService"。

5).單擊"確定"。這樣將會提示您"MS DTC 將會停止並重新啟動。 所有的依賴服務將被停止。請按'是'繼續"。單擊"是"繼續。

6).單擊"確定"關閉"我的電腦"屬性視窗。

4. MSDTC依賴於RPC,RPC使用的埠是135,測試135埠是否開啟.是否有防火牆?如果有先關了防火牆. telnet IP 135 如果是關閉的開啟它.

5. 有的機由於各種原因,SQLOLEDB不能使用分散式事務,更改為"MSDASQL" 的ODBC方式聯接. 使用RRAS而不是RAS.(控制面版--管理工具--遠端服務管理器) Check whether you are using Remote Access Server (RAS) to access remote servers. If so, make sure that you have implemented Routing RAS (RRAS). Linked server does not work on RAS because RAS allows only one way communication.

6.檢查你的兩臺伺服器是否在同一個域中. 如果不在同一個域中,是否建立可信任聯接.

7.如果是WIN2000,升級到SP4

8.升級MDAC到2.6以上,最好是2.8.

9.要安裝SQL的最新補丁: sp3a

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7646028/viewspace-1026829/,如需轉載,請註明出處,否則將追究法律責任。

相關文章