前情提要

在上一篇文章《【HTTP
2.0】 简介(Introduction)
》中,我们简单介绍了 HTTP 2。

在本篇文章中,我们将会了解到 HTTP 2 协议概述部分的内容。

HTTP/2 协议概述(HTTP/2 Protocol Overview)

HTTP 2 优化了 HTTP 传输部分的语义。HTTP 2 支持 HTTP 1.1 中所有的特性,它旨在通过多种方法提升 HTTP 的效率。

HTTP 2 协议的基础单元是帧(Frame)(参考章节
4.1
)。每种帧的目的各不相同。比如,HEADERS 帧和 DATA帧组成了 HTTP 的请求和相应(参考章节
8.1
)。其他类型的帧则用于支持 HTTP 2 的其他特性,比如 SETTINGS、WINDOW_UPDATE 和 PUSH_PROMISE。

每一个 HTTP 通过在其流(参考章节
5
)中关联请求与相应,以实现请求的多路复用。流与流之间是相互独立的,所以,一个挂起的或者慢速的请求或响应,将不会影响其他流的进度。

通过流量控制和优先级来保证流的多路复用效率。流量控制(参考章节
5.2
)保证可用数据能够传达至接收者。优先级(参考章节
5.3
)保证有限的资源能够最先被应用在最重要的流中。

HTTP 2 新增了互动模式,以实现服务器主动推送响应内容至客户端(参考章节
8.2
)的功能。服务器推送技术允许服务器预测客户端所需的数据,并推送至客户端,通过付出一些网络资源来降低等待延迟。服务器通过发送 PUSH_PROMISE 帧,建立合成请求,之后便可以通过合成请求在单独的流中发送响应信息。

在一个连接中包含大量重复的 HTTP 报头字段,帧中包括了这些字段,并对其进行了压缩(参考章节
4.3
)。在大多数情况下,这有利于请求大小的优化,允许很多请求被压缩至一个数据包。

文档组织结构

HTTP 2 规范分为以下四部分:

  • 发起 HTTP 2(第3章)包括了如何初始化一个
    HTTP 2 连接。
  • 帧层(第4章)和流层(第5章)描述了
    HTTP 2 中帧的构成,以及如何形成多路复用流。
  • 帧定义(第6章)和异常定义(第7章)包括了
    HTTP 2 中的帧的详细信息以及异常的类型。
  • HTTP 映射(第8章)和附加要求(第9章)描述了
    HTTP 语法是如何表达帧和流的。

帧和流的概念有一部分是独立于 HTTP 的,本规范没有定义完全通用的帧层。帧和流是根据 HTTP 协议以及服务器推送而定制的。

约定和术语

本文档中的关键词 “MUST”,“MUST NOT”,“REQUIRED”,“SHALL”,“SHALL NOT”,“SHOULD”,“SHOULD NOT”,“RECOMMENDED”,“MAY”,“OPTIONAL”如 RFC
2119
 中所描述的进行解读。

所有数值都是按网络字节顺序。值均为无符号,除非进行特殊说明。字面量通过十进制或者十六进制表示。十六进制字面量以 0x 作为前缀,以区别于十进制字面量。

以下术语用于:

客户端(client):

发起一个 HTTP 2 连接的终端。客户端发送 HTTP 请求,并接收 HTTP 响应。

连接(connection):

两个终端之间的传输层连接。

连接错误(connection error):

影响整个 HTTP 2 连接的错误。

终端(endpoint):

连接中的客户端或者服务器。

帧(frame):

一个 HTTP 2 连接内通信的最小单位。是一个由报头和帧类型(八种帧类型之一)所组成的可变长度序列。

点(peer):

点是一个终端。当讨论一个特定终端时,“点”指代的是讨论的主题所对应的远程终端。

接收者(receiver):

接收帧的终端。

发送者(sender):

发送帧的终端。

服务器(server):

接受 HTTP 2 连接的的终端。服务器接收 HTTP 请求,并发送 HTTP 响应。

流(stream):

HTTP 2 连接中双向流动的帧。

流错误(stream error):

独立的 HTTP 2 流中产生的错误。

最后,术语“网关”,“中介”,“代理”和“隧道”在 RFC
7230
 的 2.3
章节
中有所定义。中介在不同的时候即充当客户端又充当服务器。

术语“有效载荷体”在 RFC
7230
 的 3.3
章节
中有所定义。


本文以 CC
BY-NC-SA 3.0 CN
 协议共享,转载、共享及二次创作时请保留原文出处及链接,请勿用于商业用途。

本文链接:http://litecodes.com/dev/http-2-spec-protocol-overview/

本系列文章将会在我的 GitBook:http2-spec-zh 同步更新,

下一篇文章将会翻译协议的第三部分:Starting HTTP/2(发起 HTTP 2),不要错过哟~

【HTTP 2】HTTP/2 协议概述(HTTP/2 Protocol Overview)的更多相关文章

  1. javaweb学习总结十九(http协议概述以及http请求信息分析)

    一:http协议概述 1:http协议定义 2:使用telnet程序连接web服务器,获取资源 3:http协议:超文本传输协议,它是基于tcp/ip协议,就是建立在tcp/ip之上工作的, http ...

  2. 嵌入式linux的网络编程(1)--TCP/IP协议概述

    嵌入式linux的网络编程(1)--TCP/IP协议概述 1.OSI参考模型及TCP/IP参考模型 通信协议用于协调不同网络设备之间的信息交换,它们建立了设备之间互相识别的信息机制.大家一定都听说过著 ...

  3. JAVA之旅(三十二)——JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用

    JAVA之旅(三十二)--JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用 GUI写到一半电脑系统挂了,也就算了,最多GUI还有一个提示框和实例, ...

  4. 【高速接口-RapidIO】1、RapidIO协议概述

    一.RapidIO背景介绍 RapidIO是由Motorola和Mercury等公司率先倡导的一种高性能. 低引脚数. 基于数据包交换的互连体系结构,是为满足和未来高性能嵌入式系统需求而设计的一种开放 ...

  5. 1.RapidIO协议概述

    转自https://www.cnblogs.com/liujinggang/p/9925859.html 一.RapidIO背景介绍 RapidIO是由Motorola和Mercury等公司率先倡导的 ...

  6. [编程] TCP协议概述

    TCP 协议概述 1.TCP提供一种面向连接的.可靠的字节流服务. 2.两个应用程序通过TCP连接交换8bit字节构成的字节流. 3.每个TCP首部都包含源端和目的端的端口号,用于寻找发端和收端应用进 ...

  7. 搞懂分布式技术4:ZAB协议概述与选主流程详解

    搞懂分布式技术4:ZAB协议概述与选主流程详解 ZAB协议 ZAB(Zookeeper Atomic Broadcast)协议是专门为zookeeper实现分布式协调功能而设计.zookeeper主要 ...

  8. arp:地址解析协议(Address Resolution Protocol)(来自维基百科)

    地址解析协议(Address Resolution Protocol),其基本功能为通过目标设备的IP地址,查询目标设备的MAC地址,以保证通信的顺利进行。它是IPv4中网络层必不可少的协议,不过在I ...

  9. 协议端口号(protocol port number)

    协议端口号(protocol port number) 先来个注意事项 (-> ->) 这种在协议层间的抽象的协议端口是软件端口,和硬件端口是完全不同的概念.硬件端口是不同设备进行交互的接 ...

随机推荐

  1. QT5程序发布dll依赖

    QT5 发布程序,太庞大了,QT4下,基本的也就20M左右 platforms目录是 对应X:\Qt\Qt5.3.2\5.3\mingw482_32\plugins\platforms 下的qmini ...

  2. Sicily-1153 解题报告

    一.原题中文大意. 1      2       3      4       5      6         7     8 9     10       11    12      13    ...

  3. 解决外贸电商难题,PayPal中国外贸电商大会圆满礼成

        在全球经济一体化的背景下,越来越多的中国企业将目光转移到了海外.对中国的企业而言,要想将生意做到海外大致有两种方法可供选择,一是到海外设立分支机构或者分公司,二是通过外贸电子商务平台实现交易. ...

  4. iOS中的 SB和XIB的前世今生

    今天给大家介绍一下Apple开发中三种几种常用的应用程序编写方式:纯代码创建.使用storyboard/XIB.我们都知道,纯代码编写模式适合大型项目大规模使用,利于版本管理.追踪改动以及代码合并,代 ...

  5. 11个实用但你可能不知道的Python程序库

    目前,网上已有成千上万个Python包,但几乎没有人能够全部知道它们.单单PyPi上就有超过47000个包列表. 现在,越来越多的数据科学家开始使用Python,虽然他们从pandas,scikit- ...

  6. JavaSE学习总结第07天_面向对象2

      07.01 成员变量和局部变量的区别 1.在类中的位置不同 成员变量    类中方法外 局部变量    方法内或者方法声明上 2.在内存中的位置不同 成员变量   堆内存 局部变量   栈内存 3 ...

  7. 配置分割Tomcat日志

    安装cronolog 官网下载:http://cronolog.org/usage.html ./configuremake;make install 或者 yum install cronolog ...

  8. TF-IDF算法-自动提取关键词汇

    引子:Automatic Keyphrase extraction 很长文章里面,如何自动提取关键词汇呢? 比如在<中国的蜜蜂养殖>的长文里面,我们准备提取它的关键词.首先一个思路, 那些 ...

  9. 第四节 二维条码与磁卡、IC卡、光卡之比较

    二维条码同其他几种自动识别技术的比较可见下表: 比较点 二维条形码 磁卡 IC卡 光卡 抗磁力 强 弱 中等 强 抗静电 强 中等 中等 强 抗损性 强可折叠可局部穿孔可局部切割 弱不可折叠不可穿孔不 ...

  10. 数据切分——MySql表分区概述

    定义:         表的分区指根据可以设置为任意大小的规则,跨文件系统分配单个表的多个部分.实际上,表的不同部分在不同的位置被存储为单独的表.用户所选择的.实现数据分割的规则被称为分区函数,这在M ...