精通软件性能测试与LoadRunner最佳实战 连载十

时间:2021-09-22 04:05:57

下面参见图12-4,针对访问百度首页您是不是就可以得出如下结论了呢?访问百度首页,共耗费了60毫秒,发送668字节,接收4300字节,应用的是GET方法,服务器给予成功响应。也许有的读者说了不可能吧,怎么这么快?这是因为由于作者经常访问百度,所以该地址的一些资源信息被缓存了,从图12-4您也能看到有些内容是从缓存中取得的。接下来,再让我们一起来看一下下方丰富的相关数据信息,如图12-5所示。

精通软件性能测试与LoadRunner最佳实战 连载十

  图12-5  访问百度首页获得的数据信息下半部分

  让我们逐页来看一下相关的数据信息:

  (1)Overview页信息(如图12-6所示)

精通软件性能测试与LoadRunner最佳实战 连载十

  图12-6  访问百度首页获得的数据信息下半部分——Overview页信息

  Display URL:表示请求的地址为百度首页,即:http://www.baidu.com/。

  Started At:发送请求的时刻,本地时间。

  DNS Lookup:DNS解析,找名称为www.baidu.com的主机。

  Connecting:开始同解析后的主机进行连接,主机IP地址为119.75.217.56。

  Connected:与119.75.217.56建立了连接,本地的连接地址和端口为“192.168.0.151:4896”。

  HTTP Request:通过浏览器发出的请求,这里的请求是“http://www.baidu.com/”。

  HTTP Response:服务器返回的头和内容信息。

  (2)Time Chart页信息(如图12-7所示)。

精通软件性能测试与LoadRunner最佳实战 连载十

  图12-7  访问百度首页获得的数据信息下半部分——Time Chart页信息

  该页以直观线条方式显示了各部分的耗时情况,左侧显示考察的URL总体耗时情况,右侧针对左侧图示给出了Blocked(阻塞)、DNS Lookup(DNS寻址)、Connect(连接)、Send(发送请求)、Wait(等待服务器响应)、Receive(返回响应)、TTFB(即:Time To First Byte,首字节返回)和Network(网络)耗费时间的情况。

  下面作者以表格形式给出各部分耗时相关的一些说明信息,参见表12-2所示。

12-2   各段耗时说明

序号

图示名称

含    义

1

Blocked

阻塞时间包括任何预处理时间(比如缓存查找)和花费的时间等待网络连接可用。浏览器限制数量的并发网络连接每个主机名和将请求排队,如果已经达到极限则后续请求需排队

2

DNS Lookup

DNS解析一个主机名到一个IP地址所耗费的时间

3

Connect

连接是所需的时间创建一个TCP连接到Web服务器(或代理)。如果一个安全的HTTPS连接正在用这段时间包括SSL握手过程

4

Send

发送是发送HTTP请求消息到服务器所需的时间

5

Wait

等待是等待从服务器得到响应消息的时间。这个值包括由于网络延迟和请求Web服务器所需时间

6

Receive

客户端接收从服务器读取响应消息的时间。这个值取决于内容返回的大小、网络带宽和是否使用了HTTP压缩等

7

TTFB

TTFB是从浏览器发出请求到服务器返回第一个字节所耗费的时间。它包括TCP连接时间,发送请求时间和接收第一个字节的响应消息时间

8

Network

网络是一个HTTP请求在网络消息传输上耗费的时间

从图12-7您可以一目了然地看到访问百度首页共耗费了60毫秒的时间,其主要耗费时间的部分在服务器返回响应数据上,其耗费了39毫秒。

 (3)Headers页信息。

  图12-8  访问百度首页获得的数据信息下半部分——Headers页信息

精通软件性能测试与LoadRunner最佳实战 连载十

  图12-8给出了发送请求头和返回请求头的相关内容,这里我们也列一个表格给予分析,参见表12-3和表12-4所示。

序号

表头信息

含    义

1

GET /HTTP/1.1

GET”代表请求方法,“HTTP/1.1”代表协议和协议的版本

2

Accept

Accept请求报头域用于指定客户端接受哪些类型的信息。例如:Accepttext/html,表明客户端希望接受html文本

3

Accept-Encoding

Accept-Encoding请求报头域类似于Accept,但是它是用于指定可接受的内容编码。例如:Accept-Encoding:gzip,deflate.如果请求消息中没有设置这个域服务器假定客户端对各种内容编码都可以接受

4

Accept-Language

Accept-Language请求报头域类似于Accept,但是它是用于指定一种自然语言。例如:Accept-Language:zh-cn,中文。如果请求消息中没有设置这个报头域,服务器假定客户端对各种语言都可以接受

5

Connection

连接类型,默认为Keep-Alive(长连接),如果不希望使用长连接,则需要在header中指明Connection的值为Close

6

Cookie

Cookie是由服务器端生成,发送给浏览器,浏览器会将Cookiekey/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器。服务器可以利用Cookies包含信息的任意性来筛选并经常性维护这些信息,以判断在HTTP传输中的状态。可以判断其是否登录过网站,客户的喜好等

7

Host

Host请求报头域主要用于指定被请求资源的Internet主机和端口号,它通常从HTTP URL中提取出来的,我们在浏览器中输入:http://bbs.51testing.com/,浏览器发送的请求消息中就会包含Host请求报头域,如下:Hostbbs.51testing.comn,此处使用缺省端口号80,若指定了端口号为8080,则变成:Hostbbs.51testing.com:8080

8

User-Agent

User-Agent请求报头域允许客户端将它的操作系统、浏览器和其他属性告诉服务器

  关于GET和POST方法在这里简单做一下说明,GET方法是默认的HTTP请求方法,我们日常用GET方法来提交表单数据,然而用GET方法提交的表单数据只经过了简单的编码,同时它将作为URL的一部分向Web服务器发送,因此,如果使用GET方法来提交表单数据就存在着安全隐患上。同时由于GET方法提交的数据是作为URL请求的一部分所以提交的数据量也不能太大。POST方法是GET方法的一个替代方法,它主要是向Web服务器提交表单数据,尤其是大批量的数据。POST方法克服了GET方法的一些缺点。通过POST方法提交表单数据时,数据不是作为URL请求的一部分而是作为标准数据传送给Web服务器,这就克服了GET方法中的信息无法保密和数据量太小的缺点。因此,出于安全的考虑以及对用户隐私的保护,通常表单提交时采用POST方法。

表12-4   服务器端响应返回表头说明

序号

表头信息

含    义

1

HTTP/1.1 200 OK

HTTP/1.1代表协议和协议的版本,200HTTP响应代码,表示成功

2

Cache-Control

Cache- Control指定请求和响应遵循的缓存机制。在请求消息或响应消息中设置 Cache-Control并不会修改另一个消息处理过程中的缓存处理过程。请求时的缓存指令包括no-cacheno-storemax-age max-stalemin-freshonly-if-cached,响应消息中的指令包括publicprivateno-cacheno-storeno-transformmust-revalidateproxy-revalidatemax-age。各个消息中的指令含义如下:

Public指示响应可被任何缓存区缓存;

Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效;

no-cache指示请求或响应消息不能缓存;

no-store用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存;

max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应;

min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应;

max-stale指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息

3

Connection

连接类型,默认为Keep-Alive(长连接),如果不希望使用长连接,则需要在header中指明Connection的值为Close

4

Content-Encoding

Accept-Encoding请求报头域类似于Accept,但是它是用于指定可接受的内容编码。例如:Accept-Encoding:gzip,deflate,如果请求消息中没有设置这个域服务器假定客户端对各种内容编码都可以接受

5

Content-Length

表示内容长度,只有当浏览器使用持久HTTP连接时才需要这个数据

6

Content-Type

表示服务器发送的内容的MIME类型

7

Date

Date头域表示消息发送的时间,时间的描述格式由rfc822定义。例如,Thu,15 Nov 2012 05:56:32 GMTDate描述的时间表示世界标准时间

8

Expires

Expires: Thu,15 Nov 2012 05:56:32 GMT 需和Last-Modified结合使用。用于控制请求文件的有效时间,当请求数据在有效期内时,客户端浏览器从缓存请求数据而不是服务器端,当缓存中数据失效或过期,才从服务器更新数据

9

Server

指示服务器的类型,如apache tomcat。这里出现的BWS应该是Baidu Web Server,百度自己研发的Web服务器用来代替apache

    关于MIME(Multipurpose Internet Email Extension),意为多用途Internet邮件扩展,它是一种多用途网际邮件扩充协议,在1992年最早应用于电子邮件系统,但后来也应用到浏览器。服务器会将它们发送的多媒体数据的类型告诉浏览器,而通知手段就是说明该多媒体数据的MIME类型,从而让浏览器知道接收到的信息哪些是MP3文件,哪些是JPEG文件等。当服务器把把输出结果传送到浏览器上的时候,浏览器必须启动适当的应用程序来处理这个输出文档。在HTTP中,MIME类型被定义在<head>、</head>部分的Content-Type中。

  后续内容请从书籍获得……

  (未完待续)