博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server扩展事件(Extended Events)-- 事件的寿命
阅读量:6226 次
发布时间:2019-06-21

本文共 506 字,大约阅读时间需要 1 分钟。

定义并启动扩展事件会话后,处理过程将照常进行,直到所监控的代码遇到某个事件为止。下图介绍了扩展事件系统所遵循的步骤。

 

 

具体步骤如下:

 

1. 执行检查以查看是否有任何扩展事件会话正在监控该事件。如果没有,控制权将返给包含该事件的代码,然后继续进行处理。

 

2. 确定事件的负载,将所需的全部信息都收集到内存中 — 换言之,构建事件的负载。

 

3. 如果为该事件定义了任何谓词,则执行它们。此时,谓词结果可能是不应消耗该事件。如果是这种情况,控制权将返给包含该事件的代码,然后继续进行处理。

 

4. 此时系统已得知事件将被消耗,因此将执行链接到该事件的所有动作。现在事件已具有完整的负载,已为消耗做好准备。

 

5. 将事件提供给同步目标(如果有的话)。

 

6. 如果存在任何异步目标,将会缓冲该事件以便随后进行处理。

 

7. 控制权将返给包含该事件的代码,然后继续进行处理。

 

如前所述,在创建事件会话时应格外注意,要避免同步动作或异步目标的缓冲对所监控代码的性能产生影响。

本文转自UltraSQL51CTO博客,原文链接:http://blog.51cto.com/ultrasql/1599383 ,如需转载请自行联系原作者
你可能感兴趣的文章
学生考试系统
查看>>
自己动手写一个单链表
查看>>
[转]VirtualBox添加新硬盘
查看>>
jQuery
查看>>
20170322Linux
查看>>
NOIp 2014 #1 生活大爆炸版石头剪刀布 Label:模拟
查看>>
判断相同树或者对称树
查看>>
foundation学习
查看>>
oracle之 获取建表ddl语句
查看>>
oracle 之 安装10.2.0.1 且 升级到 10.2.0.4
查看>>
Java培训学习笔记(四):简单小总结
查看>>
NYOJ467中缀式变后缀式
查看>>
视图层 表格里面的 的超链接
查看>>
Linux里面非常重要的目录
查看>>
angular-seed — AngularJS种子项目
查看>>
开发人员准确理解技术需求:用户想得与说的不一样
查看>>
OpenCV 颜色空间转换参数CV_BGR2GRAY改变
查看>>
Allegro PCB Design GXL (legacy) 从dxf文件中导入板框
查看>>
手撸系列之——ORM(对象关系映射)
查看>>
iOS - OC RunLoop 运行循环/消息循环
查看>>