SQL Serverの期埅倀の統蚈情報、たたはどこが痛いのか教えおください

SQL Serverのパフォヌマンスの問題を䜕回経隓し、どこを調べるかを決めたしたか



めったに䜿甚されないSQL Serverパフォヌマンスのトラブルシュヌティング方法の1぀は、期埅倀ずキュヌ期埅倀統蚈ずも呌ばれたすず呌ばれたす。 方法論の基本的な前提は、SQL Serverがどのスレッドを埅機するかを垞に監芖するこずです。 パフォヌマンスの問題の考えられる原因のリストを短瞮するために、SQL Serverにこの情報を芁求できたす。 期埅はSQL Serverが監芖するものです。 キュヌは、スレッドがアクセスを埅機しおいるリ゜ヌスです。 通垞、システムは膚倧な数の期埅を獲埗し、それらはすべおさたざたなリ゜ヌスぞのアクセスを埅機するこずを意味したす。 たずえば、PAGEIOLATCH_EXを埅぀こずは、ストリヌムがディスクからバッファプヌルぞのデヌタペヌゞの読み取りを埅っおいるこずを意味したす。 LCK_M_Xを埅っおいるずいうこずは、スレッドが䜕かに排他ロックをかける機䌚を埅っおいるこずを意味したす。



玠晎らしいニュヌスは、SQL Server がパフォヌマンスの問題が䜕であるかを正確に知っおいるこずです。あなたがする必芁があるのは、圌に尋ねるだけです...そしお、圌が蚀うこずを正しく解釈するこずはもう少し耇雑になりたす。



次の情報は、すべおの期埅を心配し、その原因を理解しおいる人向けです。 期埅は垞に生じたす。 これが、SQL Serverの䜜業スケゞュヌリングシステムの仕組みです。



スレッドはプロセッサを䜿甚し、リ゜ヌスぞのアクセスを埅機する必芁に盎面するたでステヌタスが「実行䞭」になりたす。 この堎合、䞀時停止状態SUSPENDEDのスレッドの順序なしリストに配眮されたす。 同時に、FIFOの原則先入れ先出しに埓っお線成され、ステヌタスが「実行可胜」RUNNABLEであるプロセッサぞのアクセスを埅機しおいるスレッドのキュヌ内の次のスレッドは、プロセッサぞのアクセスを取埗しお「実行䞭」になりたす。 「䞀時停止」状態のスレッドが、そのリ゜ヌスが䜿甚可胜であるずいう通知を受け取るず、「実行準備完了」になり、実行準備が敎ったスレッドのキュヌの最埌に配眮されたす。 フロヌは、タスクが完了するたで、チェヌン「実行䞭」-「䞀時停止䞭」-「実行準備完了」に沿っお呚期的な動きを続けたす。 動的管理ビュヌDMVsys.dm_exec_requestsを䜿甚しお、プロセスずそのステヌタスを確認できたす。



SQL Serverは、スレッドが実行状態を終了しおからその状態に戻るたでの経過時間を監芖し、それを「埅機時間」ずしお定矩し、準備完了状態で費やした時間を「時間」ずしお定矩したす。信号埅機時間」、぀たり プロセッサにアクセスするためにリ゜ヌスの可甚性に関するシグナルを受信した埌、スレッドが必芁ずする時間。 合蚈タむムアりトから信号タむムアりトを匕くこずにより、スレッドが「リ゜ヌス埅機時間」ず呌ばれる「䞀時停止」状態で費やす時間を理解する必芁がありたす。



これに぀いお読むこずをお勧めする優れた情報源は、埅機統蚈に関する新しい2014幎文曞「期埅倀統蚈を䜿甚したSQL Serverパフォヌマンスの調敎初心者向けガむド」 英語です。 たた、はるかに叀いドキュメント 期埅ずキュヌを䜿甚したパフォヌマンス管理 英語には倚くの有甚な情報がありたすが、珟時点ではかなり時代遅れです。さたざたなタむプの期埅および短期ロックのクラスの最良のチュヌトリアルは、 期埅の包括的なラむブラリです 英語および短期ロック 英語。



DMV sys.dm_os_wait_statsを䜿甚しお、环積埅機統蚈に぀いおSQL Serverを照䌚できたす。 倚くの人は、DMV呌び出しを䜕らかの芁玄コヌドでラップするこずを奜みたす。 以䞋は、2016幎時点での私のスクリプトの最新バヌゞョンです。これはすべおのバヌゞョンで動䜜し、SQL Server 2016の埅機タむプが含たれおいたすAzure で䜿甚するスクリプトのバヌゞョンはこちらをご芧ください 。



WITH [Waits] AS (SELECT [wait_type], [wait_time_ms] / 1000.0 AS [WaitS], ([wait_time_ms] - [signal_wait_time_ms]) / 1000.0 AS [ResourceS], [signal_wait_time_ms] / 1000.0 AS [SignalS], [waiting_tasks_count] AS [WaitCount], 100.0 * [wait_time_ms] / SUM ([wait_time_ms]) OVER() AS [Percentage], ROW_NUMBER() OVER(ORDER BY [wait_time_ms] DESC) AS [RowNum] FROM sys.dm_os_wait_stats WHERE [wait_type] NOT IN ( N'BROKER_EVENTHANDLER', N'BROKER_RECEIVE_WAITFOR', N'BROKER_TASK_STOP', N'BROKER_TO_FLUSH', N'BROKER_TRANSMITTER', N'CHECKPOINT_QUEUE', N'CHKPT', N'CLR_AUTO_EVENT', N'CLR_MANUAL_EVENT', N'CLR_SEMAPHORE', -- Maybe uncomment these four if you have mirroring issues N'DBMIRROR_DBM_EVENT', N'DBMIRROR_EVENTS_QUEUE', N'DBMIRROR_WORKER_QUEUE', N'DBMIRRORING_CMD', N'DIRTY_PAGE_POLL', N'DISPATCHER_QUEUE_SEMAPHORE', N'EXECSYNC', N'FSAGENT', N'FT_IFTS_SCHEDULER_IDLE_WAIT', N'FT_IFTSHC_MUTEX', -- Maybe uncomment these six if you have AG issues N'HADR_CLUSAPI_CALL', N'HADR_FILESTREAM_IOMGR_IOCOMPLETION', N'HADR_LOGCAPTURE_WAIT', N'HADR_NOTIFICATION_DEQUEUE', N'HADR_TIMER_TASK', N'HADR_WORK_QUEUE', N'KSOURCE_WAKEUP', N'LAZYWRITER_SLEEP', N'LOGMGR_QUEUE', N'MEMORY_ALLOCATION_EXT', N'ONDEMAND_TASK_QUEUE', N'PREEMPTIVE_XE_GETTARGETSTATE', N'PWAIT_ALL_COMPONENTS_INITIALIZED', N'PWAIT_DIRECTLOGCONSUMER_GETNEXT', N'QDS_PERSIST_TASK_MAIN_LOOP_SLEEP', N'QDS_ASYNC_QUEUE', N'QDS_CLEANUP_STALE_QUERIES_TASK_MAIN_LOOP_SLEEP', N'QDS_SHUTDOWN_QUEUE', N'REDO_THREAD_PENDING_WORK', N'REQUEST_FOR_DEADLOCK_SEARCH', N'RESOURCE_QUEUE', N'SERVER_IDLE_CHECK', N'SLEEP_BPOOL_FLUSH', N'SLEEP_DBSTARTUP', N'SLEEP_DCOMSTARTUP', N'SLEEP_MASTERDBREADY', N'SLEEP_MASTERMDREADY', N'SLEEP_MASTERUPGRADED', N'SLEEP_MSDBSTARTUP', N'SLEEP_SYSTEMTASK', N'SLEEP_TASK', N'SLEEP_TEMPDBSTARTUP', N'SNI_HTTP_ACCEPT', N'SP_SERVER_DIAGNOSTICS_SLEEP', N'SQLTRACE_BUFFER_FLUSH', N'SQLTRACE_INCREMENTAL_FLUSH_SLEEP', N'SQLTRACE_WAIT_ENTRIES', N'WAIT_FOR_RESULTS', N'WAITFOR', N'WAITFOR_TASKSHUTDOWN', N'WAIT_XTP_RECOVERY', N'WAIT_XTP_HOST_WAIT', N'WAIT_XTP_OFFLINE_CKPT_NEW_LOG', N'WAIT_XTP_CKPT_CLOSE', N'XE_DISPATCHER_JOIN', N'XE_DISPATCHER_WAIT', N'XE_TIMER_EVENT') AND [waiting_tasks_count] > 0 ) SELECT MAX ([W1].[wait_type]) AS [WaitType], CAST (MAX ([W1].[WaitS]) AS DECIMAL (16,2)) AS [Wait_S], CAST (MAX ([W1].[ResourceS]) AS DECIMAL (16,2)) AS [Resource_S], CAST (MAX ([W1].[SignalS]) AS DECIMAL (16,2)) AS [Signal_S], MAX ([W1].[WaitCount]) AS [WaitCount], CAST (MAX ([W1].[Percentage]) AS DECIMAL (5,2)) AS [Percentage], CAST ((MAX ([W1].[WaitS]) / MAX ([W1].[WaitCount])) AS DECIMAL (16,4)) AS [AvgWait_S], CAST ((MAX ([W1].[ResourceS]) / MAX ([W1].[WaitCount])) AS DECIMAL (16,4)) AS [AvgRes_S], CAST ((MAX ([W1].[SignalS]) / MAX ([W1].[WaitCount])) AS DECIMAL (16,4)) AS [AvgSig_S], CAST ('https://www.sqlskills.com/help/waits/' + MAX ([W1].[wait_type]) as XML) AS [Help/Info URL] FROM [Waits] AS [W1] INNER JOIN [Waits] AS [W2] ON [W2].[RowNum] <= [W1].[RowNum] GROUP BY [W1].[RowNum] HAVING SUM ([W2].[Percentage]) - MAX( [W1].[Percentage] ) < 95; -- percentage threshold GO
      
      







ク゚リ結果には、システム内のすべおの期埅倀の割合でグルヌプ化された期埅倀が降順で衚瀺されたす。 朜圚的に泚意を払う䟡倀がある期埅はリストの䞀番䞊にあり、SQL Serverが時間を費やすほずんどの期埅を衚しおいたす。 考慮から陀倖された期埅倀の倧きなリストが衚瀺されたす。前述したように、それらは垞に発生し、䞊にリストされたものは通垞無芖できたす。



このコヌドを䜿甚しお、サヌバヌによっお蓄積された統蚈をリセットするこずもできたす。



 DBCC SQLPERF (N'sys.dm_os_wait_stats', CLEAR); GO
      
      







そしおもちろん、結果を数時間ごずたたは毎日保存し、時間分析を行っお倉曎の方向を把握したり、問題が発生し始めた堎合に自動的に問題を远跡したりするこずができたす。

パフォヌマンスダッシュボヌドを䜿甚しお、SQL Server 2005の結果ずSQL Server 2008のデヌタコレクタをグラフィカルに衚瀺するこずもできたす。SQLServer 2000では、DBCC SQLPERFN'waitstats 'を䜿甚できたす。



結果が埗られたら、それらをどのように解釈し、どこを芋るかに぀いお考え始めるでしょう。 以前に参照したドキュメントには、ほずんどのタむプの期埅に関する豊富な情報がありたすSQL Server 2008で远加されたものを陀く。



ここで、少し前に公開した研究の結果を提䟛したいず思いたす。 䞊蚘のコヌドを実行しお結果を知らせおください。 1823台のサヌバヌから倧量の結果が出たした-ありがずう



以䞋は、結果のグラフ衚瀺です。







クラむアントシステムで䜕床も芋た結果、トップ4の結果にはたったく驚きたせん。



私の蚘事の続きでは、調査回答者が提䟛する最も人気のあるタむプの期埅倀を降順でリストし、それらがあなたのシステムの基本である堎合に正確に䜕を意味できるかをいく぀かの蚀葉でコメントしたす。 リスト圢匏は、指定されたタむプの埅機が䞻なものである回答者からのシステムの数を瀺したす。







おもしろかった 具䜓的に䜕かに興味があるか、この蚘事を読んで楜しんだか教えおください



All Articles