最近,利用tsung测试cm的时候,脚本是这样配置的:

<load>
28 <arrivalphase phase="1" duration="2" unit="second">
29 <users maxnumber="19" arrivalrate="10" unit="second"></users>
30 </arrivalphase>
31 </load>
32 <options>
33 <option name="global_number" value="13">
34 </options>
35
36 <sessions>
37 <session probability="100" name="raw" type="ts_raw">
38
45 <transaction name="login">
46 <request subst="true">
47 <raw data=" 119 1 %%_sessionID%%&lt;iq>&lt;sessionid>%%_sessionID%%&lt;/sessionid>&lt;login>hanhy,hanhy123&lt;login>&lt;/iq>" ack="local"></raw>
48 </request>
49 </transaction>
50 <for from="1" to="3" incr="1" var="counter">
51 <transaction name="sendmsg">
52 <!--for from="1" to="2" incr="1" var="counter"-->
53 <request subst="true">
54 <raw data=" 124 3 %%_sessionID%%&lt;message>&lt;sessionid>%%_sessionID%%&lt;/sessionid>&lt;content>tsungMsg%%_counter%%&lt;/content>&lt;/message>" ack="local"></raw>
55 </request>
56 <!--thinktime min="2" max="10" random="true"/-->
57 <!--/for-->
58 </transaction>
59 </for>
60
61 <thinktime value="3"/>

也就是说,业务流程是:先登录,登录完以后,发3条消息,然后,在系统驻留3s,脚本结束。但是,执行了一上午脚本却仍然没有结束,此时通过看tsung的log,tsung已经停止了发送,CM也停止了接收与发送消息。首先,我们分析一下脚本没有结束的几种可能:

1、虽然消息发送结束,是否还在thinktime之内

2、脚本里的某个参数设置是不是不误

3、服务端是不是出现了错误

下面,咱们看一下脚本:

先看一下thinktime的设置,thinktime=3,意味着最后一个request在正确处理的情况下,用户在系统内停留3s,用户应该不会有明显的感知。所以,我将问题定位在最后一个请求:

<request subst="true">
54 <raw data=" 124 3 %%_sessionID%%&lt;message>&lt;sessionid>%%_sessionID%%&lt;/sessionid>&lt;content>tsungMsg%%_counter%%&lt;/content>&lt;/message>" ack="global"></raw>
55 </request>

现在看一下这个request中的各个参数,subst是获取动态参数的,剩下的就是ack了,根据Tsung官方的解释:

  • ack="local" as soon as a packet is received from the server, the request is considered as completed. Hence if you use a local ack with a request that do not require a response from the server, it will wait forever (or until a timeout is reached)

每个request中,ack的值均为local,这意味着在这个请求发出以后,一定要等服务器的响应,直到收到响应以后,这个请求才算结束。

Ok,这个暂时可以作为原因之一。再看tsung.dump文件,可以看到

Send:1442885664.692798:<0.90.0>: 119   1             6197146762302455809<iq><sessionid>6197146762302455809</sessionid><login>hanhy,hanhy123<login></iq>
Recv:1442885664.732048:<0.90.0>:<iq><login>1<login></iq>^@
Send:1442885664.733678:<0.90.0>: 124   3             6197146762302455809<message><sessionid>6197146762302455809</sessionid><content>tsungMsg1</content></message>
Recv:1442885664.770652:<0.90.0>:86<message><sessionid>6197146762302455809</sessionid><content>tsungMsg1</content></mes^@
Send:1442885664.772076:<0.90.0>: 124   3             6197146762302455809<message><sessionid>6197146762302455809</sessionid><content>tsungMsg2</content></message>

最后一条消息发出后,始终没有收到 recv。现做如下验证:将ack的值改为no_ack,再运行脚本,果然脚本在数秒内即运行结束。是不是这样就可以解决问题了呢?

也就是说,我们在发出消息后,不管是不是回应,只要成功发送即可。这是不是我们想要的结果?我觉得,如果你要考量事务响应时间这个指标,这样做是不妥的。所以,我们应该追踪一下这个问题,tsung的日志记录是显示发送出去了,但是,服务端究竟收到没有这个请求?那么问题来了,继续抓包!!!进一步验证问题究竟出在哪儿,如果服务端收到请求了,没有给出响应,那么这是服务端的一个bug,如果服务端给出了响应,是tsung没有收到,那么在客户端也开启抓包,继续追踪。

关于Tsung脚本无法停止的问题的更多相关文章

  1. Tsung脚本中使用动态参数(一)---直接在脚本里编写Erlang代码

    杀死一个程序猿,只要改三次需求.同理,杀死一个接口自动化测试人员,只要改三次接口数据处理方式.我目前的状态,改了一次接口数据处理方式,有一种胸闷的感觉. 因为改需求,所以,要改脚本.T_T.所以,才有 ...

  2. 2.Jmeter 如何在jsr223 脚本中停止测试任务

    Jmeter 如何在jsr223 脚本中停止测试任务 在可以直接引用ctx的变量的processor中可以执行如下脚本即可. (例如jsr223 postprocessor中) ctx.getEngi ...

  3. Linux shell脚本启动 停止 重启jar包

    最近做的微服务jar包想弄在持续集成中自动化部署,所以首先得有一个操作jar包的脚本 只需将jar文件的路径替换到APP_NAME的值就可以了,其他不用改 注意:window编辑的shell文件,通过 ...

  4. linux脚本启动停止一个jar

    ###########################启动########################### #!/bin/sh ####定义一个函数在当前文件夹下读取所有jar文件 functi ...

  5. 脚本 启动/停止 jar包服务

    windows (.bat): @set port=8692 @echo %port% for /f "tokens=5" %%i in ('netstat -aon ^| fin ...

  6. linux下lampp的启动和停止脚本

    今天试着写了lampp的启动停止脚本,和上一篇的tomcat的启动停止有一点小区别,就是lampp启动之后有很多的进程号,如果按照tomcat的停止脚本写就会出错,下面做细细的介绍 1.lampp的停 ...

  7. 一个脚本可以一直运行 ignore_user_abort

    php中ignore_user_abort函数的用法 PHP中的ignore_user_abort函数是当用户关掉终端后脚本不停止仍然在执行,可以用它来实现计划任务与持续进程,下面会通过实例讨论ign ...

  8. 两个shell脚本

    脚本1停止lampp #!/bin/bash #set -xv 开启调试模式? count=`ps -ef|grep lampp|grep -v "grep"|wc -l`  # ...

  9. linux添加开机自启动脚本示例详解

    linux下(以RedHat为范本)添加开机自启动脚本有两种方法,先来简单的; 一.在/etc/rc.local中添加如果不想将脚本粘来粘去,或创建链接什么的,则:step1. 先修改好脚本,使其所有 ...

随机推荐

  1. 从 Bridge 到 OVS,探索虚拟交换机

    Linux Bridge 和物理网络一样,虚拟网络要通信,必须借助一些交换设备来转发数据.因此,对于网络虚拟化来说,交换设备的虚拟化是很关键的一环. 上文「网络虚拟化」已经大致介绍了 Linux 内核 ...

  2. opensslBIO系列之2---BIO结构和BIO相关文件介绍

    BIO结构和BIO相关文件介绍     (作者:DragonKing Mail:wzhah@263.net 公布于:http://gdwzh.126.com openssl专业论坛)          ...

  3. BZOJ 1211 HNOI2004 树的计数 Prufer序列

    题目大意:给定一棵树中全部点的度数,求有多少种可能的树 Prufer序列.详细參考[HNOI2008]明明的烦恼 直接乘会爆long long,所以先把每一个数分解质因数.把质因数的次数相加相减.然后 ...

  4. 腾讯云安全:移动 APP 安全行业报告

    移动 APP 已逐步渗透入我们的生活,据统计,2016年,APP 发行数量仅电商.金融.游戏这三大类共计高达2万左右,国内移动互联网活跃用户数已经突破10亿,移动互联网这样快速的推移,移动互联网的安全 ...

  5. 【quickhybrid】架构一个Hybrid框架

    前言 虽然说本系列中架构篇是第一章,但实际过程中是在慢慢演化的第二版中才有这个概念, 经过不断的迭代,演化才逐步稳定 明确目标 首先明确需要做成一个什么样的框架? 大致就是: 一套API规范(统一An ...

  6. 自学Python3.3-字符串格式化 作用域 递归

    一.字符串格式化 二.作用域 三.递归

  7. Python爬虫(二十四)_selenium案例:执行javascript脚本

    本章叫介绍如何使用selenium在浏览器中使用js脚本,更多内容请参考:Python学习指南 隐藏百度图片 #-*- coding:utf-8 -*- #本篇将模拟执行javascript语句 fr ...

  8. Struts2框架(3)---Action类的3种书写方式

    Action类的3种书写方式 本文主要写有关写Action类的3种书写方式: (1)第一种 Action可以是POJO (简单模型对象)  不需要继承任何父类 也不需要实现任何接口 (2)实现Acti ...

  9. CentOS 7 学习(四)Git配置(一)

    CentOS 7 学习(四)Git配置(一) 1.对于版本管理系统,目前常用的是Subverion和Git,Subversion是集中式版本管理系统中最好的,所有人的代码都要提交到服务器上,如果要知道 ...

  10. 小白的Python之路 day1 pyc

    pyc是个什么? 1. Python是一门解释型语言? 我初学Python时,听到的关于Python的第一句话就是,Python是一门解释性语言,我就这样一直相信下去,直到发现了*.pyc文件的存在. ...