I saw the introduction of http/2.0 in developers.google.com. However, I feel confused about the request and response multiplexing. So I decided to make a demo or an example for better understanding.git
When I saw the TCP connection reuse, I had a lot of questions in my head. For instances,github
After searching, I found that there is a Connection ID column in the chrome dev tool Network panel. For example, here is the network image of baidu.com :web
According to this questionchrome
The new Connection ID Network Panel column in Canary can help indicate to you that a TCP connection was reused instead of handshaking and establishing a new one.
Combined with the above image, we can say that in the network panel of baidu.comcors
It seems http/1.1 also support TCP connection Reuse. So, how can I prove the advantages of H2 or what's the difference between the connection reuse of http/1.1 and 2.0? That confused me in the past.ide
I pick two requests from the network record and then fetch it at the console. The code of requests to http/1.1 is:chrome-devtools
Array(13) .fill() .forEach(() => { fetch('https://www.baidu.com/favicon.ico', { credentials: 'omit', referrer: 'https://www.baidu.com/', referrerPolicy: 'unsafe-url', body: null, method: 'GET', mode: 'cors' }) })
And the code of requests to http/2.0 is:fetch
Array(13) .fill() .forEach(() => { fetch( 'https://ss3.baidu.com/6ONWsjip0QIZ8tyhnq/ps_default.gif?_t=1556369856347', { credentials: 'omit', referrer: 'https://www.baidu.com/', referrerPolicy: 'unsafe-url', body: null, method: 'GET', mode: 'cors' } ) })
Here are the results:ui
Take a closer look at the pictures, we can find thatthis
On HTTP 1.0/1.1 connections, Chrome enforces a maximum of six TCP connections per host. If you are requesting twelve items at once, the first six will begin and the last half will be queued. Once one of the original half is finished, the first item in the queue will begin its request process.
This would bring more delay when sending more requests.
On http/1.1 connections, chrome would reuse TCP connection by default and you can find
Connection: keep-alive
in the response headers. But according to docs in mdn
This connection will not stay open forever: idle connections are closed after some time (a server may use the Keep-Alive header to specify a minimum time the connection should be kept open).
And for http/2.0, according to developers.google.com
all http/2.0 connections are persistent, and only one connection per origin is required, which offers numerous performance benefits.