SQL Server扩展事件(Extended Events)-- 使用扩展事件跟踪监控死锁脚本实现

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:

SQL Server扩展事件(Extended Events)-- 使用扩展事件跟踪监控死锁脚本实现

1
2
3
4
5
6
7
8
-- Create a new event session (it is better to create a new session and not modify the system’s built-in session “system_health”):
CREATE  EVENT SESSION [Deadlock_Monitor]  ON  SERVER
ADD  EVENT sqlserver.xml_deadlock_report
ADD  TARGET package0.asynchronous_file_target
( SET  filename= N 'C:\temp\deadlock.xel'  )
WITH
(MAX_MEMORY=4096 KB,EVENT_RETENTION_MODE=ALLOW_SINGLE_EVENT_LOSS,MAX_DISPATCH_LATENCY=10 SECONDS,
MAX_EVENT_SIZE=0 KB,MEMORY_PARTITION_MODE=NONE,TRACK_CAUSALITY= OFF ,STARTUP_STATE= ON )

 

1
2
-- Enable the session to start capturing events:
ALTER  EVENT SESSION [Deadlock_Monitor]  ON  SERVER STATE = start;

 

1
2
-- To see how many deadlocks have been captured by the session since it started running, you can run this query:
select  COUNT (*)  from  sys.fn_xe_file_target_read_file ( 'c:\temp\deadlock*.xel' 'c:\temp\deadlock*.xem' null null )

 

1
2
3
4
5
6
-- To get a list of the captured deadlocks and their graphs you can execute this query:
select  xml_data.value( '(event[@name="xml_deadlock_report"]/@timestamp)[1]' , 'datetime' ) Execution_Time,
xml_data.value( '(event/data/value)[1]' , 'varchar(max)' ) Query
from  ( select  object_name  as  event,  CONVERT (xml, event_data)  as  xml_data
from  sys.fn_xe_file_target_read_file
( 'c:\temp\deadlock*.xel' 'c:\temp\deadlock*.xem' null null )) v  order  by  Execution_Time

 

1
2
-- If you want the session to stop capturing events (until you enable the session again), you can use this query:
ALTER  EVENT SESSION [Deadlock_Monitor]  ON  SERVER STATE = stop;

 

1
2
-- If you want to completely remove (delete) the session from the server, you can use this query:
DROP  EVENT SESSION [Deadlock_Monitor]  ON  SERVER

 

1
2
3
4
5
6
7
-- If you want to configure other events too, you can query these tables to find out what you can trace and how:
--Show the possible targets:
SELECT  xp.[ name ], xo.*
FROM  sys.dm_xe_objects xo, sys.dm_xe_packages xp
WHERE  xp.[guid] = xo.[package_guid]
AND  xo.[object_type] =  'target'
ORDER  BY  xp.[ name ];

 

1
2
3
4
5
6
--Show the possible actions
SELECT  xp.[ name ], xo.*
FROM  sys.dm_xe_objects xo, sys.dm_xe_packages xp
WHERE  xp.[guid] = xo.[package_guid]
AND  xo.[object_type] =  'action'
ORDER  BY  xp.[ name ], xo.[ name ];





















本文转自UltraSQL51CTO博客,原文链接:http://blog.51cto.com/ultrasql/1600520 ,如需转载请自行联系原作者


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3天前
|
SQL API 流计算
实时计算 Flink版产品使用合集之在Mac M1下的Docker环境中开启SQL Server代理的操作步骤是什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
18 1
|
2天前
|
SQL 数据处理 API
实时计算 Flink版产品使用合集之遇到SQL Server锁表问题如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
8 0
|
3天前
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用合集之当 SQL Server 源数据库中的数据更新后,CDC 吐出的操作(op)是怎样的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
14 0
|
5天前
|
SQL XML Linux
SQL Server的版本
【5月更文挑战第14天】SQL Server的版本
20 3
|
5天前
|
SQL 关系型数据库 数据管理
Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
【5月更文挑战第14天】Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
16 2
|
5天前
|
SQL 存储 数据库连接
LabVIEW与SQL Server 2919 Express通讯
LabVIEW与SQL Server 2919 Express通讯
|
5天前
|
SQL Windows
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
14 4
|
5天前
|
SQL 数据可视化 Oracle
这篇文章教会你:从 SQL Server 移植到 DM(上)
这篇文章教会你:从 SQL Server 移植到 DM(上)
|
5天前
|
SQL 关系型数据库 数据库
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
SQL Server语法基础:入门到精通
|
5天前
|
SQL 存储 网络协议
SQL Server详细使用教程
SQL Server详细使用教程
32 2