Tsung测试Tcp协议的应用或接口

2023-11-06 02:10

本文主要是介绍Tsung测试Tcp协议的应用或接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用Tsung模拟基于Tcp的业务流程,实属无奈。因ConnectManager部署在linux下,其中,Loadrunner的winsocket因不支持linux platform而无法使用,而Jmeter 又因本身太耗机器的资源,所以,最后决定探索一下Tsung--这个神奇而又让人感到很无奈的工具。

说它无奈主要是它的易用性,一切设置,一切脚本处理都要在xml文档里编写,对于一个使用loadrunner和Jmeter的人,这是相当的残酷的。原因有以下:

1、user manual是英文版的,虽然对我来说没所谓,但是,相信大部分人都会感到整个人都不好了

2、目前网上的资料,基本都是浅浅的

3、tsung脚本的语法是tsung-1.0.dtd,只有元素和属性的值,但是,没有任何说明

虽然,有各种原因,但是,我还是踏上了这条不归路。下面我主要记录一下,我解决这个问题的路程:

首先,我想到了看tsung-1.0.dtd,因为我相信脚本的正确性绝对是依赖于这个dtd文档的,其实,用过tsung的朋友可以发现,tsung脚本运行起来以后,客户端与服务端建立的连接有三种方式,下面贴一下Tsung脚本的位置和dtd文档中,对这个的定义:

 

  <servers><server host="192.168.14.101" port="9284" type="tcp"></server></servers>

我们看一下,<server>标签里的type属性在dtd文档里的定义:

 

<!ATTLIST server21      host   NMTOKEN #REQUIRED22      port   NMTOKEN #REQUIRED23      weight NMTOKEN "1"24      type (ssl | tcp | udp | erlang | ssl6 | tcp6 | udp6 |bosh | bosh_ssl | websocket) #REQUIRED>

从而可以看出,客户端与服务端建立的连接方式支持多种,我要建立的是Tcp连接,所以,我选择type="tcp",接下来就是session里建立连接,发消息的业务流程了,而问题也出在了这里,下面贴一下脚本里对session部分的定义:

 

<session probability="100" name="raw" type="ts_raw">

probability和name属性就不用介绍了,刚才的server标签定义了底层的连接方式,而这里的type要定义的则是通信时使用的协议类型,我们在dtd里看一下这个type属性的定义:

 

<!ATTLIST session
133     name         CDATA #REQUIRED
134     bidi         CDATA #IMPLIED
135     persistent   (true | false) #IMPLIED
136     probability   NMTOKEN #IMPLIED
137     weight        NMTOKEN #IMPLIED
138     type         (ts_jabber | ts_http | ts_raw | ts_pgsql | ts_ldap | ts_webdav |ts_mysql| ts_fs | ts_shell | ts_job | ts_websocket | ts_amqp | ts_mqtt) #REQUIRED>

从dtd里可以看出,session标签里type属性的值为:ts_jabber | ts_http | ts_raw | ts_pgsql | ts_ldap | ts_webdav |ts_mysql| ts_fs | ts_shell | ts_job | ts_websocket | ts_amqp | ts_mqtt,这里的属性值决定了Tsung可以测试的相关协议的插件,从名称上来看,ts_raw可以作为我查找资料的对象,在user manual里第二章节是介绍tsung的主要功能的,其中2.11章节Raw plugin related features的说明是这样的的:

2.11. Raw plugin related features

 

  • TCP / UDP / SSL compatible
  • raw messages
  • no_ack, local or global ack for messages

 

当我看到TCP/UDP/SSL compatible,raw message,我好开心。于是,我决定去github:github.com/processone/tsung上看一下tsung的源码以及tsung目前的bug库https://github.com/processone/tsung/issues,从gihub的examples文件夹处,我看到了:,进入这个文件夹我看到了

同时,我在bug库里看到了#115bug,于是,我更加坚信Tsung对基于Tcp协议的业务流程的测试。于是,根据开发给的接口设计文档,开始业务流程的第一步:从服务器获取sessionID

<transaction name="open"><request><raw data="00520005150805134521f84409ba6f5f317c6613dc201018caeb" ack="local"></raw></request>

从tsung.dump中,成功看到send和recv:其中,recv中这串618...数字是sessionID

开始业务流程的第三步:登录,但是,有一个问题是登录时需要用到刚才的sessionID,这就用到了关联,与loadrunner和Jmeter一样,在Tsung里模拟时,也同样需要用到关联将响应中动态数据取出来,作为下一人请求的请求内容。这里,需要参考user manual的Advanced Feature章节,我在这里第一时间想到的是用正则表达式,从user manual里这句话,“the regexp engine uses the re module, a Perl like regular expressions module for Erlang.”明显觉察出,此处的正则表达式或许跟之前在Linux下用的正则表达式有一些区别。但是,不知道有什么区别,所以,一如既往的用linux下的语法写正则表达式,于是,写成:re="[6][0-9]{18}",具体代码贴下:

<request><dyn_variable name="sessionID"  re="6[0-9]{18}"/><raw data="00520005150805134521f84409ba6f5f317c6613dc201018caeb" ack="local"></raw></request>

运行后,无果,取出来的值为空。抓狂,抓狂,抓狂,重要的事情我要说三遍。我一直觉得是因为我把正则表达式放在请求前,正则表达式匹配是字节流,而正则表达式的作用范围是字符串,所以取的值为空(后来,证明我是错误的)。后来,于绝望中看了Erlang,决定利用Erlang函数处理请求,然后利用字符串截取获取我要的sessionID,但是,苦于获取请求这个阶段就很无望。于绝望中,在一个群里说了一下这个问题,一朋友指出有可能是正则表达式的问题,于是,提醒在要匹配的模式用“()”括起来,即:re="(6[0-9]{18})"死马当活马医,但是,奇迹真的发生了,我成功的取到了sessionID.事实证明,此正则表达式非彼表达式。  

 

接下来,进行登录,发消息流程,贴代码说话:

 

<transaction name="login"><request subst="true"> <raw data=" 119   1             %%_sessionID%%&lt;iq>&lt;sessionid>%%_sessionID%%&lt;/sessionid>&lt;login>hanhy,hanhy123&lt;login>&lt;/iq>" ack="local"></raw></request></transaction><transaction name="sendmsg"><request subst="true"> <raw data=" 124   3             %%_sessionID%%&lt;message>&lt;sessionid>%%_sessionID%%&lt;/sessionid>&lt;content>tsungMsg&lt;/content>&lt;/message>" ack="local"></raw></request></transaction>

 

业务流程模拟成功解决。

 

 

 

 

 

 

 


 

 

转载于:https://www.cnblogs.com/comeonbaby/p/4778466.html

这篇关于Tsung测试Tcp协议的应用或接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/353875

相关文章

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

从基础到高阶详解Python多态实战应用指南

《从基础到高阶详解Python多态实战应用指南》这篇文章主要从基础到高阶为大家详细介绍Python中多态的相关应用与技巧,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、多态的本质:python的“鸭子类型”哲学二、多态的三大实战场景场景1:数据处理管道——统一处理不同数据格式

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.