當(dāng)客戶端啟動(dòng)到服務(wù)器的 TCP/IP 套接字連接時(shí),客戶端通常連接到服務(wù)器上的特定端口,并請(qǐng)求服務(wù)器通過臨時(shí)(或暫時(shí))TCP 或 UDP 端口進(jìn)行響應(yīng)。在 Windows Server 2003 和 Windows XP 中,客戶端應(yīng)用程序所使用的臨時(shí)端口的默認(rèn)范圍為 1025 到 5000。在某些情況下,有可能耗盡默認(rèn)范圍的可用端口。
TCP/IP 端口耗盡的癥狀隨客戶端應(yīng)用程序的不同而不同,但通常都表現(xiàn)為顯示網(wǎng)絡(luò)連接失敗錯(cuò)誤。若要確定網(wǎng)絡(luò)連接失敗是否是由 TCP/IP 端口耗盡造成的,請(qǐng)?jiān)诳蛻舳擞?jì)算機(jī)上執(zhí)行以下步驟:
在運(yùn)行 Windows XP 或 Windows Server 2003 的計(jì)算機(jī)上單擊“開始”,再單擊“運(yùn)行”,然后鍵入 cmd,單擊“確定”打開命令提示。執(zhí)行以下操作之一:
- 在 Windows XP 或 Windows Server 2003 計(jì)算機(jī)上的命令提示中輸入以下命令,顯示此計(jì)算機(jī)上 TCP/IP 協(xié)議所使用的活動(dòng)連接:netstat -n 這將列出綁定到客戶端計(jì)算機(jī)的 TCP/IP 地址以及 TCP/IP 地址與遠(yuǎn)程服務(wù)器通信所使用的端口。如果列出的端口使用了所有可用的端口,則出現(xiàn)了 TCP/IP 端口耗盡現(xiàn)象。
- 在基于 Windows Server 2003 的客戶端計(jì)算機(jī)的命令提示中輸入以下命令,以顯示 TCP/IP 協(xié)議所使用的活動(dòng)連接:netstat -b 這將列出綁定到客戶端計(jì)算機(jī)的 TCP/IP 地址、TCP/IP 地址與遠(yuǎn)程服務(wù)器通信所使用的端口以及使用這些端口的應(yīng)用程序。此信息可以幫助您確定那個(gè)客戶端應(yīng)用程序正在使用過多的 TCP/IP 端口。
與 TCP/IP 端口耗盡有關(guān)的問題
當(dāng)客戶端應(yīng)用程序嘗試使用 TCP/IP 套接字連接到 BizTalk Server,或當(dāng) BizTalk 應(yīng)用程序嘗試使用 TCP/IP 套接字連接到服務(wù)器時(shí),可能會(huì)出現(xiàn)類似于下面的情況:
- System.Net.WebException: The underlying connection was closed: An unexpected error occurred on a send.Unable to connect to the remote server.
- System.Net.Sockets.SocketException: Only one usage of each socket address (protocol/network address/port) is normally permitted.
當(dāng)出現(xiàn)這些錯(cuò)誤時(shí),還可能出現(xiàn)以下問題:
- 客戶端應(yīng)用程序可能無(wú)法連接到 BizTalk Server。
- BizTalk 應(yīng)用程序服務(wù)可能無(wú)法連接到遠(yuǎn)程 SQL 服務(wù)器。
- BizTalk Server 適配器可能無(wú)法連接到遠(yuǎn)程服務(wù)器。
原因
如果客戶端計(jì)算機(jī)中存在數(shù)目超常的 TCIP/IP 套接字連接,則客戶端計(jì)算機(jī)上可能出現(xiàn) TCP/IP 端口耗盡的情況。當(dāng) TCP/IP 端口耗盡時(shí),將無(wú)法預(yù)留客戶端端口,并且嘗試通過 TCP/IP 套接字連接到服務(wù)器的客戶端應(yīng)用程序也將出錯(cuò)。
客戶端應(yīng)用程序預(yù)留的每個(gè)端口均占用內(nèi)核內(nèi)存。如果預(yù)留了數(shù)目超常的客戶端端口,Windows 內(nèi)核內(nèi)存的占用率將相應(yīng)增加。
解決方法
如果大量客戶端應(yīng)用程序要啟動(dòng)已知數(shù)量的 TCP/IP 套接字連接,但沒有足夠數(shù)量的可用臨時(shí)端口來(lái)滿足連接請(qǐng)求,則需要進(jìn)行以下注冊(cè)表修改。
增加動(dòng)態(tài)分配到客戶端 TCP/IP 套接字連接的臨時(shí)端口的上限。
- 啟動(dòng)注冊(cè)表編輯器。
- 在注冊(cè)表中,瀏覽到并單擊注冊(cè)表項(xiàng) HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters。
- 在“編輯”菜單中單擊“新建”、“DWORD 值”,然后添加注冊(cè)表值,以增加可以動(dòng)態(tài)分配到客戶端的臨時(shí)端口的數(shù)量:
值名稱 MaxUserPort
值數(shù)據(jù) <在此輸入一個(gè) 5000 到 65534 之間的十進(jìn)制值> - 關(guān)閉注冊(cè)表編輯器。
注意:必須重新啟動(dòng)計(jì)算機(jī),此更改才會(huì)生效。增加用于客戶端 TCP/IP 連接的臨時(shí)端口的范圍將占用 Windows 內(nèi)核內(nèi)存。請(qǐng)勿將此設(shè)置的值增加至超過容納客戶端應(yīng)用程序套接字連接所需要的值,以便盡可能降低對(duì) Windows 內(nèi)核內(nèi)存的不必要占用。