sqlserver 抓取所有执行语句 SQL语句分析 死锁 抓取
在多人开发中最头疼的是人少事多没有时间进行codereview,本来功能都没时间写,哪有时间来开会细细来分析代码.软件能跑就行,但是一些影响性能的语句写出来,有可能本人都不知道.找就更
麻烦了.幸亏sqlserver提供了工具可以导出执行语句进行分析.可以看看是哪些语句影响整体性能.工具叫sql server profiler,这玩意可以抓取实例上执行的所有语句\死锁\事物,为分析提供帮助.
开始->sqlserver目录->性能工具->sql server profiler 打开软件新建连接你想抓的实例,然后你就可以看到这个了
点击显示所有事件,会列出可以监视的所有状态.一般分析和用的多的话死TSQL\Stored ProcedureS\Lock 这三个.第一个很简单是SQL语句,第二个是存储过程,第三个是锁的情况.
一般把前两个放在一起分析.可以找到所有的执行语句.第三个用来单独分析来找死锁.
前两个选好以后,转到第一个选项卡,不要保存在文件,保存在文件给没有一样,直接保存到表,这时,你要另外找个数据库了.因为保存到表中相当于往保存的数据库中插入一条记录,然后这个语句
又会产生一个语句,造成无限递归,一会就把服务器搞死,我们一次分析时,直接把要分析的库跟抓取的库放在同一个实例上,结果3分钟后整个SQL挂了,没有响应了,删了抓取表,重启实例服务,重启网站
才好.还好是处理的快.简单说,比如你要分析服务器上的一个实例所有的语句,你要把抓取的结果放在你本地的数据库实例中
放到数据库表中后,因为是结构化数据,所以分析也特别容易,一下贴一张图.抓取的结果放在表中,是会覆盖原表中的数据.还有它抓取数据中,界面在不断的闪烁.也在列表中增加,如果服务器显卡不佳,一会
就给卡死,所以开启以后直接最小化,抓取完毕直接用任务处理器杀掉进程就行.抓取时间跟你们要分析的片段有关.然后用SQL语句直接查出耗时前10,然后个人认领回去修改就行.我存在本地数据库
名字DataA中的表InitTableInfo,这样我们就可以查询下
use DataA select top 100 datediff(second, StartTime, EndTime) costtime, RowNumber, TextData, ApplicationName, ClientProcessID, SPID from InitTableInfo where StartTime is not null and EndTime is not null order by costtime desc
以下是结果展示
第一个是花费的时间,还有对应的语句,以及一些额外的信息.可以看到一些用时最大的达到20多秒.很吓人的额.这样贴出来让个人认领去修改.达到提升执行效率的目的.
2.死锁
程序运行中一些关键模块,比如会员积分和金额代金券等,有些人写的因为不够注意或者当时水平不行,容易些一些死锁.这样我们需要有一个分析的路径.
如果再程序中加入try catch来捕获,自己写的熟悉的模块还好,如果是别人写的另外时间紧任务重.你一时发现不了,你就可以启用死锁了
deadlock graph 会把找到的deadlock放到一个xdl文件中,这玩意用文件夹也打的开,可以分别存储每个deadlock发生的语句和占用的资源.这时间你就可以根据这玩意处理了.
一般处理死锁是相同顺序的读写\优化索引和最小限度的使用表里的数据,对于抓取数据,进行使用行级锁和页级锁.对于非必要的数据进行脏读.单独说又是很多了.这里只介绍工具
保存好的死锁文件,可以送给你的各位同事,