所有文章均来自网络(除测试总结部分),如果涉及到版权问题请与我联系,我会及时删除~~~~

LoadRunner与Winsock协议(转贴)

上一篇 / 下一篇  2007-01-18 09:03:27 / 个人分类:性能测试

 

[翻译]LoadRunner与Winsock协议(一)在开始讨论winsocket解决方案之前,我们先讨论一下各种协议是如何工作.从前面的简介可以了解到很多的高级协议,例如FTP,HTTP协议等.以及所有基于window的应用(例如IE,WS-FTP)底层都是在Winsocket层上通信,因此任何高级协议的底层都是用Winsocket通信。什么时候在LR中选择Winsocket协议呢?你要先了解LR是怎么样工作的:LR捕捉API请求然后再把它们回放。所以当你在创建LR WEB脚本的时候,VUGEN捕捉从IE出去的所有的HTTP请求。除此之外lr还支持其他很多协议,例如Oracle,ODBC等。在选择不同协议录制脚本的时候,LR是依靠hooks捕捉正确的API请求。所以既然大部分网络协议都是架构在winsocket协议之上的,那对于lr不支持的协议,我们都可以在winsocket层上录制脚本。所以当找不到合适协议的时候,可以选择winsocket来录制。录制WinSock协议脚本!Lr录制新的虚拟用户脚本,选择winsock协议在web虚拟用户脚本中录制的是URL信息,所以VUGEN启动流览器并运行就可以了,但选择Winsocket录制的时候,可能会是各种形式的应用,并不简简单单就是浏览器,所以在开始的时候我们不需要指定应用的地址。下面的例子我们选择winsock来录制web应用,正如上面说的我们开始要指定ie的地址。因为本来lr是支持http协议的,所以这个例子并无具体的意义,只是为了使例子简单。

+_kN$d;?-Y;h1Z@^j0

[翻译]LoadRunner与Winsock协议(二)51Testing软件测试网s3?7vf)j h

winsock脚本典型代码?

t&o$T6\R+q,Q0

lrs_create_socket(”socket0″, “UDP”, “LocalHost=0″, “RemoteHost=doors:2084″, LrsLastArg);51Testing软件测试网X`(zgY(p

lrs_create_socket(”socket1″, “TCP”, “LocalHost=0″, “RemoteHost=www2.yahoo.com:80″, LrsLastArg);51Testing软件测试网(R avHARz]

lrs_send(”socket0″, “buf0″, LrsLastArg);51Testing软件测试网GD p w^;c#m

lrs_receive(”socket0″, “buf1″, LrsLastArg);

w{R1}.Hv2R9K?k H0

lrs_send(”socket1″, “buf2″, LrsLastArg);

j'G2f.|w$i0

lrs_send(”socket0″, “buf3″, LrsLastArg);

.b6p g2?I0Q3c*Q'g0

lrs_receive(”socket0″, “buf4″, LrsLastArg);

2W)R"}6r[2S0

 

Q^#|#X1~h*S8L1_0g0

这是访问雅虎的一个应用,正如我们看到的,winsock先打开一个winsocket连接,然后收发包。我们发现录制的脚本中比web脚本(三个文件)多一个文件。51Testing软件测试网z NMj ya)F

第四个文件是data.ws,它里面记载了在action里面收发所有包的内容下面是一个data.ws的例子。51Testing软件测试网jU;]d&|8u2ZQ

send buf0

c%xNV/D m|ho3q0

“!”51Testing软件测试网s"F9ztV c'}CsS

recv buf1 1

XP5L$u:n3J[0

“!”

6|:r,}Deb"tSK0

send buf251Testing软件测试网^:N7{.i s1U1|&O

“GET / HTTP/1.1\r\n”51Testing软件测试网 b3x4D+Z Q;hI-RMP%Z

“Accept: */*\r\n”51Testing软件测试网4G h%SDd5p7s"W?U|

“Accept-Language: en-us\r\n”51Testing软件测试网OKW.^3cA)_x

“Accept-Encoding: gzip, deflate\r\n”

ye_%F%P_;_$j(R*? hL0

“User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)\r\n”51Testing软件测试网,lfJ2rb m

“Host:www.yahoo.com\r\n51Testing软件测试网qN0` Ytto`

“Connection: Keep-Alive\r\n”51Testing软件测试网Z4HW X_"s D

“Cookie: B=5oj83bst12l6m&b=2; Y=v=1&n=8lln5lmi3f8g1&l=6ef8c0d34b0/o&p=m2a2s”51Testing软件测试网 d-{t'Byz

“qa4110004&r=3f&lg=us&intl=us; T=z=4TVE6A4ZqE6A9dIIpt30.NQNTYGNDE3NTYwM081&”

Jb#L MmWZ0

“a=AAE&sk=DAAEwinHlDtEm/&d=c2wBTWpFQk16WXdNakUzTkRneQFhAUFBRQF6egE0VFZFNkFn”

o8IV4}'h+F3e0

“V0E-; I=i1=010g1q1u24252e2i2k2p2r494a4g4m4q55565b5g6g6t6u7172737678797a7f7″51Testing软件测试网:nrO5} v

“g7k7n7o888f8k8p8q989c9f9i9k9l9n9qacanapb0b3bdbfbhblbqbrbuc0c1c4cgcmcscteie”51Testing软件测试网 ]7j a1n3k

“jgr&ir=73\r\n”

~ h,bt9J\6U0

“\r\n”51Testing软件测试网\:CW;g2^$g,v5~

send buf3

(P*L*adzq'r+\d0

“!”

rp(Mx:_Y6k0

recv buf4 151Testing软件测试网fX G2Y&Y\

“!”51Testing软件测试网f{if M7pOj^p

recv buf5 204851Testing软件测试网4\tm2@7X8B~(qy

“HTTP/1.0 200 OK\r\n”

X.RhAJ n0

“Content-Length: 16030\r\n”

J)?@!@w uFG}0

“Content-Type: text/html\r\n”51Testing软件测试网?xg j\$OW

“\r\n”

5Oa ]n @ X bC t9q0

“ 

'CN`#^8v(L9W6B0

    buf2包含了发给www.yahoo.com的包,buf5包含了从server收到的回应。正如看到的winsock录制的脚本并不像web脚本那样具有可读性,因为winsock是我们最后的选择。在buf序列号的后面是buf的字节数。例如5号buffer后面的2048就是表示收到了2048个帧。51Testing软件测试网"aa ^PY*@-Cj/a

    注意:在很多buffer里面你会发现仅仅包含了一个“!”,这是一个网络常识,这个帧对于应用来说没有任何的作用,完全可以把这些桢清除掉,在data.ws清除这个帧是效果的,需要到action里把这些桢注释掉。譬如例子中收到和发出的buffer可以用//注释掉。这样可以使脚本运行得更快。下边的例子: buffers 0, 1, 3 和 4 可以注释掉:51Testing软件测试网 l&H0f/W`kox!A

lrs_create_socket(”socket0″, “UDP”, “LocalHost=0″, “RemoteHost=doors:2084″, LrsLastArg);

FuopGY:\!jz\C0

lrs_create_socket(”socket1″, “TCP”, “LocalHost=0″, “RemoteHost=www2.yahoo.com:80″, LrsLastArg);51Testing软件测试网hZI/|2cx

// lrs_send(”socket0″, “buf0″, LrsLastArg);51Testing软件测试网#zlx3o U'Y.r

// lrs_receive(”socket0″, “buf1″, LrsLastArg);51Testing软件测试网1yq/P.h6Ke

lrs_send(”socket1″, “buf2″, LrsLastArg);

[ U4S/d ad?-D,v8@0

// lrs_send(”socket0″, “buf3″, LrsLastArg);51Testing软件测试网+{2I2rG)}4Z

// lrs_receive(”socket0″, “buf4″, LrsLastArg);

a&~$]2~U)h0

lrs_receive(”socket1″, “buf5″, LrsLastArg);51Testing软件测试网K1em&L#h:Aut

lrs_send(”socket0″, “buf6″, LrsLastArg);51Testing软件测试网L"e YS8M;S!l}

[翻译]LoadRunner与Winsock协议(三)

~N)s:x$?0w[2~.eG0

创建脚本步骤:

1b;? u b0S:A0

1. VuGen录制脚本51Testing软件测试网B#UL7e ^TG(Z?

2.增强脚本51Testing软件测试网` kGH jrS

3.参数化

T [2~ C!e-F0

4.关联脚本51Testing软件测试网!{7{cz9N:hx

5.设置运行参数

B f(Mq;d.Z9l.xD0

6.运行脚本

$w,rYM-fJ0

1. VuGen录制脚本

c'iJ\l7g0

按照之前章节说的步骤创建脚本,录下来的就是基本脚本,可以先把“!”的buffer注释掉。51Testing软件测试网D(JR2AZDS

练习:

u*c:{e`9y/H+p0

    创建一个简单的winsock脚本,可以选择MI公司的网站,把录下来的脚本命名为winsocket_1,再用Http协议方式创建一个Web脚本,把脚本保存为WebWinsock_1.请不要更改session_id把两种脚本比较,当你登陆的时候,可以收到一个“welcome,jojo….”的消息。既然所有的消息都放在data.ws文件里,那么data.ws里面应该能找到这条消息。

.E%T)s!OV/y0

1.1) 在几号bufffer里面包含“welcome,jojo”?怎样判断这是收到的帧而不是发出的帧?还有着个字符串正如显示的那样或者他是html的一个标签。

/G(w2i V~q:|\#u.^0

   仔细查看脚本,在data.ws文件中寻找MSO=SIDxxxxxxxxx,XXXXXX是9位数的号码,他表示自从January 1 st,1970以来流逝的所有的秒时间,cookie和session_id都是根据时间来生成的,所以脚本里面的9位数也就直接和脚本运行时间挂钩,所以我们要把这个数改成我们每次运行脚本的确切时间,首先把这个值更换成参数,在c里面有一个Time()的函数。他返回的就是自从January 1 st,1970以来流逝的所有的秒时间,在脚本的开始用这个函数获取时间值,然后把刚才创建的参数指向这个值。然后在data.ws里面替换所有的id,这样每次脚本运行都能获得正确的id。51Testing软件测试网"KNM-N O

1.2)把修改了参数的脚本运行一遍,在脚本的运行日志里面寻找”incorrectly”。会找到”You’ve reached this page incorrectly”这条消息,运行web脚本也会发现类似的消息。其中发生了什么呢?

5e-@"KQ!h6Rc0

    注意:在data.ws文件中收到的buffer内容在每次运行时不会改变,录制脚本时data.ws文件被创建并且回放过程中也不会改变?所以lr录制的脚本种buffer不是很重要,LR用发送包的数据发出请求,然后对比发送请求的数据包和脚本里面包存的数据,这里lr只判断数据包大小,而不是具体内容。如果收到的数据包包括“rob”,而server响应是“bob”,lr也会认为脚本运行成功。但如果server回复的是robot”,这样lr就会因为收到包的大小不对而认为脚本执行失败。另一种情况时lr期望收到500bytes大小的包,但是前10秒只收到了100bytes,这时r会认为超时判断脚本运行失败,可以通过lrs_set_recv_timeout 函数来设定超时时间。

0Dr.H4H6p)sF/u0

    那么反面一种情况是,你不想接受所有的数据包,只是想收到包的前100bytes,可以通过函数ltr_receive_ex 来任意设定想要收到的字节。 2.增强脚本51Testing软件测试网z#ao,f$[j]4M

   在脚本中添加事务,集合点和控制语句等增强脚本,和web脚本不同的是winsock脚本可读性很差,所以要在录制脚本时添加注释,事务和集合点等。如果在脚本中有逻辑需求,那么插入逻辑语句 (通用声明不适应Winsock_1脚本).

] qPWl9b*@-k0

3.脚本参数化51Testing软件测试网(xVJ K$K8i5q.^k\;}q)d

    把脚本中变化的值参数化,只要用参数把这些值替换掉就可以,使用不同参数重复业务流程,例如在上面的例子里面jojo/bean就可以参数化成为userIDs/passwords51Testing软件测试网J?R Pq&Y8Y6^z

4.关联脚本51Testing软件测试网XV.j"N[5}8x8YXrJ`

    关联目的是为了让你在一个并发中用到一个商业流程的结果,在web脚本中有这样的过程,从web脚本中sessionid关系到后面的流程能不能运行,winsock脚本有同样的问题。所以需要捕获到session id然后把它关联起来,举个例子从下面的脚本中获取PID(lr函数的例子):

C;gi#g8P$\ y0

“\r”

L-W} V TN0

“\x0 blah blah blah “

]#~*ji/Xh4PG0

“\r\n blah blah blah “51Testing软件测试网!z?6bK|(w)b

“PID TT STAT TIME COMMAND\r\n PID 28469 q2″

lFJI"rjX!x4K0

” S 0:01 -tcsh (tcsh)\r\n”51Testing软件测试网2l/z/w]#P+\L"hL

    在一个典型的web脚本中,你用web_create_html_param函数,用“PID“ 和“q2”定义边界扑获数据。

&mo }+T}^0

    在Winsock脚本中,用lrs_save_param函数从静态数据或收到的数据包中截获数据,看下面的例子:

_:f m%G9TmR0

lrs_receive(”socket2″, “buf47″, LrsLastArg);

Z4f X0GU.I6Y5j/_0

lrs_save_param(”socket2″, NULL, “param1″, 67, 5);51Testing软件测试网ZG2Ch6A5q6Sr

    和web_create_html_param函数不同的是lrs_save_param在请求之后进行,这个例子中,第一行代码是接收到47号包。lrs_save_param函数的参数意义如下:51Testing软件测试网fc3O!Oq[ x

socket2: 从socket2中扑获数据

&fh!v/Rb0

NULL: null参数意思是从最后一个buffer里截取,在这儿就是指buf47,如果你从其它的buf里面来获取数据,则你必须要指明buf的号码了

I7_+d.vSc0

param1:命名的参数值

BD4P%S5Z ?V0

67:位移(下面截解释)51Testing软件测试网7g a Mm/uD U5^ s

5:捕获的长度51Testing软件测试网w\*|aa:n"RY? X

位移:从buffer的开始多少位去捕获参数的值,在下面的例子里面,PID是从buf47开始往后67bytes来截取的,我们怎么确定这个值?51Testing软件测试网g\/j EJ(l%^ E

在data.ws中选取需要截取参数的地方然后按F7键,这样会弹出一个窗体。如下图:51Testing软件测试网)T] mw6oEvS%I

    在左边的列,你将看到符合这部分数据的偏移量,中间四行是用EBCDIC加密的数据包。最右边,是没有经过加密的数据。所以你应该看第五行包含PID的真实的数据,,很容易就可以根据64+3得出位偏移为67。51Testing软件测试网 EN,jgjY%M9B

(现在我们解释一下问什么添加这些多余的东西到数据包中,让它适合我的例子呢?)

2d9{9Ct6e*m`*PdS0

注意:在socket脚本中没有提供web_find函数。只有通过编程来找到你要截取的脚本。

V)}%L Y&g.~XMv0

5.run-time的设置51Testing软件测试网CA_Xy

配置Run-Time可以控制脚本运行过程中的虚拟用户行为,包括loop,log和Time信息等设置

y X}X$s.]K0

6.VuGen运行脚本.

(\|5v{:@:[+X0

保存并用VuGen运行脚本验证脚本是否正确

Y,iT9x^N,f gw#?0

搞定WinSock!

jx9VO)I6x#yE2p2s0

原始链接:http://blog.51testing.com/?49159/action_viewspace_itemid_875.html

Qfez)o_6h_0

 51Testing软件测试网gd$?7e zUu

源文档 <http://www.51testing.com/html/27/1907.html>51Testing软件测试网a`e5o\.x DpD6i


TAG: 性能测试

 

评分:0

我来说两句

日历

« 2023-07-05  
      1
2345678
9101112131415
16171819202122
23242526272829
3031     

数据统计

  • 访问量: 42124
  • 日志数: 61
  • 建立时间: 2007-01-15
  • 更新时间: 2007-07-23

RSS订阅

Open Toolbar