當您使用 SQL Profiler 執行個體中執行之事件的用戶端追蹤時,會緩慢執行 SQL Server 執行個體

文章翻譯 文章翻譯
文章編號: 929728 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

徵狀

考慮下列案例:
  • 您有正在執行的 Microsoft SQL Server 2000 或 Microsoft SQL Server 2005 的執行個體的電腦。
  • 您可以使用 SQL Profiler SQL Server 執行個體中執行用戶端追蹤的事件。
  • 正在執行的 SQL Server 執行個體在電腦上執行 SQL Profiler,或在不同的電腦上執行 SQL Profiler。
在這種情況下 SQL Server 執行個體的執行速度變慢。

當就會發生這個問題如果查詢 master.dbo.sysprocesses 系統資料表的 SQL Server 執行個體中看到下列徵狀:
  • 數個作用中的伺服器處理序識別碼 (SPID) 顯示 0x404 (LATCH_EX)waittype 資料行中。
  • 一或多個 SPID 顯示 SQL Profilerprogram_name 資料行中。
此外,您會看到一個下列 waitresource 資料行中值如果查詢 master.dbo.sysprocesses 系統資料表:
  • 雜項 (hex address)
  • TRACE_CONTROLLER
  • TRACE_IO_SYNC
  • TRACE
您看到其中一個值,如果下列情況成立:
  • 您可以使用 SQL Server 2000 服務套件 4 (SP4) 或 SQL Server 2005。
  • 某個 SPID 正在等候 SQL Profiler 中執行同步處理追蹤作業。

發生的原因

您在對執行個體的 SQL Server 2000 或 SQL Server 2005 的執行 SQL Profiler 時執行個體的每個作用中的 SPID 需要獨佔的閂鎖 (LATCH_EX) SQL Profiler 中寫入事件。SPID 將事件寫入本機記憶體緩衝區第一次。然後,事件將轉移至 SQL Profiler。如果本機記憶體緩衝區已滿,SPID 就會捨棄該事件。本機記憶體緩衝區中的事件傳送到 SQL Profiler 之後 SPID 可以寫入本機記憶體緩衝區的新事件。如果其他 SPID 正在等候事件寫入 SQL Profiler,在佇列中等候這些 SPID。

因為 SQL Profiler 從 SQL Server 處理序分開的處理程序將每個事件轉送到 SQL Profiler 需要一些時間。如果您在不同的電腦上執行 SQL Profiler 此程序需較長的時間。因為網路延遲與因為正在執行 SQL Profiler 電腦的效能,此程序需較長的時間。因此,SQL Server 執行個體的執行速度變慢。

其他可行方案

如果要解決這個問題,不要在 SQL Server 執行個體中執行之事件的用戶端追蹤使用 SQL Profiler。而是,使用系統預存程序來執行伺服器端追蹤事件。

您可以使用下列系統預存程序:
  • sp_trace_create
  • sp_trace_setevent
  • sp_trace_setfilter
  • sp_trace_setstatus
如需有關這些系統預存程序,預存程序在 SQL Server 2000 線上叢書 》 或 SQL Server 2005 線上叢書 》 中的搜尋]。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。

其他相關資訊

您可以使用 PSSDIAG 資料集合公用程式來收集追蹤資料檔案。如需有關 PSSDIAG 資料集合公用程式的資訊,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項:
830232PSSDIAG 資料集合公用程式
如更多有關 waittype 資料行在 SQL Server 2000 和 SQL Server 2005 中,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
822101在 SQL Server 2000 和 SQL Server 2005 master.dbo.sysprocesses 資料表中的 < waittype 和 lastwaittype 資料行的描述

屬性

文章編號: 929728 - 上次校閱: 2008年9月30日 - 版次: 3.0
這篇文章中的資訊適用於:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 2000 Enterprise Edition
  • Microsoft SQL Server 2000 Workgroup Edition
  • Microsoft SQL Server 2000 Developer Edition
關鍵字:?
kbmt kbsql2005engine kbexpertiseadvanced kbtshoot kbprb KB929728 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:929728
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