web-dev-qa-db-ja.com

デッドロック拡張イベントのring_bufferの代わりにsystem_health event_fileを読み取る

現在、この災害を利用して、system_health拡張イベントリングバッファを読み取ることにより、最近のデッドロックを特定しています。

select top 2000000000
      XEvent.value('@timestamp', 'datetime2(3)') as CreationDateUtc,
      --
      -- Extract the <deadlock>...</deadlock> tag from within the event
      -- Todo: Surely there is a better (xml) way to do this.
      --
      substring(convert(varchar(max), XEvent.query('.')), 
          -- start
          patindex('%<deadlock%', convert(varchar(max), XEvent.query('.'))),          
          -- end
          patindex('%</deadlock%', convert(varchar(max), XEvent.query('.'))) -
              patindex('%<deadlock%', convert(varchar(max), XEvent.query('.'))) + 11 -- 11 to include for '</deadlock>'
          ) AS XdlFile
 from 
    (
      select cast (target_data as xml) as TargetData
        from sys.dm_xe_session_targets st with (nolock)
        join sys.dm_xe_sessions s with (nolock)
          on s.address = st.event_session_address
       where [name] = 'system_health'
         and st.target_name = N'ring_buffer'
    ) as Data
 cross apply TargetData.nodes('RingBufferTarget/event[@name="xml_deadlock_report"]') AS XEventData (XEvent)
 order by CreationDateUtc desc

正常に動作しますが、イベントは非常に長く(24時間など)滞留するようには見えません。これは、その「リングバッファ」の部分だと思います。次に、同様の情報を持つsystem_health "ファイル"を読んでいたリンクに偶然遭遇しました。

select event_data = CONVERT(XML, event_data) 
from sys.fn_xe_file_target_read_file(N'system_health*.xel', NULL, NULL, NULL)
where event_data like '%xml_deadlock%'  

このファイルはリングバッファーと同じですか?ファイルを使用することに不利な点はありますか?いくつかのXMLスキルを持っている人は、トップスクリプトを変換したいですか?

目標は、XdlFileフィールドを新しいファイルにコピーして貼り付け、「ファイルを開く」を使用してSSMSまたはSQL Sentry Plan Explorerに直接読み込むことです。

リングバッファリンク:

https://connect.Microsoft.com/SQLServer/feedback/details/754115/xevents-system-health-does-not-catch-all-deadlocks#tabs

https://www.sqlskills.com/blogs/jonathan/why-i-hate-the-ring_buffer-target-in-extended-events/

http://www.sqlskills.com/blogs/jonathan/multi-victim-deadlocks/

https://www.sqlskills.com/blogs/jonathan/graphically-viewing-extended-events-deadlock-graphs/

http://www.mssqltips.com/sqlservertip/1234/capturing-sql-server-deadlock-information-in-xml-format/

http://blogs.msdn.com/b/sqldatabasetalk/archive/2013/05/01/tracking-down-deadlocks-in-sql-database.aspx

デッドロックエラーがデッドロックSQLを返さない

ファイル:

https://www.mssqltips.com/sqlservertip/3636/query-data-from-extended-events-in-sql-server/

@@ version = Microsoft SQL Server 2012(SP3-CU5)(KB3180915)-11.0.6544.0(X64)

4
crokusek

これはうまくいくようです:

with XmlDeadlockReports as
(
  select convert(xml, event_data) as EventData
   from sys.fn_xe_file_target_read_file(N'system_health*.xel', NULL, NULL, NULL)
  where object_name = 'xml_deadlock_report'
) 
select EventData.value('(event/@timestamp)[1]', 'datetime2(7)') as TimeStamp,
       EventData.query('event/data/value/deadlock') as XdlFile
  from XmlDeadlockReports
 order by TimeStamp desc
4
crokusek