性能测试 CODEARTS PERFTEST-添加请求信息(报文):操作步骤

时间:2024-04-10 11:27:15

操作步骤

  1. 登录性能测试服务控制台,在左侧导航栏中选择“PerfTest测试工程”
  2. 在待编辑PerfTest测试工程所在行,单击工程名称进入测试工程详情页面。
  3. 选择“测试用例”页签,在左侧“用例列表”下选择待添加请求信息的用例。
  4. 在“用例步骤”页签中,选择待添加请求信息的用例,单击“添加请求”。
  5. “报文”页签,请根据业务的协议类型选择匹配的协议类型,当前支持HTTP/HTTPS/TCP/UDP/HLS/RTMP/WEBSOCKET/HTTP-FLV/MQTT。请参照以下对应的报文参数表设置基本信息。

    表1 HTTP和HTTPS协议报文参数

    参数

    参数说明

    请求方法

    可以选择GET、POST、PATCH、PUT或DELETE。

    请求地址

    发送请求的URL地址,比如“http://域名/路径”,也可以包含参数的部分“http://域名/路径?key1=value1&key2=value2”。

    支持变量输入,详情请参见插入变量

    响应超时(ms)

    发送请求,等待服务器响应的超时时间。响应超时时间范围是20ms到5分钟。

    如果不设置此参数,默认响应超时时间为5000ms。

    携带cookie

    说明:

    用例下至少已有一个请求信息,添加新的请求信息时进行设置。

    • 自动获取:使用响应设置的cookie。
    • 手动设置:只使用当前请求信息设置在头域中的cookie。

    自动重定向

    选择是否跳转到重定向的地址,开关默认打开,即默认自动跳转到重定向的地址。

    请求参数

    请求地址中的参数设置。

    单击“添加请求参数”,设置“名称”和“值”。选择是否勾选“Url Encode”,默认为不勾选,勾选后对请求参数的值做URL编码。

    如果您不需要添加请求参数,可以单击“删除”,删除请求参数。

    请求头

    请根据压测服务器需要校验或者使用的头域来添加相关头域及内容。性能测试服务没有对必填头域作要求,仅透传用户定义的头域到压测服务器。“头域”的说明请参见头域说明

    单击“添加头域”,设置“头域”和“值”,如果您不需要添加头域信息,单击“删除”,删除报文头域。

    单击“批量编辑”,可以切换成文本框编辑模式同时对多个头域进行编辑;单击“键值编辑”,可返回“键值对”编辑模式。

    说明:

    “请求方法”为“POST”或“PUT”,且“头域”为“Content-Type”时,“值”有三种类型,且支持插入变量:

    • 自定义:直接在输入框中输入值。
    • application/x-www-form-urlencoded:请求体为可添加的键值对形式,值为文本。
    • multipart/form-data:请求体为可添加的键值对形式,值可为文本或文件。值为文件时,支持body体导入。

    Body体

    实体的主体部分包含一个由任意数据组成的数据块,并不是所有的报文都包含实体的主体部分。

    如果已设置全局变量或响应提取的局部变量,可在报文内容部分引用变量,执行压测任务过程会将报文内容中的变量值动态替换为指定的值。

    1. 在请求内容输入框内输入“$”。
    2. 在“插入变量”对话框中,配置参数。详情请参见插入变量
    3. 单击“选择”。
    表2 TCP协议报文参数

    参数

    参数说明

    IP

    发送请求到被测服务器的IP地址。

    端口号

    发送请求到被测服务器的端口号。

    连接超时

    发起连接,服务器无响应的超时时间。连接超时时间范围是20ms到60s。

    返回超时

    连接建立成功,等待响应返回的超时时间。返回超时时间范围是20ms到60s。

    连接设置

    • 重复使用连接:请求响应完成后,不断开连接,复用连接发送接收下一次请求响应。
    • 关闭连接:每次完成请求响应完成后,断开连接,下一次重新建立连接。

    返回结束设置

    通过返回结束设置,来判断本次请求的响应内容是否已经接收完成。

    • 返回数据长度:设置返回数据的长度,单位字节。当接收到此长度的响应内容时,数据接收完成。
    • 结束符:设置返回数据的结束标记。当接收到结束符时,数据接收完成 。
      说明:

      结束符建议设置一个唯一的结束标记,如果设置的结束符在响应内容中存在多个,当接收到第一个结束符时,就认为响应内容已经接收完成,这样接收的响应数据就不完整。

    内容格式

    请根据被测服务器的业务请求内容,选择“字符串”或“16进制码流”。

    说明:

    16进制码流的内容取值范围为“0~9”和“a~f”,且总字符个数为双数。

    如果已设置全局变量或响应提取的局部变量,可在报文内容部分引用变量,执行压测任务过程会将报文内容中的变量值动态替换为指定的值。

    1. 在请求内容输入框内输入“$”。
    2. 在“插入变量”对话框中,配置参数。详情请参见插入变量
    3. 单击“选择”。
    表3 UDP协议报文参数

    参数

    参数说明

    IP

    发送请求到被测服务器的IP地址。

    端口号

    发送请求到被测服务器的端口号。

    返回结束设置

    通过返回结束设置,来判断本次请求的响应内容是否已经接收完成。

    • 返回数据长度:设置返回数据的长度,单位字节。当接收到此长度的响应内容时,数据接收完成。
    • 结束符:设置返回数据的结束标记。当接收到结束符时,数据接收完成 。
      说明:

      结束符建议设置一个唯一的结束标记,如果设置的结束符在响应内容中存在多个,当接收到第一个结束符时,就认为响应内容已经接收完成,这样接收的响应数据就不完整。

    内容格式

    请根据被测服务器的业务请求内容,选择“字符串”或“16进制码流”。

    说明:

    16进制码流的内容取值范围为“0~9”和“a~f”,且总字符个数为双数。

    如果已设置全局变量或响应提取的局部变量,可在报文内容部分引用变量,执行压测任务过程会将报文内容中的变量值动态替换为指定的值。

    1. 在请求内容输入框内输入“$”。
    2. 在“插入变量”对话框中,配置参数。详情请参见插入变量
    3. 单击“选择”。
    表4 HLS协议报文参数

    参数

    参数说明

    流媒体地址

    视频源的地址,比如“http://域名/路径”。

    播放时长(秒)

    模拟播放的时长。

    说明:

    用例调试时,播放时长会设置为3秒。

    直播缓冲等待请求时间间隔(毫秒)

    直播场景下,视频播放源无新数据时候,尝试获取新数据的时间间隔。

    直播缓冲等待请求的最大次数

    直播场景下,视频播放源无新数据时候,尝试获取新数据的最大次数,如果超过最大次数,则判断为失败。

    表5 RTMP协议报文参数

    参数

    参数说明

    请求方式

    • 推流:将现场的视频信号传到网络的过程。
    • 拉流:服务器里面有流媒体视频文件,用指定地址进行拉取的过程。

    请求方式为“推流”时设置以下参数。

    流媒体服务器地址

    被测流媒体服务器的IP地址。

    端口号

    被测流媒体服务器监听的端口号,RTMP协议默认为1935。

    应用名称

    即推流URL中的AppName,直播流媒体文件存放路径,例如:live。

    流名称

    即推流URL中的StreamName,用来唯一标识一条直播流,例如:livestream。

    推流时长(秒)

    模拟主播推流的时长,单位:秒。

    视频源地址

    用来存放模拟直播推流的视频源文件的OBS地址。目前仅支持flv文件格式,且不支持H.265编码的非标准flv文件。

    请求方式为“拉流”时设置以下参数。

    流媒体服务器地址

    被测流媒体服务器的IP地址。

    端口号

    被测流媒体服务器监听的端口号,RTMP协议默认为1935。

    应用名称

    即拉流URL中的AppName,直播流媒体文件存放路径,例如:live。

    流名称

    即拉流URL中的StreamName,用来唯一标识一条直播流,例如:livestream。

    播放时长(秒)

    模拟观众观看直播的时长,单位:秒。

    表6 WEBSOCKET协议报文参数

    参数

    参数说明

    请求方法

    Connect:与压测网站建立WebSocket连接。

    DisConnect:关闭与压测网站的连接。

    Pong:向压测网站发送pong。

    Ping&Pong:向压测网站发送pong期望返回ping。

    Request:向压测网站发送请求并接收响应。

    ReadOnly:仅接收压测网站发送的信息。

    WriteOnly:仅向压测网站发送信息。

    请求连接地址

    WebSocket连接的URL地址,比如“ws://域名/路径”,支持加密请求,即“wss://域名/路径”。

    连接超时(ms)

    发起连接,服务器无响应的超时时间。连接超时时间范围是20ms到60s。

    说明:

    仅当“请求方法”为“Connect”时,需要设置该参数。

    状态码

    自定义关闭连接对应的状态码。默认值为1000,输入范围为0~4999。

    说明:

    仅当“请求方法”为“DisConnect”时,需要设置该参数。

    请求类型

    请根据被测服务器的业务请求内容,下拉选择“Text”或“Binary”。

    说明:

    仅当“请求方法”为“Request/WriteOnly”时,需要设置该参数。

    请求内容

    根据请求类型中设定格式输入请求信息报文内容。

    说明:

    仅当“请求方法”为“Request/WriteOnly”时,需要设置该参数。

    响应类型

    请根据被测服务器的业务响应内容,下拉选择“Text”或“Binary”。

    说明:

    仅当“请求方法”为“Request/ReadOnly”时,需要设置该参数。

    响应超时(ms)

    连接建立成功,等待响应返回的超时时间。返回超时时间范围是20ms到60s。

    请求头

    请根据压测服务器需要校验或者使用的头域来添加相关头域及内容。性能测试服务没有对必填头域作要求,仅透传用户定义的头域到压测服务器。“头域”的说明请参见头域说明

    单击“添加头域”,设置“头域”和“值”,如果您不需要添加头域信息,单击“删除”,删除报文头域。

    单击“批量编辑”,可以切换成文本框编辑模式同时对多个头域进行编辑;单击“键值编辑”,可返回“键值对”编辑模式。

    表7 HTTP-FLV协议报文参数

    参数

    参数说明

    流媒体地址

    视频源的地址,比如“http://{视频源ip}:8080/live/stream.flv”。

    播放时长

    模拟播放的时长。

    说明:

    用例调试时,播放时长会设置为3秒。

    表8 MQTT协议报文参数

    参数

    参数说明

    请求方法

    Connect:与压测网站建立MQTT连接。

    Publish:发布消息。

    Subscribe:订阅发送的消息。

    DisConnect:关闭与压测网站的MQTT连接。

    请求方法为“Connect”时设置以下参数。

    MQTT版本

    MQTT的版本,当前支持3.1、3.1.1版本。

    传输地址

    MQTT服务器地址,地址支持TCP、SSL、WS、WSS协议。

    超时时间(ms)

    客户端建立连接、发送消息等相关操作的超时时间。

    客户端ID

    MQTT客户端ID。通过“添加随机后缀”开关,可以设置客户端ID是否添加随机后缀。

    用户名

    MQTT客户端设置的用户名。用户名为敏感参数,请通过敏感参数模式的全局变量设值。

    密码

    MQTT客户端设置的密码。密码为敏感参数,请通过敏感参数模式的全局变量设值。

    连接保活时长(s)

    活动心跳间隔时间,单位为秒。

    清空会话

    • 打开开关,客户端和服务器之间建立连接时,会清空上一次连接所保留的会话信息。
    • 关闭开关,客户端和服务器之间建立连接时,不会清空上一次连接所保留的会话信息。

    添加遗嘱

    • 打开开关,添加遗嘱。当客户端异常断开连接时,MQTT代理会自动将该遗嘱消息发布给其他订阅者。
      添加遗嘱时设置以下参数:
      • 主题:遗嘱的主题。
      • 类型:支持Text和Binary类型,可以配置是否添加时间戳。
      • 内容:遗嘱的内容。
      • QoS级别:服务质量等级,用于描述消息传递的可靠性。最多发送一次,适用于实时数据传输;至少发送一次,适用于需要可靠性但允许轻微延迟的应用;只发送一次,适用于需要高可靠性和较大延迟的应用。
      • 保留遗嘱:打开开关,客户端订阅后马上就会收到设置的遗嘱信息;关闭开关,发布遗嘱信息的客户端发生意外断开之后,订阅了该客户端遗嘱信息的客户端才可收到遗嘱消息。
    • 关闭开关,无遗嘱发送。

    请求方法为“Publish”时设置以下参数。

    主题

    发布消息的主题。

    QoS级别

    服务质量等级,用于描述消息传递的可靠性。最多发送一次,适用于实时数据传输;至少发送一次,适用于需要可靠性但允许轻微延迟的应用;只发送一次,适用于需要高可靠性和较大延迟的应用。

    请求类型

    支持Text和Binary类型,可以配置是否添加时间戳。

    请求内容

    请求的详细内容。

    超时时间(ms)

    客户端发送消息的超时时间。

    保留消息

    • 打开开关,客户端断开连接时发布的消息仍会保留在服务器。
    • 关闭开关,客户端断开连接时发布的消息会被清除。

    请求方法为“Subscribe”时设置以下参数。

    订阅主题

    订阅消息的主题,应与发布消息的主题匹配。

    QoS级别

    服务质量等级,用于描述消息传递的可靠性。最多发送一次,适用于实时数据传输;至少发送一次,适用于需要可靠性但允许轻微延迟的应用;只发送一次,适用于需要高可靠性和较大延迟的应用。

    响应类型

    支持Text和Binary类型,可以配置是否添加时间戳。

    超时时间(ms)

    订阅主题的超时时间。

    结束条件

    达到该条件时,结束订阅消息。

    • 触发耗时上限:达到设置的耗时上限时结束订阅消息。
    • 触发收到消息数上限:达到设置的收到消息数上限时结束订阅消息。

    请求方法为“Disconnect”时无需设置参数。

  6. 配置完成后,单击“保存”
support.huaweicloud.com/usermanualnew-cpts/cpts_02_0012.html