DDT数据驱动性能测试(二)

一、保存数据到入csv、txt文件

1、写代码

2、不写代码

  2.1 从数据库中获取数据,写入文件

    2.1.1 在jdbc取样器下面,添加保存响应到文件(右键-监听器-保存响应到文件)

    2.1.2 文件名称前缀: 写一个文件名包含文件格式:例如 jdbcresult.txt (文件可以是txt、xls、xlsx格式)

    2.1.3 勾选:Don't add number to preffix,Don't add content type suffix,否则保存文件类型会出错

    2.1.4 如果保存的文件名不变,保存响应到文件,保存的则是最后一个取样器执行的结果到文件中,会覆盖前面的响应结果

  2.2 有注册接口,用了参数,我期望把用到的参数值保存到本地文件。

    2.2.1 写代码

    2.2.2 不写代码方法:http://testingpai.com/article/1595507274025

 

二、DDT数据驱动二

1、用sqlite数据库获取数据,作为性能测试输入源数据

2、用传统的csv方式,作为性能测试输入源数据

3、两者的区别

  3.1 使用的数据量如果完全相同的话,csvtxt文件用的内存会比 sqlite的方式大一些

  3.2 csvtxt文件本身包含了我们不需要的数据,所以csvtxt文件大小就要比sqlite方式占用内存要大

    3.2.1 比如:txt文件中有5列,但是,使用csv数据文件设置我只需要使用其中的3列,那么有多余2列的数据也会占用内存。

    3.2.2 sqlite数据库是以查询的方式来获取数据,所以我只需要select查询对应3列数据就可以,这样不会占用更多的内存。

  3.3 csv数据文件设置,不可以从指定位置开始读取数据,因为每次读取,都是读取整个csvtxt文件。而用sqlite数据库查询的方式,可以使用查询语句从指定行查询数据:select xxx from table limit xxx offset xxx。

  3.4 在性能测试中,如果要使用数据驱动性能测试,sqlite查询数据的方 式,要比传统的csv方式要更灵活,效率也更高。

 

三、websocket协议

1、概念:是一种基于TCP的全双工通信协议,websocket这个协议与http协议相同,都是用tcp方式来传输数据

2、协议区分:ws--没有加密的数据传输方式;wss--使用加密方式来传输数据

3、全双工通信

  3.1 http:半双工, 只能从通信的一方主动发生数据给另一方进行数据通信

  3.2 websocket: 全双工, 双方都可以主动发起数据通信

    3.2.1 数据传输:客户端 -> 服务器端发送数据,也可以由服务器端主动 --> 客户端发送数据。

    3.2.2 典型应用:微信,QQ消息提醒,物联网

  3.3 websocket VS socket:两种完全不同的协议

    3.3.1 websocket是应用层的一个协议,是在互联网中进行数据通信的一 个协议,这个协议的数据是暴露在互联网中的

    3.3.2 socket 是服务与服务之间进行数据通信的协议---这种方式的 数据有效率比较高。

    3.3.3 websocket可以用jmeter元件写脚本进行测试,socket就需要写代码来调用

    3.3.4 jmeter测试websocket协议,需要引入插件 jpgc

4、jmeter引入插件

  4.1 jar包:jmeter-plugins-manager-1.7.jar,放到jmeter的libext文件夹 重启jmeter、

  4.2 在"选项"菜单下 plugins manager入口

    4.2.1 installed plugins 已经安装的

    4.2.2 available plugins 可以安装的:搜索 websocket 或者 拉到最下面---勾选 websocket samplers by perter Doornbosch----点击 【apply changes and restart jmeter】

    4.2.3 upgrade 需要升级的

5、编写脚本

  5.1 启动项目:./stwebsocketserver.sh

  5.2 取样器:

    5.2.1 websocket close 关闭

    5.2.2 websocket open connection 建立一个连接:serverURL--ws

    5.2.3 websocket Single Read sample 从服务器上获取消息

    5.2.4 websocket Single write sample 向服务器发送指令:use existing connection 使用已经建立的连接;Data:txt-文本,binary: 二进制

    5.2.5 websocket request-response sample 读-写请求都有

 

四、MQ消息队列

1、实现消息队列的软件很多 mqtt、rabbitmq、kafka .....

2、发送一个消息,服务器收到消息,根据先收到先处理的原则,排队,在前面的就会被先消费,属于异步消息

3、启动项目:./stmqttserver.sh

  3.1 服务端口

    3.1.1 1883 MQTT/tcp 协议端口,可以被外部访问

    3.1.2 11883 MQTT/tcp 协议端口,只能在内部访问

    3.1.3 8883 MQTT/ssl 协议端口

    3.1.4 8083 MQTT/ws 协议端口

    3.1.5 8084 MQTT/wss 协议端口

    3.1.6 18083 HTTP端口,可以通过浏览器访问 admin / public

4、测试

  4.1 安装mq插件:插件管理 > 可安装的插件 > 搜索mqtt > 选择 MQTT Protocol Support, 下载

    注意:插件下载,有可能会失败,因为,这些插件的服务器在国外,所以,网络原因可能导致失败。

  4.2 publisher 发布主题:tcp://youmqttserver_ip:1883 主题、内容

  4.3 subscriber 订阅主题:tcp://youmqttserver_ip:1883 主题

  4.4 MQ异步消息的性能测试

    4.4.1 开启2个jmeter线程组:

      4.4.1.1 1个jmeter进行 主题发布,可以是单个用户发送

      4.4.1.2 1个jmeter进行多用户并发的 主题订阅:设计性能场景进行测试,最终要得到是订阅的性能报告

 

五、dubbo协议

1、现在企业中用springboot做微服务的开发,微服务之间的通信,很多都会用dubbo, 这个协议,通信内容,不会暴露在公网

2、测试:

  2.1 启动服务 ./stdubboserver.sh

  2.2 把jmeter-plugins-dubbo-2.7.3-jar-with-dependencies.jar放到jmeter的 libext文件夹中重启jmeter

  2.3 取样器:dubbo sample

    2.3.1 registry setting填写 注册中心信息

      2.3.1.1 protocol: 协议选择zookeeper,默认端口2181

      2.3.1.2 address: ip:20181

    2.3.2 点击 【get provider list】:yes 出现jmeter有几秒无响应

      2.3.2.1 选择method: list

  2.4 带有参数

    2.4.1 paramType: 开发接口文档给出

    2.4.2 paramValue: 开发接口文档给出

 

内容来源于网络如有侵权请私信删除

文章来源: 博客园

原文链接: https://www.cnblogs.com/hailangboke/p/16183115.html

你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!