HTTP/2(超文本传输协议第2版),是 HTTP 协议的第二个主要版本,向下兼容 HTTP1.X,设计目标是:解决 HTTP1.X 中的性能问题,更有效的利用网络资源,减少网络应用的延迟,提高站点页面加载速度。
HTTP历史

HTTP/0.9
HTTP/0.9 是于 1991 年提出的,主要用于学术交流,需求很简单——用来在网络之间传递 HTML 超文本的内容,所以被称为超文本传输协议。整体来看,它的实现也很简单,采用了基于请求响应的模式,从客户端发出请求,服务器返回数据。
-
-
建立好连接之后,会发送一个 GET 请求行的信息,如GET /index.html用来获取 index.html。
-
服务器接收请求信息之后,读取对应的 HTML 文件,并将数据以 ASCII 字符流返回给客户端。
-
- 首先在浏览器中展示的不单是 HTML 文件了,还包括了 JavaScript、CSS、图片、音频、视频等不同类型的文件。因此支持多种类型的文件下载是 HTTP/1.0 的一个核心诉求,而且文件格式不仅仅局限于 ASCII 编码,还有很多其他类型编码的文件。为了让客户端和服务器能更深入地交流,HTTP/1.0 引入了请求头和响应头,它们都是以为 Key-Value 形式保存的,在 HTTP 发送请求时,会带上请求头信息,服务器返回数据时,会先返回响应头信息。
-
-
服务器需要统计客户端的基础信息,比如 Windows 和 macOS 的用户数量分别是多少,所以 HTTP/1.0 的请求头中还加入了用户代理的字段。
-
HTTP/1.1对带宽的利用率并不理想,这也是 HTTP/1.1 的一个核心问题。
带宽是指每秒最大能发送或者接收的字节数。我们把每秒能发送的最大字节数称为上行带宽,每秒能够接收的最大字节数称为下行带宽。之所以说 HTTP/1.1 对带宽的利用率不理想,是因为 HTTP/1.1 很难将带宽用满。比如我们常说的 100M 带宽,实际的下载速度能达到 12.5M/S,而采用 HTTP/1.1 时,也许在加载页面资源时最大只能使用到 2.5M/S,很难将 12.5M 全部用满。
原因:
-
TCP 的慢启动。一旦一个 TCP 连接建立之后,就进入了发送数据状态,刚开始 TCP 协议会采用一个非常慢的速度去发送数据,然后慢慢加快发送数据的速度,直到发送数据的速度达到一个理想状态,我们把这个过程称为慢启动。慢启动是 TCP 为了减少网络拥塞的一种策略,我们是没有办法改变的。
-
同时开启了多条 TCP 连接,那么这些连接会竞争固定的带宽。想象一下,系统同时建立了多条 TCP 连接,当带宽充足时,每条连接发送或者接收速度会慢慢向上增加;而一旦带宽不足时,这些 TCP 连接又会减慢发送或者接收的速度。比如一个页面有 200 个文件,使用了 3 个 CDN,那么加载该网页的时候就需要建立 6 * 3,也就是 18 个 TCP 连接来下载资源;在下载过程中,当发现带宽不足的时候,各个 TCP 连接就需要动态减慢接收数据的速度。
-
多路复用
-
-
这些数据经过二进制分帧层(stream)处理之后,会被转换为一个个带有请求 ID 编号的帧,通过协议栈将这些帧发送给服务器。
-
服务器接收到所有帧之后,会将所有相同 ID 的帧合并为一条完整的请求信息。
-
然后服务器处理该条请求,并将处理的响应行、响应头和响应体分别发送至二进制分帧层。
-
同样,二进制分帧层会将这些响应数据转换为一个个带有请求 ID 编号的帧,经过协议栈发送给浏览器。
-

以及服务端推送(服务端主动推动客户端所需资源,减少请求次数),还有流量控制、请求优先级等。
开启HTTP/2
Nginx配置HTTP/2
Nginx的版本不能低于Nginx 1.10,编译的时候有http_v2_module和http_ssl_module模块,需要开启HTTPS
server {
#开启HTTP2
listen 443 ssl http2;
#请填写绑定证书的域名
server_name www.timelessq.com;
#请填写证书文件的相对路径或绝对路径
ssl_certificate www.timelessq.com.crt;
#请填写私钥文件的相对路径或绝对路径
ssl_certificate_key www.timelessq.com.key;
ssl_session_timeout 5m;
#添加需要的TLS协议配置
ssl_protocols TLSv1.2 TLSv1.3;
#请按照以下套件配置,配置加密套件,写法遵循 openssl 标准。
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_ciphers on;
}
检查请求使用的http协议





还没有评论,快来抢第一吧