SQLServer死锁监测方案:如何使用XE.Core解析xel文件里包含死锁扩展事件的死锁xml

1.处理流程

对于SQLServer死锁监测的方式,最终选用的方案是自定义的死锁扩展事件在生成本地xel文件,直接对xel文件解析。SQLServer自带两个dll可用于解析xel文件,编程语言选用C#,死锁扩展事件的名为 xml_deadlock_report。解析时需考虑版本问题,SQLServer2008版本需要xel,xem文件。

两个DLL: Microsoft.SqlServer.XE.Core.dll, Microsoft.SqlServer.XEvent.Linq.dll

  1. 抛弃SQLServer自带的system_health,完全自定义新的死锁扩展事件,system_health包含扩展事件太多,解析耗费时间长,且文件很大。
  2. 抛弃使用sys.fn_xe_file_target_read_file查询死锁xml的方式,当有xel文件,却仍旧依赖数据库查询获取xml不值得,希望与数据库查询隔离。

2.两种SQLServer版本代码解析示例

2008版本的处理代码,需要xel和xem文件一起解析,xem也是需要指定生成的

csharp 复制代码
			try
			{
				using (QueryableXEventData events = new QueryableXEventData(
					new string[]{ @"D:\xxxx_0_134010006262980000.xel"},
					new string[]{ @"D:\xxxx_0_134010006262980000.xem"}
				))
				{
					int count = 0  ;
					foreach (PublishedEvent evt in events)
					{
						if (evt.Name == "xml_deadlock_report")
						{
							string timeStamp = evt.Timestamp.ToLocalTime().ToString("yyyy-MM-dd HH:mm:ss");
							string deadlockXml = evt.Fields["xml_report"].Value.ToString();
						}
					}
					
				}
			}
			catch (Exception ex)
			{
			}

2008版本以上的,直接解析xel

csharp 复制代码
			try
			{
				using (QueryableXEventData events = new QueryableXEventData(@"D:\xxxx_0_134010006262980000.xel"
				))
				{
					int count = 0  ;
					foreach (PublishedEvent evt in events)
					{
						if (evt.Name == "xml_deadlock_report")
						{
							string timeStamp = evt.Timestamp.ToLocalTime().ToString("yyyy-MM-dd HH:mm:ss");
							string deadlockXml = evt.Fields["xml_report"].Value.ToString();
						}
					}
					
				}
			}
			catch (Exception ex)
			{
			}
相关推荐
Traced back1 天前
SQL Server 核心语法+进阶知识点大全(小白版)
数据库·sqlserver
山岚的运维笔记1 天前
SQL Server笔记 -- 第14章:CASE语句
数据库·笔记·sql·microsoft·sqlserver
松涛和鸣1 天前
70、IMX6ULL LED驱动实战
linux·数据库·驱动开发·postgresql·sqlserver
UpYoung!1 天前
【SQL Server 2019】企业级数据库系统—数据库SQL Server 2019保姆级详细图文下载安装完全指南
运维·数据库·sqlserver·运维开发·数据库管理·开发工具·sqlserver2019
知识分享小能手1 天前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 数据表的操作 —语法详解与实战案例(3)
数据库·学习·sqlserver
知识分享小能手2 天前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
山岚的运维笔记2 天前
SQL Server笔记 -- 第15章:INSERT INTO
java·数据库·笔记·sql·microsoft·sqlserver
山岚的运维笔记2 天前
SQL Server笔记 -- 第16章:MERGE
java·笔记·sql·microsoft·sqlserver
奥特曼打小白2 天前
Microsoft SQL Server2025的下载、安装与配置——从环境、管理工具、配置管理器入手,解决VS2022ASP.NET网站项目中SqlDataSource控件找不到服务器的问题
sqlserver·asp.net
今晚打老虎z3 天前
解决SQL Server 安装运行时针对宿主机内存不足2GB的场景
sqlserver·c#