Jmeter中Websocket协议支持包的使用
转自:http://blog.csdn.net/typing_yes_no/article/details/49512167
一、添加Jmeter对WebSocket协议的支持插件
1、到https://github.com/maciejzaleski/JMeter-WebSocketSampler下载Jmeter的WebSocket协议的支持插件:JMeterWebSocketSampler-1.0.2-SNAPSHOT.jar,并直接将这个jar包放到Jmeter软件的\lib\ext\目录下。2、另外,查阅https://github.com/maciejzaleski/JMeter-WebSocketSampler/wiki/Dependencies看到,这个插件需要以下几个jar包的支持:1、jetty-http-9.1.2.v20140210.jar2、jetty-io-9.1.2.v20140210.jar3、jetty-util-9.1.2.v20140210.jar4、websocket-api-9.1.1.v20140108.jar5、websocket-client-9.1.1.v20140108.jar6、websocket-common-9.1.1.v20140108.jar对于1.0.1的版本,这些可以到http://download.eclipse.org/jetty/updates/jetty-bundles-9.x/9.1.1.v20140108/网站下载。网上也有整理好的,可以到360云盘下载http://yunpan.cn/cFDUNhHywxsMh (提取码:2c0b),也可以到http://download.csdn.net/detail/qq_14913813/8568431CSDN网站下载。直接放到Jmeter目录的\lib\ext\目录下即可。3、以上jar包都准备好并放到Jmeter目录的\lib\ext\目录下后,重启Jmeter之后可以在sampler中看到websocket sampler这一项。
1、WebServer(1)Server Name or IP:WebSocket发送的目标服务器的地址或者名称
(2)Port Number:WebSocker服务器监听的端口号。(一般是HTTP 80端口,可以通过WireShark数据包得到)2、Timeout:(1)Connection – 发送一个连接请求后,Jmeter等待连接完成的最长时间,单位是毫秒。(2)Response - 对响应消息的最大等待时间。
3、WebSocket Request(1)Implementation – 只支持RFC6455(v13) ,WebSocket协议标准的最新版。
(2)Protocol – 有ws与wss之分, ws前缀是WebSocket连接的辨别标识,wss前缀是WebSocket安全连接的辨别标识。根据自己的实际情况填写(3)Streaming Connection – 选择这个TCP session要不要保持,如果勾上标识连接会一直存在,如果没有勾上,那么得到第一次响应后该链接就会被关闭。(4)Request data:填入将要发送的请求,要跟开发沟通好,这个是什么格式的消息。4.WebSocket Response(1)Response Pattern – 采样器将等待含有该标识的消息并继续通信(或者直到timeout,该连接关闭)(2)Close Connection Pattern – 如果服务器返回的消息含有这样的字符,就结束会话。(3)Message Backlog – 定义服务器返回消息保留的最大长度。
按照网上的例子,可以用http://www.websocket.org/echo.html这个网站做一些试验,网站会将收到的数据(你的request数据)在服务器响应中原样返回。将网站提供的host等信息填入即可与网站通信,下面是我的实验,用于理解Jmeter中websocket sampler
可以看出发送的Ground control to Major Tom被返回,这个实验是成功的,从result tree的sampler result中Execution FLow中可以看出测试的结果与上面我们的设置之间的关系:用了5000毫秒的时间等待服务器的连接,用了20000毫秒的时间等待服务器的消息,且在接受到第一条消息后,关闭了这个websocket会话。可以看到在结束测试的时候,勾上streaming那个小勾后,测试结束时streaming connection还是开着的。
(4)、参照参考文档设置一个测试(添加一个loop controller,设置循环次数为3)
结果如下:循环中的sampler都勾选了streaming,最后一个sampler没有勾选此选项,结果中可以看出:在loop controller中的sampler使用的是一个连接,在loop外面的这个sampler会打开一个新的连接,可以得出一个结论,实际上,当勾选了streaming connection时,不仅会在结束会话后保留连接,而且勾选了的sampler会在有可用连接是直接使用,而没有勾选的sampler即使存在可用连接也会重新打开一个新的连接。因此,如果是要在一个会话中发送多条消息,请勾选这个streaming connection。
这就要用到之前提到过的response pattern和close pattern,先给出三个请求在没有设置response pattern和close pattern的运行结果以便于比较然后在第一个sampler中设置response pattern和close pattern如下(由于只建立一次连接,所以只会读取第一个sampler中的pattern设置信息)这样在第二个请求的响应返回不符合father这个标识,又符合了close pattern时,就会断开连接了,此时第三个websocket勾选了streaming使用上一个连接,但实际上却连接不上这个远程终端时就会报错了。(response响应在这种情况下不能设置为空,如果先检测到返回的内容符合response pattern,就不会再去判断是否符合close pattern了)
3、Message Backlog的设置
上面的试验使用的都是默认的3,因此如果试验中的三个socket都是是在一个会话中通信,点击第三个是可以看到最近的三个服务器响应的。当这个选项设置为1时,就只能看到最近的一条响应信息了