是的你没看错,HTTP3来了
简介
很多小伙伴可能还沉浸在HTTP1.1的世界无法自拔,但是时代的洪流已经带领我们来到了HTTP3的世界了。是的,你在桥上看风景,而桥边的房子上有人正在看你。
为了不被时代所抛弃,今天给大家讲解一下HTTP3的新特性。
HTTP成长介绍
HTTP的全名叫做超文本传输协议,是万维网所基于的应用层传输协议。最初的版本是HTTP 0.9,是在80年的后期产生的,后面在1996年升级到了1.0.
但是HTTP1.0满足不了日益增长的物质文化需求和对美好世界的向往。所以在1997年出现了HTTP1.1,随后到2014年,HTTP1.1都一直都在更新。
然后到了2015年,为了适应快速发送的web应用和现代浏览器的需求,在Google的SPDY项目基础上发展出了新的HTTP2协议。
又过了4年,在2019年,Google又开发出了一个新的协议标准QUIC协议,它就是HTTP3的基石,其目的是为了提高用户与网站和API交互的速度和安全性。
不同HTTP协议解决的问题
不同HTTP协议解决的问题也是不同的,HTTP1.1有什么问题呢?
因为HTTP1.1一个连接中数据是顺序传输的,所以会有Head-of-line Blocking的问题,如果前面是一个大的数据包,则会导致后续数据包的阻塞。
HTTP1.1无法对请求头和cookie进行压缩,所以传输效率会比较低。
为了保证缓冲区不会溢出,HTTP1.1有一个TCP慢启动的功能,作为拥塞控制措施,协议反复探测网络以计算可用容量,但是这样就会导致多次数据的传输,从而导致消息的延时。
对于HTTP2来说,它使用二进制进行消息传输,并且将消息拆分成一个个的stream,在stream中又包含了多个frame,允许资源通过多路复用使用同一个连接发送,解决了行头阻塞的问题,并且还支持数据包的优先级和服务器推送。
但是HTTP2的服务器推送会导致应用程序变得复杂,TCP级别的头阻塞的问题在数据包丢失并且必须重新以正确的顺序重新发送时,仍然可能发生。
要注意,HTTP/2是HTTP/1.1的扩展,而不是它的替代品。 应用程序语义保持不变,具有相同的HTTP方法、状态代码、URI和标头字段。 所以HTTP/2可以被用在任何使用HTTP/1.1的地方。
HTTP/2在客户端和服务器之间使用单个TCP连接,该连接在交互期间保持打开状态。
虽然HTTP/2支持并发,但是过多的并发会导致HTTP/2服务器接收到大批量的请求,从而导致请求超时。
HTTP3和QUIC
HTTP/3的目标是通过解决HTTP/2的传输相关问题,在所有形式的设备上提供快速、可靠和安全的Web连接。为此,它使用了一种不同的传输层网络协议,称为QUIC,该协议最初由Google开发的。
感慨一下,虽然最近中国在系统的应用方面有了一定的进步,但是看看这些底层的协议,还都是外国人搞出来的。
HTTP/2和HTTP/3的根本区别在于,HTTP/2底层使用的是TCP协议,而HTTP/3使用的是QUIC,而QUIC的底层使用的是UDP协议。
我们看一下HTTP/2和HTTP/3的协议栈对比:

TCP协议主要保证服务的可靠性和有序交付,但是TCP需要同握手来建立连接,这样做是为了确保客户端和服务器都存在并且他们愿意并且能够交换数据。但是,它也需要一个完整的网络往返才能完成,然后才能在连接上完成任何其他操作。 如果客户端和服务器端相距比较远,那么就需要花费较多的时间来进行连接。
我们知道UDP是无连接的,所以它要比TCP简单很多。它不需要TCP这种建立多次连接的步骤,只需要发送数据包出去就够了。
所以使用QUIC的优点就在于减少了系统的延时,适用于可以容忍一些数据丢包的情况,比如在线游戏、广告竞价、在线视频、实时流等地方。
另外因为UDP支持广播,所以HTTP3还适用于广播应用中,如精确时间协议和路由信息协议等。
另外HTTP3还可以用在物联网、大数据和VR等方面。
既然HTTP3使用的是QUIC协议,那么QUIC到底是什么呢?
通常来说QUIC是一种通用传输协议,与TCP非常相似。为什么要打造一套新的协议呢?这是因为现有的TCP协议扩展起来非常困难,因为已经有太多太多的设备使用了各种不同的TCP协议的版本,如果想直接在现有的TCP协议上进行扩展非常困难,因为需要给这么多台设备进行升级几乎是不可能完成的任务。
所以QUIC在选择在UDP协议之上进行构建。QUIC使用UDP,主要是因为希望能让HTTP/3更容易部署,因为它已经被互联网上的所有设备所知并已实现.
QUIC实际上就是在UDP基础上重写了TCP的功能,但是又比TCP更加智能,更高效的实现了TCP的核心功能。
接下来我们看下QUIC具体有哪些特征。
TLS1.3
TLS主要用来保证客户端和服务器端在数据传输过程的数据安全性,可以对明文数据进行加密传输。TLS1.3是TLS协议的最新版本,在旧的版本如TLS1.2中,客户端和服务器端的握手至少需要两次网络往返,但是在TLS1.3中,将其减少到只有一次往返。
虽然在HTTP/2中是支持无加密传输模式,但是默认情况下所有的现代浏览器都不支持这种模式,所以HTTP/2必须配合HTTPS一起使用。长远看来HTTPS肯定是未来的趋势,所以在QUIC中,直接就使用了TLS 1.3协议。QUIC本身就封装了TLS1.3。
这样做的好处就是QUIC没办法运行明文,所以更加的安全。并且QUIC内置了加密协议,将传输和加密握手合二为一,节省了往返。
因为QUIC是全程加密的,所以对于某些ISP和中间网络来说,无法再对网络数据进行分析和统计,所以可能会限制它的使用。并且因为QUIC是单独对每个数据包进行加密的,在高并发的情况下,可能会造成性能问题。
解决HoL阻塞
传统的HTTP1.1和HTTP2底层协议是TCP,虽然HTTP2在应用层可以将不同文件的数据拆分成一个个的stream放在同一个连接中进行传输。但是对于TCP本身来说,它并不知道这些stream属于不同的文件,它会将其当成同一个文件。所以如果发送数据丢包的情况,TCP会重新发送所有的文件包。从而导致HOL阻塞的问题。
而QUIC更加细粒度一点,它可以在每个流的基础上执行丢包检测和恢复逻辑。从而只会重发失败的流,而不是整个文件。
连接的迁移
在TCP中,如果我想要建立客户端和服务器端的连接,需要知道这4个元素:客户端IP地址 + 客户端端口 + 服务器IP地址 + 服务器端口。
如果这4个元素中有一个发送了变化,则需要重新建立TCP连接。并且需要根据应用程序级协议,重新启动进程中的操作。
比如你正在下载一个大的文件,但是网络地址突然发生了变化,则可能需要重新请求该文件。
为了解决这个问题,QUIC引入了一个名为连接标识符(CID)的概念 。 每个连接都在上述4个元素中额外分配一个编号,用于标记客户端和服务器端的唯一连接。
因为这个CID是由QUIC定义的,所以不会随着网络迁移的变化而变化。从而不需要新的握手,这种情况被称为连接迁移 。
总结
好了,今天的HTTP/3和QUIC就介绍到这里,虽然我们没有涉及到底层的更多细节,但是相信大家应该都听得明白了,再总结一下,QUIC实际上行就是在UDP协议之上,再造了一个更加高级有效的TCP协议。
本文已收录于 http://www.flydean.com/03-http3/
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
是的你没看错,HTTP3来了的更多相关文章
- 是的 你没看错!!!用JAVA为MCU开发物联网程序?
是的 你没看错!!!用JAVA为MCU开发物联网程序? 一直以来,物联网设备这种嵌入式硬件,对于Java软件开发者来说,就是Black Magic Box,什么中断.寄存器,什么 ...
- 是的,你没看错!Python可以实现自动化办公
是的,你没看错!Python可以实现自动化办公 公众号[伤心的辣条],如今越来越多的人加入到学习Python的队伍当中,尤其是对于很多职场人来说,不管你是程序员还是非程序员,Python已经为很多职场 ...
- QQ公众号?是的,你没看错!
微信公众平台培育了800多万的微信公众号,自身也通过微信游戏.广告分销等找到了一些增值盈利模式.作为同门大师兄,qq也在11月份推出了QQ公众号,第一个手机QQ上的“生活服务号”——YTO圆通速递上线 ...
- 为什么我的子线程更新了 UI 没报错?借此,纠正一些Android 程序员的一个知识误区
开门见山: 这个误区是:子线程不能更新 UI ,其应该分类讨论,而不是绝对的. 半小时前,我的 XRecyclerView 群里面,一位群友私聊我,问题是: 为什么我的子线程更新了 UI 没报错? 我 ...
- 【Luogu】P2765魔术球问题(没看懂的乱搞)
题目链接 这题……讲道理我没看懂. 不过我看懂题解的代码是在干嘛了qwq 题解是zhaoyifan的题解 然后……我来讲讲这个题解好了. 题解把值为i的球拆成了两个,一个编号是i*2,一个编号是i*2 ...
- Java抽象类和接口的区别(好长时间没看这种文章了)
Java抽象类和接口的区别(好长时间没看这种文章了) abstract class和interface是Java语言中对于抽象类定义进行支持的两种机制,正是由于这两种机制的存在,才赋予了Java强大的 ...
- PAT 甲级 1031 Hello World for U (20 分)(一开始没看懂题意)
1031 Hello World for U (20 分) Given any string of N (≥) characters, you are asked to form the char ...
- Bug2020011601,在ssh项目的applicaitonContext.xml中,少了一个双引号,打包成功(没报错),项目运行才发现
在ssh项目的applicaitonContext.xml中,少了一个双引号,打包成功(没报错),项目运行才发现. 加上少的双引号,解决了.
- 【Kafka 源码解读】之 【代码没报错但是消息却发送失败!】
聊聊最近,2020年,在2019年的年尾时,大家可谓对这年充满新希望,特别是有20200202这一天.可是澳洲长达几个月的大火,新型冠状病毒nCoV的发现,科比的去世等等事情,让大家感到相当的无奈,生 ...
随机推荐
- 3.Java入门
一.Java帝国的诞生 一场旷日持久的战争 1.C & C++ 1972年C诞生 贴近硬件(有汇编的一些特点),运行极快,效率极高 操作系统,编译器,数据库,网络系统等 指针(能够直接操作内存 ...
- c语言:随机函数应用
#include <stdio.h> #include <time.h>//声明time 时间不可逆转一直在变 #include <math.h> #include ...
- PYTHON2.7安装 pyinstaller出错,不能正常安装
解决方法: pip2.7 install pyinstaller==3.4
- 【论文阅读】Motion Planning through policy search
想着CSDN还是不适合做论文类的笔记,那里就当做技术/系统笔记区,博客园就专心搞看论文的笔记和一些想法好了,[]以后中框号中间的都算作是自己的内心OS 有时候可能是问题,有时候可能是自问自答,毕竟是笔 ...
- this的四种用法!
经常会有人问到this的用法,其实简单来说,this有四种应用场景,分别是在构造函数上.对象属性中.普通函数中.call和apply方法中. 首先我们来看第一种:在构造函数中的用法 第二种是在在对象属 ...
- xhell、xftp、putty使用教程
作为远程登陆工具,上传代码登陆服务器工具 1.XSHELL Xshell是远程连接Linux服务器的工具,基于SSH协议,使用它可以更加方便的操作Linux操作系统,在刚使用时可能需要提前简单的设置下 ...
- (Opencv02)图片展示
(Opencv02)图片展示 在程序里我们怎么把图片显示出来呢? 这里需要记一个自定义函数就好啦! def cv_show(name, img): cv2.imshow(name, img) ...
- 类加载机制+JVM调优实战+代码优化
类加载机制 Java源代码经过编译器编译成字节码之后,最终都需要加载到虚拟机之后才能运行.虚拟机把描述类的数据从 Class 文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直 ...
- QT-可拖拽可编辑的多控件ListView
目标 结合前面的2篇文章, 继续升级QML版本的ListView: 又要拖拽, 又要可编辑, 还得支持多个控件. 循序渐进 本文基于前一篇的基础: Qt-可编辑的ListView 要循序渐进的学习. ...
- noip模拟测试21
考试总结:这次考试,前两道题的题面描述不是很清楚,导致我不知道输出格式到底是什么,挂了差不多80分(好多人也是这样),总体来说,这次考试的前两道题暴力分是打满了,最后一道题打了一个假的暴搜,在考场上没 ...