1.http协议介绍
HTTP是一种请求/响应式的协议,基于TCP协议来进行数据传输。
HTTPS是HTTP协议和安全套借口层(SSL)的结合,即安全增强版的HTTP。
HTTP请求由三部分组成:请求行,消息报头,请求正文(可选)。
请求行e.g.
GET/HTTP/1.1
请求行格式:
1)Method(请求方法) 2)Request-URI(统一资源标识符) 3)HTTP-Version(HTTP协议版本) 4) CRLF(回车或换行)
请求方法:
GET:请求获取Request-URI所标识的资源 常用
POST:在Request-URI所标识的资源后附加新的数据 常用
HEAD:请求获取由Request-URI所标识的资源的响应消息报头
PUT:请求服务器储存一个资源,并用Request-URI作为其标识 常用
DELETE:请求服务器删除Request-URI所标识的资源 常用
TRACE:请求服务器回送收到的请求信息,主要用于测试或诊断
CONNECT:保留将来使用
OPTIONS:请求查询服务器的性能,或者查询与资源相关的选项和需求
HTTP响应由三部分组成:状态行,消息报头,响应正文
状态行e.g.
HTTP/1.1 200 OK
状态码:
1**:指示信息——表示请求已被接收,继续处理
2**:成功——表示请求已被成功接收,理解,接受
3**:重定向——要完成请求必须进行更进一步的操作
4**:客户端错误——请求有语法错误或请求无法实现
5**:服务器端错误——服务器未能实现合法的请求
常见状态代码:
200 OK //客户端请求成功
400 Bad Requests //客户端请求有语法错误,不能被服务器所理解
401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
403 Forbidden //服务器收到请求,但是拒绝提供服务
404 Not Found //请求资源不存在,e.g. 输入了错误的URL
500 Internal Server Error //服务器发生不可预期的错误
503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后可能恢复正常
二.在TCP协议层面的交互和并发
一次完整的HTTP请求包括四部分:
1)TCP 连接建立(三次握手)
2)HTTP GET请求的发出
3)HTTP响应的返回
4)TCP连接断开(四次握手)
HTTP请求中TCP连接可以复用:
如果页面有200个元素,是不是应该新建和销毁200个TCP请求呢,实际情况并不是,实际TCP源端口出现了6次,只连接完成了6次HTTP请求和响应,所以复用了这个TCP连接来串行发起多次请求。
可以在firefox中设置并发数,Avalanche中设置单个server最大连接数,Jmeter中单个Sever最大连接数设置pool size。
HTTP传输过程中的数据压缩:
客户端在HTTP请求头里面指明可以支持gzip压缩,服务器也要开启压缩相关的设置。
缓存的管理:
satus code:200 OK(from cache)/304 Not Modified
cache-control:设定了缓存的有效时间max-age,还有很多参数可以选择。
e.g.public private no-cache no-store max-age s-maxage
last-modified:表示这个文件的内容最后一次在服务器上被修改的事件
expires:表示这个文件可用于本地缓存的过期时间
HTTP 304:缓存过期了,服务端接受到浏览器的请求后,判断认为服务端最新的该文件版本和客户端已有的一致,于是高速客户端不需要再传输完整的内容了,可以直接用本地的版本。
即只需通过304简单应答,而不必重新传输文件的内容,同样起到了缓存的目的。