Loadrunner对https协议(单双向SSL)的web端性能测试

1.项目背景

1.1 单双向SSL的含义及部署

单向SSL即我们说到的https协议。

特点是,浏览器需要请求验证服务器证书;

基本含义是:一个安全通信通道,它基于HTTP开发,用于在客户计算机和服务器之间交换信息。它使用安全套接字层(SSL)进行信息交换,简单来说它是HTTP的安全版。

双向SSL顾名思义就是双方都需要验证证书的协议,浏览器首先向服务端请求证书,然后服务器端需要向浏览器请求目前登陆用户的个人证书验证。

1.2 系统的基本部署

单向SSL交互过程:

使用单向SSL时,仅通过虚拟主机2,请求即可传递到tomcat完成整个通信过程。

双向SSL交互过程:

使用双向SSL时,请求先到虚拟主机2,由虚拟主机2rewrite至虚拟主机3,再由虚拟主机3与tomcat进行通信。同时在虚拟主机3,会将用户证书放在参数中随请求一起传递给tomcat。

1.3 测试背景

为了配合使用证书系统,本系统上所有请求将更改为使用https进行访问。同时为了增加安全性以及对本系统核心操作的控制,需要对请求进行分级控制,即普通操作为单向SSL,核心操作为双向SSL。

需要交互的系统:OSCP服务器,用于在线验证证书状态。

2.测试目的

主要验证系统:

(1). 评估在预期用户规模的情况下,系统是否响应正常。

(2). 评估系统在应用了单双向SSL之后响应的区别,关联服务器是否会影响该系统的性能情况。

(3). 在逐渐增加负载的情况下,分析系统瓶颈。

(4). 在压力情况下系统的表现。

(5). 在长时间运行该模块是否会出现系统性能异常。

3.测试分析

3.1场景分析

假设根据系统分析,主要测试两个场景,第一是单向SSL,登陆场景,第二是双向SSL,对下载文件功能。假设预估的并发用户量都是10人。


用户行为


操作


预估并发用户量


下载文件


选择指定文件->下载


10


登陆


填写用户名和密码->登陆->加载登陆后界面


10

3.2测试模块分析

负载测试:主要测试各个场景在正常情况下是否运转,是否系统响应正常。并且对比应用了单双向SSL之后的响应差别,关注到关联服务器是否会影响该系统的性能情况。

并且在不断增加负载的情况下,分析系统的瓶颈。

压力测试:主要考察在压力情况下系统的表现,是否会出现性能异常,以及出现异常之后是否能及时回复并给与友好性提示。

长时间稳定性测试:主要测试系统在预期的用户量下,在一段时间内,是否能够稳定的响应。重点关注下内存是否泄漏。

4.测试执行

基本步骤:录制LoadRunner脚本->执行LoadRunner场景->进行分析

在测试执行里主要说一下录制脚本时遇到的问题,关于loadrunner对于单双向SSL脚本录制的问题。

主要从以下几个方面来说,如何将浏览器导出的证书.crt转换为.pem,如何录制单向SSL脚本,如何录制双向SSL脚本。

4.1 如何将浏览器导出的证书.crt转换为.pem

所有的blog上都说用openssl转换。那么哪里有openssl?

答:这个再linux下面一般都带的,没有的话yuminstall openssl 就可以了

步骤是什么?

答: pfx提取公钥私钥方法如下:

openssl pkcs12 -in server.pfx -nodes -out temp.pem  //生成临时文件:temp.pem

openssl rsa -in temp.pem -out server.key         //生成服务器私钥 server.key

openssl x509 -in temp.pem -out server.pem    //生成服务器公钥 server.pem

4.2 如何录制单向SSL脚本?

只需要设置LoadRunner即可,LR中可以直接录制https脚本,只需在create new scripts->web(HTTP/HTML)->start record->options->netword下的port mapping,设置为winnetlevel data (2、runtime setting -> Internet protocol->perference 选中 WinInet replay instead of sockets.)

4.3 如何录制双向SSL脚本?

由于LR的机制是利用LR模拟浏览器与服务器进行交互,所以证书需要安装在

---------------------------------------------------------------------------------------------

1. 证书的准备

常见的证书为:*.pfx格式,该种格式的证书可以通过双击运行安装到IE浏览器上。用户在访问的时候就可以使用到。

但这种证书并不是LoadRunner所使用的类型,因此需要对其进行转换。将其转换为*.pem格式。

转换方法如下:

?安装openssl后

?运行C:\<OpenSSL>/bin文件夹的openssl二进制文件,它将启动OpenSSL命令提示符

?执行以下命令:pkcs12 -in D:\test1.pfx -out D:\test01.pem –nodes

?执行后,将会在指定目录生成test01.pem文件,这个文件将会在下一个步骤,对LoadRunner进行配置的时候使用到。

2. LR配置

启动LoadRunner,打开Recording Option选项。

留意红色框中的选项。

选择后,单击New Enty

红框中的配置为服务器的ip和端口号,按照测试所需要的实际地址进行配置就可以

配置后,将Use specified client-sidecertificate[Base64/PEM]钩选,为使用客户端证书访问。

单击。。。选择刚刚转换生成的客户端证书。

如果你为证书有设置密码,在这里也需要输入。

到此为止所有与http区别的配置就完成了。

录制后,可以在脚本的开始,看到LoadRunner新生成的语句

web_set_certificate_ex("CertFilePath=test01。pem",

"CertFormat=PEM",

"KeyFilePath=test01。pem",

"KeyFormat=PEM",

"Password=123456",

"CertIndex=1",

LAST);

下面的操作和普通的页面性能测试一样。

Loadrunner 录制htpps 协议通过IE打开页面,报错“Internet Explorer cannot display the webpage”.

但是直接打开IE不通过 loadrunner打开https页面却可以正常打开。

问题解决如下(Windows 7):

执行:cmd

然后执行命令:certutil -setreg chain\minRSAPubKeyBitLength 512

重启电脑,问题解决。

参考文章:

http://eyeontesting.com/questions/2758/loadrunner-vugen-cannot-record-secure-web-sites-ht.html

测webservice遇到https的请求,是在事务开始前加web_set_sockets_option("SSL_VERSION","TLS");

时间: 2024-10-27 10:15:56

Loadrunner对https协议(单双向SSL)的web端性能测试的相关文章

使用loadrunner对https协议(单双向SSL)的web端性能测试 (转)

1.项目背景 1.1 单双向SSL的含义及部署 单向SSL即我们说到的https协议. 特点是,浏览器需要请求验证服务器证书: 基本含义是:一个安全通信通道,它基于HTTP开发,用于在客户计算机和服务器之间交换信息.它使用安全套接字层(SSL)进行信息交换,简单来说它是HTTP的安全版. 双向SSL顾名思义就是双方都需要验证证书的协议,浏览器首先向服务端请求证书,然后服务器端需要向浏览器请求目前登陆用户的个人证书验证. 1.2 系统的基本部署 单向SSL交互过程: 使用单向SSL时,仅通过虚拟主

loadrunner支持https协议的操作方法-经验总结

loadrunner支持https协议的操作方法-经验总结 上一篇 / 下一篇  2012-11-09 15:41:33 查看( 6813 ) / 评论( 3 ) / 评分( 10 / 0 ) 问题:用户portal支持https协议,用loadrunner录制登陆脚本时发现未录制到用户名和密码 录制到的脚本如下: login() { lr_think_time(10); web_url("verifycode.jsp", "URL=https://192.168.211.2

代理服务器https协议单站点开通注意事项

在管理代理服务器,开通访问外网权限时 添加的地址的https协议或者http网站,在登陆或使用过程中跳转到https协议时会卡住. 不会出现拦截报文,页面会一直在连接没有反映. 这时有两种解决方案一 第一种 1.使用全开放权限登陆时提示"此网站的安全证书有问题" 2.选择"继续浏览此网站(不推荐)" 3.如下出现地址栏变"粉",末端提示"证书错误"点击"证书错误" 4.点击"查看证书"

Loadrunner之https协议录制回放报错如何解决?(九)

一.录制中遇到报错27778的问题(如下图1),即关于录制的链接为https开头的问题,分两个步骤解决,如下: 图1 https访问报错解决步骤如下: 1.修改Vuser-->Run-time Settings-->Winlnet reply instead of Sockets(Windows only),一般就可以解决上方Error-27778报错.如果不可以继续进行步骤2的操作进行调试工作. 2.1修改后如果还是不能成功回放https相关脚本,按照下图处理,然后继续进行回放调试操作. 准

Https协议:SSL建立过程分析(也比较清楚,而且有OpenSSL的代码)

web访问的两种方式: http协议,我们一般情况下是通过它访问web,因为它不要求太多的安全机制,使用起来也简单,很多web站点也只支持这种方式下的访问. https协议(Hypertext Transfer Protocol over Secure Socket Layer),对于安全性要求比较高的情况,可以通过它访问web,比如工商银行https://www.icbc.com.cn/icbc/(当然也可以通过http协议访问,只是没那么安全了).其安全基础是SSL协议. SSL协议,当前版

Tomcat服务器配置https协议(Tomcat HTTPS/SSL 配置)

通常商用服务器使用https协议需要申请SSL证书,证书都是收费的,价格有贵的有便宜的.它们的区别是发行证书的机构不同,贵的证书机构更权威,证书被浏览器否决的几率更小. 非商业版本可以通过keytool来生成. 用keytool工具生成证书与配置 1.相关工具说明 此处使用1.7.0_79版本,如图所示: 切换到jdk bin目录下面,如图: 证书密钥生成 1.创建证书 keytool -genkey -alias [your_alias_name] -keyalg RSA -keystore

HTTP协议和HTTPS协议初探

概况 HTTP是hypertext transfer protocol(超文本传输协议)的简写.它是TCP/IP协议的一个应用层协议,用于定义WEB浏览器与WEBserver之间交换数据的过程. HTTP是一个属于应用层的面向对象的协议,因为其简捷.高速的方式,适用于分布式超媒体信息系统.它于1990年提出.经过几年的使用与发展.得到不断地完好和扩展.眼下在WWW中使用的是HTTP/1.0的第六版,HTTP/1.1的规范化工作正在进行之中,并且HTTP-NG(Next Generation of

http与https协议

HTTP协议是什么?    简单来说,就是一个基于应用层的通信规范:双方要进行通信,大家都要遵守一个规范,这个规范就是HTTP协议. HTTP协议能做什么?     很多人首先一定会想到:浏览网页.没错,浏览网页是HTTP的主要应用,但是这并不代表HTTP就只能应用于网页的浏览.HTTP是一种协议,只要通信的双方都遵守这个协议,HTTP就能有用武之地.比如咱们常用的QQ,迅雷这些软件,都会使用HTTP协议(还包括其他的协议). HTTP协议如何工作? 大家都知道一般的通信流程:首先客户端发送一个

Loadrunner录制https脚本

Loadrunner录制https脚本 原创 2017-07-10 爱测未来 爱测未来 随着公司的发展,公司原有的SVN服务器存放的内容不断增加,容量已经不能满足后续需求,首先我们想到对服务器进行扩容,然而因为各种原因服务器不能进行扩容,所以公司决定更换新的SVN服务器,在做数据迁移和环境部署之前我们需要对服务器进行一次性能测试,了解部署后的服务器性能,测试过程中需要对https的网页进行性能测试. 我们可以用loadrunner录制http网页,但是当录制https网页的时候会发现证书错误不能