文章編號: 925001 - 上次校閱: 2007年11月20日 - 版次: 3.4

FIX: 兩個 SQL Server 2005 之間執行查詢時的錯誤訊息連結伺服器:"登入失敗的使用者 'NT AUTHORITY\ANONYMOUS 登入'"

可以下載 Hotfix下載 Hotfix
檢視和要求下載 hotfix
系統提示本文適用於您使用的作業系統之外的作業系統。與您不相關的文章內容已停用。
注意: # 50000204 (SQL Hotfix)

如 SQL Server 2005 SP1 中相同的問題的更多有關,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
925843? (http://support.microsoft.com/kb/925843/ ) FIX: 錯誤訊息,當您使用伺服器原生 SQL 用戶端提供者來執行查詢 SQL Server 2005 Service Pack 1 中的兩個連結伺服器之間:"登入失敗的使用者 'NT AUTHORITY\ANONYMOUS 登入'"
Microsoft 為一個可下載檔案散佈 Microsoft SQL Server 2005 的修正程式。因為修正程式是累積,每個新版本包含所有 Hotfix 及先前的 SQL Server 2005 隨附所有安全性修正程式都修正發行。

在此頁中

全部展開 | 全部摺疊
在本文所述的問題存在於 SQL Server 2005 和 SQL Server 2005 Service Pack 1 (SP1)。本文只適用於 SQL Server 2005。

本文將告訴您下列關於此 Hotfix 版本:
  • 此 Hotfix 套件所修正的問題
  • 安裝 Hotfix 套件的先決條件
  • 是否您必須重新啟動電腦安裝 Hotfix 套件之後
  • 是否 Hotfix 套件就會取代任何其他 Hotfix 套件
  • 您必須在是否做任何登錄變更
  • 包含在 Hotfix 套件中的檔案

徵狀

使用 SQL Server 原生用戶端 (SQL 原生的用戶端) 執行 SQL Server 2005 的兩個連結電腦之間執行查詢的提供者。您執行這項操作之後您可能會收到下列錯誤訊息:
登入失敗的使用者 ' NT AUTHORITY\ANONYMOUS 登入 '
當您使用 TCP/IP 通訊協定,而且您啟用連結部電腦之間連線的 Kerberos 驗證時,就會發生這個錯誤訊息。

通常,這個錯誤訊息時,工作階段中所有的其他查詢失敗,並且產生相同的錯誤訊息。這種行為持續,直到來源 SQL Server 服務重新啟動。

附註您不能解決這個錯誤訊息,藉由執行 [DBCC FreeSessionCache 陳述式。

發生的原因

因為 SQL 原生用戶端提供者中發生問題,所以會發生這個問題。過早釋放 Kerberos 連線會建立以某些連線模組控點。

解決方案

服務套件資訊

如果要解決這個問題,取得最新的 Service Pack 的 SQL Server 2005。如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
913089? (http://support.microsoft.com/kb/913089/ ) 如何取得最新的 Service Pack,SQL Server 2005 的

Hotfix 資訊

Microsoft 提供支援的 Hotfix。不過,此 Hotfix 旨在修正本文中所述隨問題。只會發生此特定問題的系統套用此 Hotfix。這個 Hotfix 可能會接受額外的測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的軟體更新。

如果此 Hotfix 可供下載,您可在本知識庫文件的頂端找到「 可用的 Hotfix 下載 」區段。如果本節 Does Not Appear 請連絡[ Microsoft 客戶服務 ] 和 [ 支援 ] 以取得此 Hotfix。

附註如果發生其他問題,或如果需要任何疑難排解,您可能必須建立個別的服務要求。和此 Hotfix 無關的額外支援問題適用一般的支援費用。如需 Microsoft 客戶服務支援部門電話號碼的完整清單或要建立個別的服務要求,請造訪下列 Microsoft 網站:
http://support.microsoft.com/contactus/?ws=support (http://support.microsoft.com/contactus/?ws=support)
附註「 下載 Hotfix 」 表單會顯示此 Hotfix 會出現,以供使用的語言。如果您沒有看到您的語言,是因為此 Hotfix 是不適用您的語言。

必要條件

這個 Hotfix 沒有先決條件。

重新啟動資訊

您沒有套用此 Hotfix 之後重新啟動電腦。

登錄資訊

您沒有套用此 Hotfix 之後,變更登錄。

Hotfix 檔案資訊

此 Hotfix 包含只那些檔案所需來修正本文將告訴您的問題。此 Hotfix 並未包含必須將產品完整更新至最新版組建的所有檔案。

此 Hotfix 的英文版在檔案屬性 (或更新版本的檔案屬性) 如下列表格中所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用在 [日期及時間中項目控制台中的 [時區] 索引標籤]。
SQL Server 2005 32 位元版本
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Msvcm80.dll8.0.50727.42479,2322005 年九月 22 日23: 48x86
Msvcp80.dll8.0.50727.42548,8642005 年九月 22 日23: 48x86
Msvcr80.dll8.0.50727.42626,6882005 年九月 22 日23: 48x86
Sqlncli.dll2005.90.1553.02,209,6242006 年九月 6 日01: 32x86
SQL Server 2005 x x64 為主版
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Sqlncli.dll2005.90.1553.03,153,2402006 年九月 6 日14: 00x64
Msvcm80.dll8.0.50727.42516,0962005 年九月 22 日23: 27x64
Msvcp80.dll8.0.50727.421,097,7282005 年九月 22 日23: 28x64
Msvcr80.dll8.0.50727.42822,7842005 年九月 22 日23: 26x64
SQL Server 2005 Itanium 架構版本
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Sqlncli.dll2005.90.1553.05,387,6082006 年九月 6 日08: 41IA 64
Msvcm80.dll8.0.50727.42572,4162005 年九月 22 日23: 29IA 64
Msvcp80.dll8.0.50727.421,385,4722005 年九月 22 日23: 31IA 64
Msvcr80.dll8.0.50727.421,484,8002005 年九月 22 日23: 28IA 64

其他可行方案

若要解決這個問題,請設定連線兩個 SQL Server 之間連結伺服器的 TCP/IP 通訊協定而不是使用具名管道 」 通訊協定。具名管道 」 通訊協定不使用 Kerberos 驗證在 SQL Server 層級。若要進行連線,請依照下列步驟執行:
  1. 請確定具名管道 」 通訊協定已啟用這兩個連結的伺服器上。

    若要判斷兩者是否已啟用具名管道 」 通訊協定連結在命令提示字元執行下列命令,執行 SQL Server 在來源電腦上的伺服器。假設來源伺服器名稱是 Server1,而且目標伺服器名稱是 Server2:
    Sqlcmd –E –Snp:Server2
    如果這個命令失敗、 具名管道 」 通訊協定可能未啟用其中一個或兩個 SQL Server 連結伺服器。若要啟用 [具名管道通訊協定,請使用 SQL Server 組態管理員]。
  2. 如果在步驟 1 中的命令執行成功,遵循下列其中一個步驟執行:
    • 卸除現有的連結的伺服器設定。
    • 建立新的連結的伺服器組態必須使用不同的名稱,並使用具名管道 」 通訊協定。請輸入下列陳述式在 Server1 設定使用具名管道 」 的連結的伺服器上通訊協定連線到
      EXEC sp_addlinkedserver @server='Server2', @srvproduct='', @provider='SQLNCLI', @datasrc='np:Server2', @provstr='Integrated Security=SSPI' 
      Server2。
  3. 開啟 SQL Server 管理 Studio Server1 上,,然後建立新的查詢。在 [查詢] 視窗中針對 Server2 判斷是否使用具名管道 」 通訊協定執行下列的連結的伺服器查詢
    select net_transport, auth_scheme from Server2.master.sys.dm_exec_connections where session_id=@@spid 
    如果正在使用具名管道 」 通訊協定,您會收到
    net_transport		auth_scheme
    -------------		---------------
    Named pipe		NTLM
    
    下列結果。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。 這個問題,首先已經在 Microsoft SQL Server 2005 Service Pack 2 中獲得修正。

其他相關資訊

如 Microsoft SQL Server 更新命名的結構描述的更多有關,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
822499? (http://support.microsoft.com/kb/822499/ ) Microsoft SQL Server 軟體更新套件的新命名結構描述
如需有關軟體更新術語的詳細資訊,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684? (http://support.microsoft.com/kb/824684/ ) 用來描述 Microsoft 軟體更新標準術語的說明

這篇文章中的資訊適用於:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
關鍵字:?
kbmt kbautohotfix kbexpertiseadvanced kbsql2005connect kbhotfixserver kbqfe kbpubtypekc kbfix KB925001 KbMtzh
機器翻譯機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:925001? (http://support.microsoft.com/kb/925001/en-us/ )
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。