重播选项(分布式重播管理工具)

Microsoft SQL Server Distributed Replay 管理工具是一种命令行工具, DReplay.exe可用于与分布式重播控制器通信。 本主题介绍 replay 命令行选项和相应的语法。

replay 选项启动事件重播阶段,在该阶段中,控制器将重播数据调度到指定客户端,启动分布式重播并同步客户端。 每个参与重播的客户端可以选择记录重播活动并在本地保存结果跟踪文件。

“主题链接”图标有关与管理工具语法一起使用的语法约定的详细信息,请参阅 Transact-SQL 语法约定(Transact-SQL)。

语法


      dreplay replay [-mcontroller] -dcontroller_working_dir [-o]
    [-starget_server] -wclients [-cconfig_file]
    [-fstatus_interval]

参数

-m 控制器 指定控制器的计算机名称。 可以用“localhost”或“.”指代本地计算机。

如果未指定 -m 参数,则使用本地计算机。

-d controller_working_dir 指定将存储中间文件的控制器上的目录。 -d 参数是必需的。

需要满足以下要求:

  • 目录必须位于控制器上。

  • 必须指定以驱动器号开头(例如 c:\WorkingDir)的完整路径。

  • 路径不能以反斜杠“\”结尾。

  • 不支持 UNC 路径。

-o 捕获客户端的重播活动,并将其保存到客户端配置文件中元素指定的<ResultDirectory>路径中的结果跟踪文件。 DReplayClient.xml

如果 -o 参数未指定,结果跟踪文件就不会生成。 在重播结束时,控制台输出将返回摘要信息,但不提供其他重播统计信息。

-s target_server 指定应对其重播分布式工作负荷的目标 SQL Server 实例。 必须以 server_name[\instance name] 格式指定此参数。

不能使用“localhost”或“.”作为目标服务器。

如果重播配置文件 部分指定了 <Server> 元素,则不需要 <ReplayOptions> -s DReplay.exe.replay.config参数。

如果使用 -s 参数,则将忽略重播配置文件 <Server> 部分中的 <ReplayOptions> 元素。

-w 客户端 此必需参数是逗号分隔的列表(不含空格),指定应参与分布式重播的客户端的计算机名称。 不允许使用 IP 地址。 注意,客户端必须已向控制器注册。

注意

当客户端服务启动时,每个客户端都向客户端配置文件中指定的控制器注册。

-c config_file 重播配置文件的完整路径;用于指定存储在其他位置时的位置。

若要使用重播配置文件 的默认值,则不需要 -c DReplay.exe.replay.config参数。

-f status_interval 指定要显示状态的频率(以秒为单位)。

如果未指定 -f ,则默认间隔为 30 秒。

示例

在本例中,分布式重播从修改的重播配置文件 DReplay.exe.replay.config派生其大部分行为。

  • -m 参数指定名为 controller1 的计算机充当控制器。 当控制器服务在另一台计算机上运行时,必须指定计算机名称。

  • -d 参数指定中间文件在控制器上的位置 c:\WorkingDir

  • -o 参数指定每个指定的客户端捕获重播活动并将其保存到结果跟踪文件中。 注意:可使用配置文件中的 <ResultTrace> 元素指定是否记录行计数和结果集。

  • -w 参数指定计算机 client1client4 作为客户端参与分布式重播。

  • -c 参数用来指向修改过的配置文件 DReplay.exe.replay.config

  • 因为重播配置文件 元素中指定了 <Server> 元素,所以不需要 <ReplayOptions> -s DReplay.exe.replay.config参数。

当管理工具从不是控制器的计算机运行时,使用下面的语法启动事件重播阶段:

dreplay replay -m controller1 -d c:\WorkingDir -o -w client1,client2,client3,client4 -c c:\DReplay.exe.replay.config

若要指定同步顺序模式,应将 <SequencingMode> 文件的 DReplay.exe.replay.config 元素设置为与 synchronization值相等。 重播配置文件的 <ResultTrace> 部分经过修改以指定记录行计数。 以下 XML 示例显示了这些更改:

<?xml version='1.0'?>
<Options>
    <ReplayOptions>
        <Server>server_name\replay_target_instance</Server>
        <SequencingMode>synchronization</SequencingMode>
        <ConnectTimeScale></ConnectTimeScale>
        <ThinkTimeScale></ThinkTimeScale>
        <HealthmonInterval>60</HealthmonInterval>
        <QueryTimeout>3600</QueryTimeout>
        <ThreadsPerClient></ThreadsPerClient>
    </ReplayOptions>
    <OutputOptions>
        <ResultTrace>
            <RecordRowCount>Yes</RecordRowCount>
            <RecordResultSet>No</RecordResultSet>
        </ResultTrace>
    </OutputOptions>
</Options>

若要指定压力顺序模式,应将 <SequencingMode> 文件的 DReplay.exe.replay.config 元素设置为与 stress值相等。 <ConnectTimeScale><ThinkTimeScale> 元素设置为值 50 (以指定 50%)。 有关连接时间和思考时间的详细信息,请参阅 Configure Distributed Replay。 以下 XML 示例显示了这些更改:

<?xml version='1.0'?>
<Options>
    <ReplayOptions>
        <Server>server_name\replay_target_instance_name</Server>
        <SequencingMode>stress</SequencingMode>
        <ConnectTimeScale>50</ConnectTimeScale>
        <ThinkTimeScale>50</ThinkTimeScale>
        <HealthmonInterval>60</HealthmonInterval>
        <QueryTimeout>3600</QueryTimeout>
        <ThreadsPerClient></ThreadsPerClient>
    </ReplayOptions>
    <OutputOptions>
        <ResultTrace>
            <RecordRowCount>Yes</RecordRowCount>
            <RecordResultSet>No</RecordResultSet>
        </ResultTrace>
    </OutputOptions>
</Options>

权限

您必须作为交互用户、本地用户或域用户帐户运行管理工具。 若要使用本地用户帐户,管理工具和控制器必须在同一台计算机上运行。

有关详细信息,请参阅 Distributed Replay Security

另请参阅

重播跟踪数据查看重播结果SQL Server Distributed ReplayConfigure Distributed ReplaySQL Server Distributed Replay Forumusing Distributed Replay to Load test your SQL Server - Part 2Using Distributed Replay to Load Test your SQL Server - Part 1