1、背景

下面是从以往Profiler收集的跟踪文件中提取Job有关数据

;with cte as(
select b.Name EventClass,TextData,DatabaseName,Duration/1000 Duration_ms
,CPU CPU_ms,Reads,Writes,StartTime,EndTime,HostName,LoginName,ApplicationName
,row_number() over(partition by ApplicationName order by CPU desc) rankid
from fn_trace_gettable(N'F:\TroubleShooting\Trace\InstanceName_HighCPU40_20160907.trc', 1) a
inner join sys.trace_events b
on a.EventClass=b.trace_event_id
where ApplicationName like '%SQLAgent - TSQL JobStep%'
)
select * from cte where rankid=1
order by CPU_ms desc


如何快速定位问题语句归属哪个Job?

1.1、关键字匹配

使用TextData中的关键字到msdb.dbo.sysjobsteps中的command中匹配

select sj.name,sjs.command,sjs.step_id
from msdb.dbo.sysjobs sj
inner join msdb.dbo.sysjobsteps sjs
on sj.job_id=sjs.job_id
where sjs.command like '%FishGameReturnRateStatistics%'


根据返回的Job名称,结合Job历史记录、问题语句Duration,基本可以定位到确切的Job。
存在问题,如果问题语句是一段很长的SQL,而非存储过程,关键字的划定直接影响定位的命中率,进而影响查找时间。

1.2、Job_id匹配

我们注意看第一张图中的ApplicationName列,SQLAgent - TSQL JobStep (Job 0xCFAF657344E1624E98B1DD4676CC18EC : Step 7),有点像是某个Job的第7个步骤。会是哪个作业,中间那串"16进制"与Job_id有什么关系?

--补充 16:22 2017/8/9 根据ApplicationName得到作业名称
select job_id,name from msdb.dbo.sysjobs
where job_id=convert(uniqueidentifier,0xCFAF657344E1624E98B1DD4676CC18EC)

2、ApplicationName与Job_id的关系

为了核查ApplicationName与Job_id的关系,创建一个跟踪,列筛选器添加对TextData筛选,作业运行得到跟踪结果

我们再来看作业的Job_id

将ApplicationName列与Job_id对比
ApplicationName:0x9C91EB5022BD9F4D94FEA58A22571EBA
Job_id:50EB919C-BD22-4D9F-94FE-A58A22571EBA
适当调整样式
ApplicationName:0x-9C91EB50-22BD-9F4D-94FE-A58A22571EBA
Job_id              :     50EB919C-BD22-4D9F-94FE-A58A22571EBA
是否发现了什么?在16进制中,每两个进制数字表示一个字节,并且是逆序排列的。
那么16进制的9C91EB50对应的实际是50EB919C;16进制的22BD对应的实际是BD22;16进制的9F4D对应的实际是4D9F。剩下的部分ApplicationName与Job_id是一致的,至于为什么这样保存,暂时没找到相关资料。我也只是通过对比,发现存在这样的现象,并推测ApplicationName与Job_id可以进行互转

use msdb
go
create function [dbo].[JobIdToApplicationName](@job_id varchar(36))
returns varchar(38)
as
begin
declare @str varchar(38)
select @str='Job 0x'
+substring(@job_id,7,2)+substring(@job_id,5,2)+substring(@job_id,3,2)+substring(@job_id,1,2)
+substring(@job_id,12,2)+substring(@job_id,10,2)
+substring(@job_id,17,2)+substring(@job_id,15,2)
+replace(substring(@job_id,20,17),'-','')
return @str
end
go

结合msdb.dbo.sysjobs就可得到所有Job对应的ApplicationName

use msdb
go
select name,job_id,[dbo].[JobIdToApplicationName](job_id) SubApplicationName
from msdb.dbo.sysjobs

3、回归主题

前两天打算跟踪一个作业执行情况,事先查看作业是直接调用存储过程,而存储过程中还会调用其他的存储过程,类似下面

CREATE PROC pro_Parent
AS
BEGIN
EXEC pro_sub1
EXEC pro_sub2
...
END
GO

习惯性的选择RPC:Completed和SQL:BatchCompleted事件,并在列筛选器对TextData应用类似于pro_sub1、pro_sub2(两边需用%)
结果第二天上班,查看跟踪数据时,什么都没有!这是由于自己疏忽,在创建跟踪前还提醒自己要添加SP:Completed事件,最后还是给忘了。又是习惯+疏忽!
我想表达的问题是,如果一个Job调用父存储过程,然后父存储过程中又调用子存储过程,如何在Profiler中只得到此Job相关的父存储过程和子存储过程的消耗情况?添加SP:Completed事件,然后TextData应用类似于各父、子存储过程。如果子存储过程很多呢?这样添加略显笨拙。
如果Job调用的是很长的SQL Batch,如何跟踪这个作业的消耗情况?
想想前面的ApplicationName,我们可以根据Job_id得出Job在Profiler中的ApplicationName列的关键信息。然后针对ApplicationName设置筛选器,不管Job执行什么样的脚本,我们都能方便地获取需要事件的信息。
因此对前两天跟踪Job的那个例子,就可以将下面的SubApplicationName应用于ApplicationName列筛选器,当然还需要加上SP:Completed事件

4、总结

只要有了ApplicationName与Job_id的对应关系,不管我们是要跟踪某个Job执行情况,还是要将Profiler结果定位到具体Job,都十分便捷。

Trace-如何跟踪某个Job的开销的更多相关文章

  1. SQL Server 默认跟踪(Default Trace)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 基础知识(Rudimentary Knowledge) 查看默认跟踪信息(Default Tr ...

  2. SQL Server中关于跟踪(Trace)那点事

    前言 一提到跟踪俩字,很多人想到警匪片中的场景,同样在我们的SQL Server数据库中“跟踪”也是无处不在的,如果我们利用好了跟踪技巧,就可以针对某些特定的场景做定向分析,找出充足的证据来破案. 简 ...

  3. 【转】SQL Server中关于跟踪(Trace)那点事

    前言 一提到跟踪俩字,很多人想到警匪片中的场景,同样在我们的SQL Server数据库中“跟踪”也是无处不在的,如果我们利用好了跟踪技巧,就可以针对某些特定的场景做定向分析,找出充足的证据来破案. 简 ...

  4. SQL Server中关于跟踪(Trace)那点事(转载)

    前言 一提到跟踪俩字,很多人想到警匪片中的场景,同样在我们的SQL Server数据库中“跟踪”也是无处不在的,如果我们利用好了跟踪技巧,就可以针对某些特定的场景做定向分析,找出充足的证据来破案. 简 ...

  5. 深入了解跟踪(trace)

    深入了解跟踪(trace) 转自:https://www.cnblogs.com/zhijianliutang/p/4113911.html 前言 一提到跟踪俩字,很多人想到警匪片中的场景,同样在我们 ...

  6. SQL Server 默认跟踪(Default Trace)介绍使用

    背景 当数据库的表.存储过程经常别修改,当这些修改造成BUG的时候,很多开发都不承认是他们干的,那我们有没办法找出谁干的呢? SQL Server有Default Trace默认跟踪,数据库记录信息到 ...

  7. 【转贴】SQL Server中关于跟踪(Trace)那点事

    SQL Server中关于跟踪(Trace)那点事 https://www.cnblogs.com/zhijianliutang/p/4113911.html 作者很牛B.. 前言 一提到跟踪俩字,很 ...

  8. 【监控笔记】【1.2】监控事件系列——SQL Trace(默认跟踪与自定义跟踪)

    目录: [1.1]概念与使用 [1.2]跟踪的基本操作 --[1.2.1]查看默认跟踪是否在运行 --[1.2.2]开启默认跟踪 --[1.2.3]关闭默认跟踪 --[1.2.4]查看跟踪文件/查看跟 ...

  9. Google Dapper-大规模分布式系统的基础跟踪设施

    [说明:本文是阅读Google论文"Dapper, a Large-Scale Distributed Systems Tracing Infrastructure"之后的一个简要 ...

随机推荐

  1. Maven 添加自定义 archetype

    环境:jdk7 maven3.23 eclipse mars 关于maven是使用插件自带的还是单独下载的,应该都是可以的,但是要注意maven和jdk版本的问题,比如3.2.3版本的maven支持j ...

  2. Smooth Mouse

    一款免费软件,使mac可以做到和 Windows 下的鼠标加速度的相同算法,实现同样 win 的鼠标操控感,也可以实现鼠标0加速度.

  3. 反调试技术常用API,用来对付检测od和自动退出程序

    在调试一些病毒程序的时候,可能会碰到一些反调试技术,也就是说,被调试的程序可以检测到自己是否被调试器附加了,如果探知自己正在被调试,肯定是有人试图反汇编啦之类的方法破解自己.为了了解如何破解反调试技术 ...

  4. UVA 12544 - Beehives O(nm) 无向图最小环

    Bees are one of the most industrious insects. Since they collect nectarand pollen from flowers, they ...

  5. 北京电子科技学院(BESTI)实验报告3

    北京电子科技学院(BESTI)实验报告3 课程: 信息安全系统设计基础 班级:1452.1453 姓名:(按贡献大小排名)周恩德 .郑凯杰 学号:(按贡献大小排名)20145217 .201453 指 ...

  6. win8 系统安装node环境记录

    原先我是用win7环境安装node很方便,到了win8系统突然变了,让我顿时困惑了一段时间,但还是被我找到方式解决了,记录一下解决方案: 首先在网上看了一些资料说win8下安装node环境会出错,但我 ...

  7. BZOJ3069: [Pa2011]Hard Choice 艰难的选择

    Description Byteasar是一个很纠结的人.每次他经过Bytetown的时候都知道有至少2条不同的路径可以选择,这导致他必须花很长时间来决定走哪条路.Byteasar最近听说了Bytet ...

  8. Web前端学习过程

    推荐学习网站www.freecodecamp.cn http://www.w3school.com.cn/ 步骤: 作者:张帅 知乎链接:https://www.zhihu.com/question/ ...

  9. GregorianCalendar类

    Calendar类实现了公历日历,GregorianCalendar是Calendar类的一个具体实现. Calendar 的getInstance()方法返回一个默认用当前的语言环境和时区初始化的G ...

  10. Assertion failure in -[UITableView _classicHeightForRowAtIndexPath:], /SourceCache/UIKit_Sim/UIKit-3318/UITableView.m:10772

    Assertion failure in -[UITableView _classicHeightForRowAtIndexPath:], /SourceCache/UIKit_Sim/UIKit-3 ...