使用IP欺骗Loadrunner并发测试小结

测试要求:

在本次测试中,我需要并发50个User,每一个User占用一个独立的IP,并且只执行一次脚本。脚本中发起两个请求,其中第一次请求返回200后才执行第二个请求。使用win7 OS。

前置及Generator设置:

我的Run-time Settings这样设定:

Run Logic: Number of Iterations: 1 (保证只执行一次脚本)

Log: Enable Log. Always send messages.(不是只在出错时发送log。我需要通过log来验证我的测试要求是否达到)

Think Time: Ignore think time (我不要思考时间,我想第二个请求紧跟第一个请求后执行)

其他不变。

为了在同一台机器上跑50个IP,我使用IP Spoofing

在开始菜单,找到Loadruner所在文件夹,进去找到Tools,里面有一个IP Wizard(IP欺骗)

在创建新的IP之前,可以CMD查看ipconfig, 查看自己所在IP区间。使用IP欺骗时,需要使用空闲IP,为确保不影响公司网络,建议使用一个路由器搭建独立的IP区间。

我使用的IP区间为:

LAN Subnet : 192.168.32.0 / 23 (空闲IP区段:192.168.32.4 ~ 192.168.33.254)

Gateway : 192.168.32.1

到增加IP地址对话框时,注意配置是否正确。我的配置如下图。

完成之后可以将刚才的IP地址保存为“IP Address File(*.ips)”文件。(这一操作我没有做,还好Loadrunner已经非常智能,在Load Generators只增加localhost就可以搞定)

好了,在CMD查看ipconfig /all 是不是多了50个IP。

注意,IP Wizard不支持DHCP,需要本机配置为固定IP地址。

接下来写脚本。

我的脚本如下:

 1 Action()
 2 {
 3
 4     int status;
 5     int HttpRetCode;
 6     char *ip;
 7     ip = lr_get_vuser_ip();
 8 //检查Loadrunner Controller有没有Enable IP Spoofing
 9     if(ip)
10         lr_output_message("The IP address is %s", ip);
11     else
12         lr_output_message("IP spoofing disabled");
13 //设置集合点,让50个vuser一起发起第一个请求
14     lr_rendezvous("letusgo");
15 //开始第一个事务(请求)
16     lr_start_transaction("1stReq");
17
18     web_url("RCS_Initial_HTTP_Req",
19 //这里有一个参数化,我要每一次传递给该参数一个唯一的msisdn号码,并且只执行一次。
20 //我在参数属性对话框里设置:Select next row -> Unique
21 //                                          Update value on -> Once
22         "URL= http://xxx.yyy.com/self?x-forwarding-msisdn={NewParam}",
23         "TargetFrame=Main",
24         "Resource=0",
25         "RecContentType=text/html",
26         "Mode=http",
27         LAST );
28 //打印第一个请求的返回码
29     HttpRetCode = web_get_int_property(HTTP_INFO_RETURN_CODE);
30     lr_output_message("Response code:%d",HttpRetCode);
31 //检查返回码是否是200
32       if(HttpRetCode == 200){
33         lr_end_transaction("1stReq", LR_PASS);
34         sleep(2000);
35 //开始第二个事务(请求)
36         lr_start_transaction("2ndReq");
37         web_url("RCS_Initial_HTTP_Req",
38         "URL= https://xxx.yyy.com/self?vers=1&IMSI=1&rcs_version=1&rcs_profile=1&client_vendor=1&client_version=1&terminal_vendor=1&terminal_model=1&terminal_sw_version=1&IMEI=1&mock_scheme=HTTPS",
39         "TargetFrame=Main",
40         "Resource=0",
41         "RecContentType=text/html",
42         "Mode=http",
43         LAST );
44 //打印第二个请求的返回码
45          HttpRetCode = web_get_int_property(HTTP_INFO_RETURN_CODE);
46          lr_output_message("Response code:%d",HttpRetCode);
47 //检查返回码是否是200
48 //结束第二个事务(请求)
49         if(HttpRetCode == 200){
50             lr_end_transaction("2ndReq", LR_PASS);
51          }else{
52              lr_end_transaction("2ndReq", LR_FAIL);
53         }
54
55      return 0;  }else{
56 //结束第一个事务(请求)
57      lr_end_transaction("1stReq", LR_FAIL);
58      return 0;
59      }
60 }
61  

场景设置:

添加Load Generator

Name: localhost

Platform: windows

添加这一条就可以了。

然后将状态开启为Ready

一定要注意每一个Vuser的IP是否是唯一的。双击下图Scenario Groups里面的Group Name行可以打开每一个Vuser对应的Generator,查看其IP。

要监控一些服务器资源的资源如cpu,memory,disk,需要在controller里加入增加监控Unix Resources, 加入服务器地址。可以一次添加多个服务器。

前提:

需要关闭防火墙

需要在要监控的服务器上安装rstatd组件

[[email protected] ~]# service rstatd

Usage: /etc/init.d/rstatd {start|stop|status|restart|reload|force-reload} 
[[email protected]~]# service rstatd status 
rpc.rstatd (pid 2650) is running... 
[[email protected]~]#

可能报的错:

lr UNIX Resources. Cannot initialize the monitoring -47190

无法连接该服务器,请找公司OPS部门解决。我在测试中需要连接公司VPN服务器,在没有连接之前就会报这个错。

开始Run之前,别忘了log保存位置放到指定位置。在Results下面设置。

关于Result :

Graphs 右键 Add new items -> Add New Graph增加想要的图表结果

Reports -> HTML Report.. 生成html报告

小心Scale陷阱

要乘以前面的Scale值,才是真实结果。

结果分析参考:

UNIX counter Windows Counter Description
Average Load* N/A The sum of the number of processes waiting in the run queue plus the number currently executing.
Collision rate N/A The total number of network collisions/sec
Context switch rate System – Context Switches/sec The rate at which processors switch from executing one thread to another. High switch rates can indicate performance problems as servers juggle multiple running applications.
CPU utilisation %Processor Time The percentage of elapsed time that the process spends executing non-idle threads.
Disk traffic %Disk time The percentage of elapsed time that the disk(s) are  busy servicing read or write requests.
Incoming packets error rate Packets received errors The number of packets received containing errors that precvent them from being delivered to a higher OSI layer protocol.
Incoming packets rate Packets received/sec The number of packets received on the network interface
Interrupt rate Interrupts/sec Average rate at which the processor receives and services hardware interrupts. Processes generate an interrupt when they finish a task and need to report that fact to the CPU.
Outgoing packets error rate Packets outbound errors The number of packets that can’t be transmitted due to errors
Outgoing packets rate Packets sent / sec The rate at which packets are sent on the network interface
Page-in rate Pages Input/sec The rate at which pages are read from disk to resolve hard page faults. Hard page faults occur when a process refers to a page in virtual memory which is not in it’s working set or available elsewhere in physical memory and has to be read from disk.
Page-out rate Pages Output/sec The rate at which memory pages are written to disk to free up space in physical memory.
Paging rate Paging rate The rate at which pages are read from disk or written to disk.  This is the sum of Pages Input/sec and Pages Output/sec.
Swap-in rate N/A The number of pages read into memory per second
Swap-out rate N/A The number of pages written out of memory per second
System mode CPU utilization Processor – %Priviledged time The percentage of elapsed time that the processor spends executing user threads (i.e. running applications)
User mode CPU utilization Processor – %User time The percentage or elapsed time that the processor spends executing priviledged or system mode threads.

时间: 2024-10-08 23:26:34

使用IP欺骗Loadrunner并发测试小结的相关文章

jmeter使用IP欺骗进行压力测试

loadrunner的IP欺骗功能很强大,耐心研究jmeter官方文档,发现在jmeter2.5以上的版本有此功能的实现~ 准备工作: 1.window7一台,安装jdk1.6环境. 2.下载最新jmeter,链接地址:http://jmeter.apache.org/download_jmeter.cgi,下载zip包解压即可,双击bin/jmeter.bat启动jmeter; 3.使用IP欺骗功能必须得本地有多个可用IP,通常普通的PC机只有一个物理网卡,这就需要我们手工设置多IP绑定同一网

LoadRunner 技巧之 IP欺骗 (推荐)

IP欺骗也是也loadrunner自带的一个非常有用的功能. 需要使用ip欺骗的原因:1.当某个IP的访问过于频繁,或者访问量过大是,服务器会拒绝访问请求,这时候通过IP欺骗可以增加访问频率和访问量,以达到压力测试的效果.2.某些服务器配置了负载均衡,使用同一个IP不能测出系统的实际性能.LR中的IP欺骗通过调用不同的IP,可很大程度上的模拟实际使用中多IP访问和并测试服务器均衡处理的能力.3.有一些网站会限制同一个用户同一个IP 的登陆.为了更加真实的模拟实际情况,LoadRunner允许运行

IP欺骗

IP欺骗也是也loadrunner自带的一个非常有用的功能. 需要使用ip欺骗的原因:1.当某个IP的访问过于频繁,或者访问量过大是,服务器会拒绝访问请求,这时候通过IP欺骗可以增加访问频率和访问量,以达到压力测试的效果.2.某些服务器配置了负载均衡,使用同一个IP不能测出系统的实际性能.LR中的IP欺骗通过调用不同的IP,可很大程度上的模拟实际使用中多IP访问和并测试服务器均衡处理的能力.3.有一些网站会限制同一个用户同一个IP 的登陆.为了更加真实的模拟实际情况,LoadRunner允许运行

jmeter使用IP欺骗压力测试

最近在使用jmeter进行压力测试时需要使用类似于loadrunner的IP欺骗功能,经问津度娘无果后决定再次耐心研究jmeter官方文 档,终于发现在jmeter2.5以上的版本有此功能的实现,由于发现很多网友都在寻找此问题答案,遂将本次测试的过程的记录下来以帮助更多的同学: 准备工作: 1.window7一台,安装jdk1.6环境,此处就不再累赘讲述. 2.下载最新jmeter 2.11,链接地址:http://jmeter.apache.org/download_jmeter.cgi,下载

LoadRunner中的IP欺骗的设置以及误区

LoadRunner中的IP欺骗的设置以及误区 最近在忙着部署web性能测试的环境后,对IP欺骗进行设置,特地做个笔记,给自己的学习历程留下点足迹. 一. 什么是IP欺骗? 做什么事首先要问个为什么,如果知道为什么了,即使不知道如何做,简单,google it,答案总会找得到,google.cn不行,google.com总行,来自全球的搜索结果,总会有帮助. IP spoof即IP 电子欺骗,我们可以说是一台主机设备冒充另外一台主机的IP地址,与其它设备通信,从而达到某种目的技术. IP是网络层

loadrunner - IP欺骗

一.什么是IP欺骗 IP spoof即IP 电子欺骗,我们可以说是一台主机设备冒充另外一台主机的IP地址,与其它设备通信,从而达到某种目的技术. IP是网络层的一个非面向连接的协议, IP数据包的主要内容由源IP地址,目地IP地址,所传数据构成,IP的任务就是根据每个数据报文的目的地址,路由完成报文从源地址到目的地址的传送.至于报文在传送过程中是否丢失或出现差错,IP不会考虑,那是TCP的事.对IP来讲,源设备与目的设备没有什么关系,它们是相互独立的.IP包只是根据数据报文中的目的地址发送,因此

LoadRunner学习知多少--IP欺骗使用

使用IP欺骗功能时,需要将系统防火墙,杀毒软件关闭(如果有影响的话) 一.为什么要设置IP欺骗 1. 当某个IP的访问过于频繁,或者访问量过大时,服务器会拒绝访问请求,这时候通过IP欺骗可以增加访问频率和访问量,以达到压力测试的效果. 2. 某些服务器配置了负载均衡,使用同一个IP不能测出系统的实际性能.LR中的IP欺骗通过调用不同的IP,可很大程度上的模拟实际使用中多IP访问和测试服务器均衡处理的能力. 3.有一些网站会限制同一个用户同一个IP 的登陆.为了更加真实的模拟实际情况,LoadRu

使用JMeter3.0实战之分布式并发测试以及web API接口测试

简介: 该文档是以Apche JMeter-3.0为例进行编写的,通过网上的学习资料和官方文档的说明手册学习后,进行项目操作实践,将测试的过程记录下提供给大家学习. 本博文的内容主要是进行配置JMeter的测试参数,进行并发测试,分布式测试和收集服务器端的性能参数以及如何去测试web api接口的方法. 本博文以工作的项目作为并发测试的实验案例.如果有错误,请大家指出. 1.使用Badboy录制Web性能测试脚本 1.1使用Badboy工具进行录制Web性能测试脚本 (1)启动Badboy.首次

loadrunner负载测试实例

回想起第一次做性能测试,感慨万千,故写下本文,从:设置虚拟用户,设置场景以及分析运行结果三个方面进行阐述 硬件环境:硬盘 1TG,cpu 3.40GHz,内存4G 软件环境:IE9.0,Weblogic12c ,Orace 12 网络环境:  100M带宽 测试工具:LR11 首先,load Generator机器必须使用固定的IP,不能使用动态IP,确定网络中不冲突的IP地址. 1.开始-程序-loadrunner-tools-ip wizard. 说明:增加新IP选择第一项:使用保存的文件增