zoukankan      html  css  js  c++  java
  • SQL Replay使用指南

    一. SQL Replay简介

    SQL Replay它是SQL Server Profiler中的一个trace模板,它将收集数据库服务器中必要的事件trace,用于在相同或不同的服务器上回放。通过改进模板脚本,我们可以更好的生成自定义的回放trace。这类trace主要可以帮助我们分析语句在同一台服务器的不同数据库对象上运行的性能(如索引、主键等),检测这些数据库对象变更前后的性能差异;也可以分析语句在不同数据库服务器的相同数据库对象上的运行性能,检测服务器不同硬件等配置的性能差异。

    二. SQL Replay脚本

    DECLARE @rc int
    DECLARE @TraceID int
    DECLARE @maxfilesize bigint
    DECLARE @DateTime datetime
    DECLARE @filecount INT
    DECLARE @path VARCHAR(100)
    DECLARE @WHO VARCHAR(200)


    ----------------------------------修改以下参数----------------------------------

    SET @maxfilesize = 300                --文件最大的大小,单位:M
    SET @filecount=5                --文件个数
    SET @DateTime = '2013-05-08 10:00:00.000'    --trace截止日期   
    SET @path='E:\BIFLT_Trace_Replay'        --trace文件保存路径
    SET @WHO='%你的用户名%'                --过滤用户

    ----------------------------------修改以上参数----------------------------------
    SET @path=REPLACE(@path,'.TRC','')
    exec @rc = sp_trace_create @TraceID output, 2, @path, @maxfilesize , @Datetime,@filecount
    if (@rc != 0) goto error

    -- Set the events
    declare @on bit
    set @on = 1
    exec sp_trace_setevent @TraceID, 78, 7, @on
    exec sp_trace_setevent @TraceID, 78, 8, @on
    exec sp_trace_setevent @TraceID, 78, 9, @on
    exec sp_trace_setevent @TraceID, 78, 6, @on
    exec sp_trace_setevent @TraceID, 78, 10, @on
    exec sp_trace_setevent @TraceID, 78, 14, @on
    exec sp_trace_setevent @TraceID, 78, 26, @on
    exec sp_trace_setevent @TraceID, 78, 3, @on
    exec sp_trace_setevent @TraceID, 78, 11, @on
    exec sp_trace_setevent @TraceID, 78, 35, @on
    exec sp_trace_setevent @TraceID, 78, 51, @on
    exec sp_trace_setevent @TraceID, 78, 12, @on
    exec sp_trace_setevent @TraceID, 78, 60, @on
    exec sp_trace_setevent @TraceID, 74, 7, @on
    exec sp_trace_setevent @TraceID, 74, 8, @on
    exec sp_trace_setevent @TraceID, 74, 9, @on
    exec sp_trace_setevent @TraceID, 74, 6, @on
    exec sp_trace_setevent @TraceID, 74, 10, @on
    exec sp_trace_setevent @TraceID, 74, 14, @on
    exec sp_trace_setevent @TraceID, 74, 26, @on
    exec sp_trace_setevent @TraceID, 74, 3, @on
    exec sp_trace_setevent @TraceID, 74, 11, @on
    exec sp_trace_setevent @TraceID, 74, 35, @on
    exec sp_trace_setevent @TraceID, 74, 51, @on
    exec sp_trace_setevent @TraceID, 74, 12, @on
    exec sp_trace_setevent @TraceID, 74, 60, @on
    exec sp_trace_setevent @TraceID, 53, 7, @on
    exec sp_trace_setevent @TraceID, 53, 8, @on
    exec sp_trace_setevent @TraceID, 53, 9, @on
    exec sp_trace_setevent @TraceID, 53, 6, @on
    exec sp_trace_setevent @TraceID, 53, 10, @on
    exec sp_trace_setevent @TraceID, 53, 14, @on
    exec sp_trace_setevent @TraceID, 53, 26, @on
    exec sp_trace_setevent @TraceID, 53, 3, @on
    exec sp_trace_setevent @TraceID, 53, 11, @on
    exec sp_trace_setevent @TraceID, 53, 35, @on
    exec sp_trace_setevent @TraceID, 53, 51, @on
    exec sp_trace_setevent @TraceID, 53, 12, @on
    exec sp_trace_setevent @TraceID, 53, 60, @on
    exec sp_trace_setevent @TraceID, 70, 7, @on
    exec sp_trace_setevent @TraceID, 70, 8, @on
    exec sp_trace_setevent @TraceID, 70, 9, @on
    exec sp_trace_setevent @TraceID, 70, 6, @on
    exec sp_trace_setevent @TraceID, 70, 10, @on
    exec sp_trace_setevent @TraceID, 70, 14, @on
    exec sp_trace_setevent @TraceID, 70, 26, @on
    exec sp_trace_setevent @TraceID, 70, 3, @on
    exec sp_trace_setevent @TraceID, 70, 11, @on
    exec sp_trace_setevent @TraceID, 70, 35, @on
    exec sp_trace_setevent @TraceID, 70, 51, @on
    exec sp_trace_setevent @TraceID, 70, 12, @on
    exec sp_trace_setevent @TraceID, 70, 60, @on
    exec sp_trace_setevent @TraceID, 77, 7, @on
    exec sp_trace_setevent @TraceID, 77, 8, @on
    exec sp_trace_setevent @TraceID, 77, 9, @on
    exec sp_trace_setevent @TraceID, 77, 6, @on
    exec sp_trace_setevent @TraceID, 77, 10, @on
    exec sp_trace_setevent @TraceID, 77, 14, @on
    exec sp_trace_setevent @TraceID, 77, 26, @on
    exec sp_trace_setevent @TraceID, 77, 3, @on
    exec sp_trace_setevent @TraceID, 77, 11, @on
    exec sp_trace_setevent @TraceID, 77, 35, @on
    exec sp_trace_setevent @TraceID, 77, 51, @on
    exec sp_trace_setevent @TraceID, 77, 12, @on
    exec sp_trace_setevent @TraceID, 77, 60, @on
    exec sp_trace_setevent @TraceID, 14, 7, @on
    exec sp_trace_setevent @TraceID, 14, 8, @on
    exec sp_trace_setevent @TraceID, 14, 1, @on
    exec sp_trace_setevent @TraceID, 14, 9, @on
    exec sp_trace_setevent @TraceID, 14, 2, @on
    exec sp_trace_setevent @TraceID, 14, 6, @on
    exec sp_trace_setevent @TraceID, 14, 10, @on
    exec sp_trace_setevent @TraceID, 14, 14, @on
    exec sp_trace_setevent @TraceID, 14, 26, @on
    exec sp_trace_setevent @TraceID, 14, 3, @on
    exec sp_trace_setevent @TraceID, 14, 11, @on
    exec sp_trace_setevent @TraceID, 14, 35, @on
    exec sp_trace_setevent @TraceID, 14, 51, @on
    exec sp_trace_setevent @TraceID, 14, 12, @on
    exec sp_trace_setevent @TraceID, 14, 60, @on
    exec sp_trace_setevent @TraceID, 15, 7, @on
    exec sp_trace_setevent @TraceID, 15, 15, @on
    exec sp_trace_setevent @TraceID, 15, 8, @on
    exec sp_trace_setevent @TraceID, 15, 9, @on
    exec sp_trace_setevent @TraceID, 15, 6, @on
    exec sp_trace_setevent @TraceID, 15, 10, @on
    exec sp_trace_setevent @TraceID, 15, 14, @on
    exec sp_trace_setevent @TraceID, 15, 26, @on
    exec sp_trace_setevent @TraceID, 15, 3, @on
    exec sp_trace_setevent @TraceID, 15, 11, @on
    exec sp_trace_setevent @TraceID, 15, 35, @on
    exec sp_trace_setevent @TraceID, 15, 51, @on
    exec sp_trace_setevent @TraceID, 15, 12, @on
    exec sp_trace_setevent @TraceID, 15, 60, @on
    exec sp_trace_setevent @TraceID, 17, 7, @on
    exec sp_trace_setevent @TraceID, 17, 8, @on
    exec sp_trace_setevent @TraceID, 17, 1, @on
    exec sp_trace_setevent @TraceID, 17, 9, @on
    exec sp_trace_setevent @TraceID, 17, 2, @on
    exec sp_trace_setevent @TraceID, 17, 6, @on
    exec sp_trace_setevent @TraceID, 17, 10, @on
    exec sp_trace_setevent @TraceID, 17, 14, @on
    exec sp_trace_setevent @TraceID, 17, 26, @on
    exec sp_trace_setevent @TraceID, 17, 3, @on
    exec sp_trace_setevent @TraceID, 17, 11, @on
    exec sp_trace_setevent @TraceID, 17, 35, @on
    exec sp_trace_setevent @TraceID, 17, 51, @on
    exec sp_trace_setevent @TraceID, 17, 12, @on
    exec sp_trace_setevent @TraceID, 17, 60, @on
    exec sp_trace_setevent @TraceID, 100, 7, @on
    exec sp_trace_setevent @TraceID, 100, 8, @on
    exec sp_trace_setevent @TraceID, 100, 1, @on
    exec sp_trace_setevent @TraceID, 100, 9, @on
    exec sp_trace_setevent @TraceID, 100, 6, @on
    exec sp_trace_setevent @TraceID, 100, 10, @on
    exec sp_trace_setevent @TraceID, 100, 14, @on
    exec sp_trace_setevent @TraceID, 100, 26, @on
    exec sp_trace_setevent @TraceID, 100, 3, @on
    exec sp_trace_setevent @TraceID, 100, 11, @on
    exec sp_trace_setevent @TraceID, 100, 35, @on
    exec sp_trace_setevent @TraceID, 100, 51, @on
    exec sp_trace_setevent @TraceID, 100, 12, @on
    exec sp_trace_setevent @TraceID, 100, 60, @on
    exec sp_trace_setevent @TraceID, 10, 7, @on
    exec sp_trace_setevent @TraceID, 10, 15, @on
    exec sp_trace_setevent @TraceID, 10, 31, @on
    exec sp_trace_setevent @TraceID, 10, 8, @on
    exec sp_trace_setevent @TraceID, 10, 9, @on
    exec sp_trace_setevent @TraceID, 10, 2, @on
    exec sp_trace_setevent @TraceID, 10, 10, @on
    exec sp_trace_setevent @TraceID, 10, 26, @on
    exec sp_trace_setevent @TraceID, 10, 3, @on
    exec sp_trace_setevent @TraceID, 10, 11, @on
    exec sp_trace_setevent @TraceID, 10, 35, @on
    exec sp_trace_setevent @TraceID, 10, 51, @on
    exec sp_trace_setevent @TraceID, 10, 12, @on
    exec sp_trace_setevent @TraceID, 10, 60, @on
    exec sp_trace_setevent @TraceID, 10, 6, @on
    exec sp_trace_setevent @TraceID, 10, 14, @on
    exec sp_trace_setevent @TraceID, 11, 7, @on
    exec sp_trace_setevent @TraceID, 11, 8, @on
    exec sp_trace_setevent @TraceID, 11, 9, @on
    exec sp_trace_setevent @TraceID, 11, 2, @on
    exec sp_trace_setevent @TraceID, 11, 6, @on
    exec sp_trace_setevent @TraceID, 11, 10, @on
    exec sp_trace_setevent @TraceID, 11, 14, @on
    exec sp_trace_setevent @TraceID, 11, 26, @on
    exec sp_trace_setevent @TraceID, 11, 3, @on
    exec sp_trace_setevent @TraceID, 11, 11, @on
    exec sp_trace_setevent @TraceID, 11, 35, @on
    exec sp_trace_setevent @TraceID, 11, 51, @on
    exec sp_trace_setevent @TraceID, 11, 12, @on
    exec sp_trace_setevent @TraceID, 11, 60, @on
    exec sp_trace_setevent @TraceID, 72, 7, @on
    exec sp_trace_setevent @TraceID, 72, 8, @on
    exec sp_trace_setevent @TraceID, 72, 9, @on
    exec sp_trace_setevent @TraceID, 72, 6, @on
    exec sp_trace_setevent @TraceID, 72, 10, @on
    exec sp_trace_setevent @TraceID, 72, 14, @on
    exec sp_trace_setevent @TraceID, 72, 26, @on
    exec sp_trace_setevent @TraceID, 72, 3, @on
    exec sp_trace_setevent @TraceID, 72, 11, @on
    exec sp_trace_setevent @TraceID, 72, 35, @on
    exec sp_trace_setevent @TraceID, 72, 51, @on
    exec sp_trace_setevent @TraceID, 72, 12, @on
    exec sp_trace_setevent @TraceID, 72, 60, @on
    exec sp_trace_setevent @TraceID, 71, 7, @on
    exec sp_trace_setevent @TraceID, 71, 8, @on
    exec sp_trace_setevent @TraceID, 71, 9, @on
    exec sp_trace_setevent @TraceID, 71, 6, @on
    exec sp_trace_setevent @TraceID, 71, 10, @on
    exec sp_trace_setevent @TraceID, 71, 14, @on
    exec sp_trace_setevent @TraceID, 71, 26, @on
    exec sp_trace_setevent @TraceID, 71, 3, @on
    exec sp_trace_setevent @TraceID, 71, 11, @on
    exec sp_trace_setevent @TraceID, 71, 35, @on
    exec sp_trace_setevent @TraceID, 71, 51, @on
    exec sp_trace_setevent @TraceID, 71, 12, @on
    exec sp_trace_setevent @TraceID, 71, 60, @on
    exec sp_trace_setevent @TraceID, 12, 7, @on
    exec sp_trace_setevent @TraceID, 12, 15, @on
    exec sp_trace_setevent @TraceID, 12, 31, @on
    exec sp_trace_setevent @TraceID, 12, 8, @on
    exec sp_trace_setevent @TraceID, 12, 1, @on
    exec sp_trace_setevent @TraceID, 12, 9, @on
    exec sp_trace_setevent @TraceID, 12, 6, @on
    exec sp_trace_setevent @TraceID, 12, 10, @on
    exec sp_trace_setevent @TraceID, 12, 14, @on
    exec sp_trace_setevent @TraceID, 12, 26, @on
    exec sp_trace_setevent @TraceID, 12, 3, @on
    exec sp_trace_setevent @TraceID, 12, 11, @on
    exec sp_trace_setevent @TraceID, 12, 35, @on
    exec sp_trace_setevent @TraceID, 12, 51, @on
    exec sp_trace_setevent @TraceID, 12, 12, @on
    exec sp_trace_setevent @TraceID, 12, 60, @on
    exec sp_trace_setevent @TraceID, 13, 7, @on
    exec sp_trace_setevent @TraceID, 13, 8, @on
    exec sp_trace_setevent @TraceID, 13, 1, @on
    exec sp_trace_setevent @TraceID, 13, 9, @on
    exec sp_trace_setevent @TraceID, 13, 6, @on
    exec sp_trace_setevent @TraceID, 13, 10, @on
    exec sp_trace_setevent @TraceID, 13, 14, @on
    exec sp_trace_setevent @TraceID, 13, 26, @on
    exec sp_trace_setevent @TraceID, 13, 3, @on
    exec sp_trace_setevent @TraceID, 13, 11, @on
    exec sp_trace_setevent @TraceID, 13, 35, @on
    exec sp_trace_setevent @TraceID, 13, 51, @on
    exec sp_trace_setevent @TraceID, 13, 12, @on
    exec sp_trace_setevent @TraceID, 13, 60, @on


    -- Set the Filters
    declare @intfilter int
    declare @bigintfilter bigint

    exec sp_trace_setfilter @TraceID, 11, 0, 6, @WHO
    -- Set the trace status to start
    exec sp_trace_setstatus @TraceID, 1

    -- display trace id for future references
    select TraceID=@TraceID
    goto finish

    error:
    select ErrorCode=@rc

    finish:
    go

    三. 其他实用脚本

    --查看当前系统运行中的trace

    SELECT * FROM SYS.TRACES

    --暂停trace

    EXEC sp_trace_setstatus @traceid = 3,@status = 0

    --停止trace(须先执行暂停trace的脚本)

    EXEC sp_trace_setstatus @traceid = 3,@status = 2


    四. 示例

    1. 创建ReplayTrace,自定义各类参数

    1

    2. 拷贝Trace文件

    Trace文件拷贝至用户本地,使用Profiler打开Trace File

    clip_image006

    3. Start Replay

    3

    4. 选择服务器

    4

    5. 回放trace

    用户自定义回放选项

    5

    6. 抓取回放trace的性能

    对比语句的执行性能,服务器各性能指标等。

  • 相关阅读:
    友链
    OI日常
    P4451 [国家集训队]整数的lqp拆分 生成函数
    AT4831 [ABC155F] Perils in Parallel 生成树
    P4438 [HNOI/AHOI2018]道路 树DP
    CF383E Vowels 子集DP 容斥
    P5488 差分与前缀和 生成函数+多项式EXP
    CF115E Linear Kingdom Races 线段树优化DP
    CF49E Common ancestor 区间DP
    P5047 [Ynoi2019 模拟赛] Yuno loves sqrt technology II 莫队二次离线
  • 原文地址:https://www.cnblogs.com/iamasqldba/p/3085050.html
Copyright © 2011-2022 走看看