Content deleted Content added
→Implementations: mention removal for nginx |
remove hat notes (issues seem addressed since the given dates) |
||
(18 intermediate revisions by 15 users not shown) | |||
Line 1:
{{Short description
{{use dmy dates|date=April 2022|cs1-dates=y}}
}}▼
'''HTTP/2 Server Push''' is an optional<ref>{{Cite journal |date=May 2015 |title=Hypertext Transfer Protocol Version 2 (HTTP/2) |doi=10.17487/RFC7540 |url=https://www.rfc-editor.org/rfc/rfc7540
HTTP/2 Server Push is not a notification mechanism from server to client. Instead, pushed resources are used by the client when it may have otherwise produced a request to get the resource anyway.<ref>{{Cite web |title=HTTP/2 server configurations |url=https://http2.co/http2-with-apache/ |url-status=live |archive-url=https://web.archive.org/web/20220327085843/https://http2.co/http2-with-apache/ |archive-date=2022-03-27 |access-date=2019-03-30 |website=HTTP/2 Space |language=en-US}}</ref><ref>{{cite IETF |title=Hypertext Transfer Protocol Version 2 (HTTP/2) |rfc=7540 |section=8.2 |sectionname=Server Push |page=60 |date=May 2015 |publisher=[[Internet Engineering Task Force]] |access-date=2015-05-06 |language=en-US |archive-url=https://web.archive.org/web/20220404104429/https://datatracker.ietf.org/doc/html/rfc7540 |archive-date=2022-04-04 |url-status=live}}</ref>
==
On May 14, 2015, HTTP/2 was standardized by {{IETF RFC|7540}}, ratified as a Proposed Standard. The document includes section 8.2 entitled "Server Push" which introduced the concept to the protocol as an optional extension. [[Google Chrome]] 40 became the first browser supporting the final standardized HTTP/2 version, including the optional Server Push.<ref>{{Cite web |last= |first= |date=2015-02-10 |title=Google announces SPDY's coming demise as HTTP/2 approaches |url=https://arstechnica.com/information-technology/2015/02/google-announces-spdys-coming-demise-as-http2-approaches/ |access-date=2023-07-30 |website=Ars Technica |language=en-us}}</ref>
In February 2018, [[Nginx]] 1.13.9 was released with optional support for HTTP/2 Server Push.<ref name=":1" />
In November 2020, [[Google]] announced its intent to remove Server Push from Google Chrome implementation of HTTP/2 and [[QUIC|gQUIC]] (which later evolved into HTTP/3).<ref>{{Cite web |last=Lassey |first=Brad |date=2020-11-12 |title=Intent to Remove: HTTP/2 and gQUIC server push |url=https://groups.google.com/a/chromium.org/g/blink-dev/c/K3rYLvmQUBY/m/vOWBKZGoAQAJ |access-date=2023-11-20 |website=Blink mailing list}}</ref>
In October 2022, Google announced their intent to remove Server Push from Google Chrome, citing the poor performance of the extension in practice, lack of use and better alternatives. Chrome 106 became the first release disabling Server Push by default.<ref name=":2">{{Cite web |date=2022-08-18 |title=Removing HTTP/2 Server Push from Chrome |url=https://developer.chrome.com/blog/removing-push/ |access-date=2023-07-30 |website=Chrome Developers |language=en}}</ref>
On October 29, 2024, [[Mozilla Corporation|Mozilla]] released [[Firefox]] 132, which removed HTTP/2 Server Push support due to "compatibility issues with various sites".<ref>{{Cite web |title=Firefox 132.0, See All New Features, Updates and Fixes |url=https://www.mozilla.org/en-US/firefox/132.0/releasenotes/ |access-date=2024-10-29 |website=Mozilla |language=en}}</ref>
== Protocol ==
Unlike [[HTTP|HTTP/1.1]], HTTP/2 can multiplex multiple streams on one TCP connection. Server Push allows the server to open new streams by sending PUSH_PROMISE frames, in order to send the client resources it expects will be needed. A PUSH_PROMISE frame is similar to a GET request, but sent by the server. A client may choose to reject the push by sending an RST_STREAM frame, for example, if it already has the resource cached; if it does not, it will store the pushed data in a cache associated with the connection which will be consulted before a request is sent down that connection. Clients can also request that servers not send server pushes using a SETTINGS frame. The specification itself does not specify how servers choose what to push: a web server might send pushes to clients only on their first visit, to avoid redundantly sending cached resources.<ref>{{Cite web |date=2022-03-17 |title=HTTP/1.1 vs HTTP/2: What's the Difference? |url=https://www.digitalocean.com/community/tutorials/http-1-1-vs-http-2-what-s-the-difference |access-date=2023-11-20 |website=DigitalOcean |language=en}}</ref><ref>{{Cite web |date=2018-02-20 |title=Introducing HTTP/2 Server Push with NGINX 1.13.9 |url=https://www.nginx.com/blog/nginx-1-13-9-http2-server-push/ |access-date=2023-11-20 |website=Nginx |language=en}}</ref><ref>{{Cite web |date=2016-04-28 |title=Announcing Support for HTTP/2 Server Push |url=https://blog.cloudflare.com/announcing-support-for-http-2-server-push-2/ |access-date=2023-11-20}}</ref>
== Implementations ==
{| class="wikitable"
HTTP/2 Server push was implemented in the [[Nginx]] web server in version 1.13.9 in February 2018.<ref>{{Cite web |date=2018-12-04 |title=Changes with nginx 1.14.2 |url=https://nginx.org/en/CHANGES-1.14 |url-status=live |archive-url=https://web.archive.org/web/20220407053209/https://nginx.org/en/CHANGES-1.14 |archive-date=2022-04-07 |website=[[Nginx]] |language=en-US}}</ref> Support was removed in version 1.25.1 in June 2023.▼
|+
!Software
!
!First supporting version
!Last supporting version
|-
|[[Nginx]]
|Server
▲
|1.25.1 (June 2023)<ref>{{Cite web |date=13 June 2023 |title=Changes with nginx 1.25.1 |url=https://nginx.org/en/CHANGES |access-date=12 July 2023 |website=[[Nginx]]}}</ref>
|-
|[[LiteSpeed Web Server|LiteSpeed]]
|Server
|5.2
|Still supported, but deprecated<ref>{{Cite web |title=Page Optimization |url=https://docs.litespeedtech.com/lscache/lscwp/pageopt/#css-http2-push |access-date=2023-07-21 |website=LiteSpeed Documentation}}</ref>{{Better source needed|reason=This is a primary source, no clear mention of deprecation/removal timeline ([[WP:NOTRS]]).|date=July 2023}}
|-
|[[Google Chrome]]
|Client
|40 (May 2015)
|106 (September 2022)<ref name=":0" /><ref name=":2" /><ref>{{Cite web |date=2022-10-31 |title=Remove HTTP/2 push |url=https://chromestatus.com/feature/6302414934114304 |access-date=2023-07-12 |website=chromestatus.com}}</ref>
|-
|[[Firefox]]
|Client
|?
|131.0 Beta 9<ref>{{Cite web |title=Intent to unship: HTTP/2 Push |url=https://groups.google.com/a/mozilla.org/g/dev-platform/c/vU9hJg343U8/m/4cZsHz7TAQAJ |access-date=2024-09-06 |website=groups.google.com}}</ref><ref>{{Cite web |title=Firefox Beta 132.0beta, See All New Features, Updates and Fixes |url=https://www.mozilla.org/en-US/firefox/132.0beta/releasenotes/?utm_source=firefox-browser&utm_medium=firefox-desktop&utm_campaign=about-dialog |access-date=2024-10-01 |website=Mozilla |language=en}}</ref>
== References ==
|