FIX: 「 記錄讀取器代理程式 」 可能會造成 17883 錯誤訊息

文章翻譯 文章翻譯
文章編號: 867878 - 檢視此文章適用的產品。
Bug #: 471610 (SHILOH_BUGS)
Microsoft SQL Server 2000 的修正程式的發送是一個可下載的檔案。由於此修正程式是累積,每個新版本包含所有 Hotfix,隨附先前的 SQL Server 2000 所有安全性修正程式都修正發行。
全部展開 | 全部摺疊

在此頁中

徵狀

「 記錄讀取器代理程式 」 可能會造成 17883 錯誤訊息。這些 17883 錯誤訊息可能會造成程式停止回應的 SQL Server 執行個體:
錯誤: 17883,嚴重性: 1,狀態: 0
伺服器處理序 162:0 (0) 將非傳送排程器 1 上似乎 UMS 內容 0x11DE8B68。
若要決定是否發生這個問題,檢視小量傾印檔案由的 17883 錯誤訊息所產生的然後搜尋 IsXactStartValid 函式。如果您執行找到 IsXactStartValid 函式,比較從您的小量傾印檔案堆疊,以在 < 其他相關資訊 > 一節中記下 [記錄讀取器 offender 執行緒堆疊。如果堆疊符合,發生這個問題。

解決方案

服務套件資訊

如果要解決這個問題,取得最新的 Service Pack,Microsoft SQL Server 2000。如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
290211如何取得最新的 SQL Server 2000 Service Pack

Hotfix 資訊

此 Hotfix 的英文版在檔案屬性 (或更新版本的檔案屬性) 如下列表格中所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。
   Date         Time   Version            Size    File name
   ----------------------------------------------------------------------
   19-Jun-2004  00:51  2000.80.952.0     664,128  Autoplt.dll      
   19-Jun-2004  00:51  2000.80.952.0      78,400  Console.exe      
   19-Jun-2004  00:51  2000.80.952.0     315,968  Custtask.dll     
   19-Jun-2004  00:51  2000.80.952.0      33,340  Dbmslpcn.dll     
   08-Apr-2004  21:42                    786,432  Distmdl.ldf
   08-Apr-2004  21:42                  2,359,296  Distmdl.mdf
   10-Oct-2003  18:48                        180  Drop_repl_hotfix.sql
   19-Jun-2004  00:51  2000.80.952.0   1,905,216  Dtspkg.dll       
   19-Jun-2004  00:52  2000.80.952.0     528,960  Dtspump.dll      
   19-Jun-2004  00:52  2000.80.952.0   1,557,052  Dtsui.dll        
   19-Jun-2004  00:52  2000.80.952.0     639,552  Dtswiz.dll       
   10-Oct-2003  18:48                    747,927  Instdist.sql
   10-Oct-2003  18:48                      1,581  Inst_repl_hotfix.sql
   19-Jun-2004  00:51  2000.80.952.0     352,828  Isqlw.exe        
   19-Jun-2004  00:51  2000.80.952.0      82,492  Itwiz.exe        
   19-Jun-2004  00:52  2000.80.952.0      90,692  Msgprox.dll      
   19-May-2004  23:43  8.11.40209.0      209,408  Mssdi98.dll      
   19-Jun-2004  00:52  2000.80.952.0      62,024  Odsole70.dll     
   19-Jun-2004  00:52  2000.80.952.0      25,144  Opends60.dll     
   19-Jun-2004  00:51  2000.80.952.0      57,904  Osql.exe         
   19-Jun-2004  00:52  2000.80.952.0     279,104  Pfutil80.dll     
   10-Oct-2003  18:37                    550,780  Procsyst.sql
   08-Apr-2004  21:42                     12,305  Qfe469315.sql
   08-Apr-2004  21:42                     19,195  Qfe469571.sql
   15-Jun-2004  18:11                  1,105,167  Replmerg.sql
   19-Jun-2004  00:52  2000.80.952.0     221,768  Replprov.dll     
   19-Jun-2004  00:52  2000.80.952.0     307,784  Replrec.dll      
   15-Jun-2004  15:43  2000.80.952.0     159,813  Replres.rll
   10-Oct-2003  18:48                  1,087,150  Replsys.sql
   10-Oct-2003  18:48                    986,603  Repltran.sql
   19-Jun-2004  00:52  2000.80.952.0     287,304  Rinitcom.dll     
   19-Jun-2004  00:52  2000.80.952.0      78,416  Sdiclnt.dll      
   19-Jun-2004  00:52  2000.80.952.0      66,112  Semmap.dll       
   19-Jun-2004  00:52  2000.80.952.0      57,916  Semnt.dll        
   19-Jun-2004  00:52  2000.80.952.0     492,096  Semobj.dll       
   15-Jun-2004  16:18  2000.80.952.0     172,032  Semobj.rll
   19-Jun-2004  00:51  2000.80.952.0      53,832  Snapshot.exe     
   12-Mar-2004  03:10                    117,834  Sp3_serv_uni.sql
   19-Jun-2004  00:51  2000.80.952.0      28,672  Sqlagent.dll     
   19-Jun-2004  00:51  2000.80.952.0     311,872  Sqlagent.exe     
   19-Jun-2004  00:51  2000.80.952.0     168,001  Sqlakw32.dll     
   19-Jun-2004  00:52  2000.80.952.0      33,344  Sqlctr80.dll     
   19-Jun-2004  00:52  2000.80.952.0   4,215,360  Sqldmo.dll       
   19-Jun-2004  00:51                     25,172  Sqldumper.exe    
   15-Jun-2004  15:26  2000.80.952.0      28,672  Sqlevn70.rll
   19-Jun-2004  00:52  2000.80.952.0     180,792  Sqlmap70.dll     
   19-Jun-2004  00:52  2000.80.952.0     188,992  Sqlmmc.dll       
   15-Jun-2004  16:25  2000.80.952.0     479,232  Sqlmmc.rll
   19-Jun-2004  00:52  2000.80.952.0     401,984  Sqlqry.dll       
   19-Jun-2004  00:52  2000.80.952.0      57,920  Sqlrepss.dll     
   19-Jun-2004  00:52  2000.80.952.0   7,581,777  Sqlservr.exe     
   19-Jun-2004  00:52  2000.80.952.0     590,396  Sqlsort.dll      
   19-Jun-2004  00:52  2000.80.952.0      45,644  Sqlvdi.dll       
   19-Jun-2004  00:52  2000.80.952.0     106,588  Sqsrvres.dll     
   19-Jun-2004  00:52  2000.80.952.0      33,340  Ssmslpcn.dll     
   19-Jun-2004  00:52  2000.80.952.0      82,492  Ssnetlib.dll     
   19-Jun-2004  00:52  2000.80.952.0      25,148  Ssnmpn70.dll     
   19-Jun-2004  00:52  2000.80.952.0     123,456  Stardds.dll      
   19-Jun-2004  00:52  2000.80.952.0     158,240  Svrnetcn.dll     
   19-Jun-2004  00:51  2000.80.952.0      76,416  Svrnetcn.exe     
   19-Jun-2004  00:52  2000.80.952.0      53,808  Ums.dll          
   19-Jun-2004  00:52  2000.80.952.0      98,872  Xpweb70.dll      


附註由於檔案相依性最新版 Hotfix 或包含這些檔案的功能也可能包含其他檔案。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。 這個問題,首先已經在 Microsoft SQL Server 2000 服務套件 4 中獲得修正。

其他相關資訊

這個問題可能不會一直發生,和相關計時。這個問題不是很常見的。問題時記錄讀取器執行緒就會發生複寫錯誤,並已準備要記錄錯誤。 記錄讀取器執行緒可能會記錄錯誤之前執行緒必須產生位置至另一個執行緒執行之執行緒排程器。當記錄讀取器執行緒會產生排程器時,執行緒持有到名為 DBTABLE 內部 SQL Server 結構上 spinlock。DBTABLE 結構會對伺服器作業。記錄讀取器執行緒會產生之後已按住 spinlock 記錄讀取器執行緒無法重新執行的一段時間。時間取決於還有什麼伺服器上執行到那個時候該排程器上。 在這段時間沒有其他執行緒在 SQL Server 可以存取 DBTABLE] 結構,並執行緒必須等待 spinlock。當 spinlock 在等候期間超過 60 秒時,17883 錯誤訊息,就會觸發。SQL Server 處理程序 CPU 為 100%,因為微調和 DBTABLE spinlock 在等候所有執行緒。CPU 使用率可能會造成停止回應的 SQL Server 執行個體。

記錄讀取器執行緒堆疊的是,如下所示:

SharedUserData!SystemCallStub+0x4
ntdll!NtWaitForSingleObject+0xc
kernel32!WaitForSingleObjectEx+0xac
ums!UmsThreadScheduler::Switch+0x4c
ums!UmsScheduler::IdleLoop+0x105
ums!UmsScheduler::Suspend+0x66
ums!UmsEvent::Wait+0x8e
sqlservr!ExecutionContext::WaitForSignal+0x1aa
sqlservr!LatchBase::Suspend+0x16c
sqlservr!LatchBase::Acquire+0xae
sqlservr!BUF::AcquireLatch+0x1f
sqlservr!BPool::GetFromDisk+0x35a
sqlservr!bufget+0x278
sqlservr!SDES::GetPage+0xb8
sqlservr!LinkedPageSupplier::FirstPage+0x10c
sqlservr!LinkedPageSupplier::GetNextPage+0xd6
sqlservr!SDES::GetBiDi+0x19c
sqlservr!CSysScan::FGetNext+0x7f
sqlservr!wfindtext+0x24b
sqlservr!ex_sprint+0x3f
sqlservr!user_log+0x92
sqlservr!IsXactStartValid+0xeb
sqlservr!ReplXactFinder::GetNextPendingXact+0x137
sqlservr!repl_cmds_get_xacts+0x15f
sqlservr!repl_cmds+0x140
sqlservr!xp_replcmds+0x18a
sqlservr!CSpecProc::ExecuteSpecial+0x119
sqlservr!CXProc::Execute+0xa3
sqlservr!CSQLSource::Execute+0x3c0
sqlservr!execrpc+0x507
sqlservr!execute_rpc+0x19
sqlservr!process_commands+0x232
ums!ProcessWorkRequests+0x272
ums!ThreadStartRoutine+0x98
msvcrt!_threadstart+0x70
kernel32!BaseThreadStart+0x34


其中一個 spinlock 正在等候的執行緒堆疊的是,如下所示:

sqlservr!SpinlockBase::SpinToAcquire+0x3a
sqlservr!FEqProtstamp+0x4d
sqlservr!SecCache::_PsceLookupDbSecntxt+0x27
sqlservr!SecCache::FValidScedb+0x10
sqlservr!checkdbperm+0xd9
sqlservr!usedb+0xda
sqlservr!FDetermineSessionDb+0x66
sqlservr!FRedoLogin+0x16c
sqlservr!ResetConnAndDtcXact+0xdc
sqlservr!execrpc+0xad
sqlservr!execute_rpc+0x19
sqlservr!process_commands+0x232
ums!ProcessWorkRequests+0x272
ums!ThreadStartRoutine+0x98
msvcrt!_threadstart+0x70
kernel32!BaseThreadStart+0x34
如需有關 17883 錯誤訊息的資訊,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項:
319892新的並行及排程加入至 SQL Server 的診斷
如需詳細資訊,請按一下下列的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
824684用來描述 Microsoft 軟體更新標準術語的說明

屬性

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

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com