003 File Manager
Current Path:
/usr/local/share/doc/apache24/howto
usr
/
local
/
share
/
doc
/
apache24
/
howto
/
đ
..
đ
access.html
(289 B)
đ
access.html.en
(13.48 KB)
đ
access.html.es
(14.67 KB)
đ
access.html.fr.utf8
(14.67 KB)
đ
auth.html
(538 B)
đ
auth.html.en
(36.79 KB)
đ
auth.html.es
(43.08 KB)
đ
auth.html.fr.utf8
(39.8 KB)
đ
auth.html.ja.utf8
(44.12 KB)
đ
auth.html.ko.euc-kr
(20.56 KB)
đ
auth.html.tr.utf8
(38.35 KB)
đ
cgi.html
(449 B)
đ
cgi.html.en
(30.3 KB)
đ
cgi.html.es
(35.69 KB)
đ
cgi.html.fr.utf8
(34.22 KB)
đ
cgi.html.ja.utf8
(35.95 KB)
đ
cgi.html.ko.euc-kr
(25.81 KB)
đ
htaccess.html
(568 B)
đ
htaccess.html.en
(27.4 KB)
đ
htaccess.html.es
(29.59 KB)
đ
htaccess.html.fr.utf8
(30.3 KB)
đ
htaccess.html.ja.utf8
(28.22 KB)
đ
htaccess.html.ko.euc-kr
(20.17 KB)
đ
htaccess.html.pt-br
(25.49 KB)
đ
http2.html
(286 B)
đ
http2.html.en
(25.65 KB)
đ
http2.html.es
(28.66 KB)
đ
http2.html.fr.utf8
(29.4 KB)
đ
index.html
(550 B)
đ
index.html.en
(8.42 KB)
đ
index.html.es
(8.14 KB)
đ
index.html.fr.utf8
(8.88 KB)
đ
index.html.ja.utf8
(7.81 KB)
đ
index.html.ko.euc-kr
(6.29 KB)
đ
index.html.zh-cn.utf8
(6.47 KB)
đ
public_html.html
(580 B)
đ
public_html.html.en
(13.34 KB)
đ
public_html.html.es
(14.16 KB)
đ
public_html.html.fr.utf8
(14.29 KB)
đ
public_html.html.ja.utf8
(15.03 KB)
đ
public_html.html.ko.euc-kr
(11.2 KB)
đ
public_html.html.tr.utf8
(14.29 KB)
đ
reverse_proxy.html
(217 B)
đ
reverse_proxy.html.en
(20.09 KB)
đ
reverse_proxy.html.fr.utf8
(21.91 KB)
đ
ssi.html
(449 B)
đ
ssi.html.en
(25.57 KB)
đ
ssi.html.es
(27.52 KB)
đ
ssi.html.fr.utf8
(27.68 KB)
đ
ssi.html.ja.utf8
(30.59 KB)
đ
ssi.html.ko.euc-kr
(22.29 KB)
Editing: http2.html.fr.utf8
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr"><head> <meta content="text/html; charset=UTF-8" http-equiv="Content-Type" /> <!-- XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX This file is generated from xml source: DO NOT EDIT XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX --> <title>Guide HTTP/2 - Serveur HTTP Apache Version 2.4</title> <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" /> <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" /> <link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /><link rel="stylesheet" type="text/css" href="../style/css/prettify.css" /> <script src="../style/scripts/prettify.min.js" type="text/javascript"> </script> <link href="../images/favicon.ico" rel="shortcut icon" /></head> <body id="manual-page"><div id="page-header"> <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p> <p class="apache">Serveur HTTP Apache Version 2.4</p> <img alt="" src="../images/feather.png" /></div> <div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div> <div id="path"> <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">Serveur HTTP</a> > <a href="http://httpd.apache.org/docs/">Documentation</a> > <a href="../">Version 2.4</a> > <a href="./">How-To / Tutoriels</a></div><div id="page-content"><div id="preamble"><h1>Guide HTTP/2</h1> <div class="toplang"> <p><span>Langues Disponibles: </span><a href="../en/howto/http2.html" hreflang="en" rel="alternate" title="English"> en </a> | <a href="../es/howto/http2.html" hreflang="es" rel="alternate" title="Español"> es </a> | <a href="../fr/howto/http2.html" title="Français"> fr </a></p> </div> <p>Ce document est le guide de l'utilisateur de l'implĂ©mentation de HTTP/2 dans Apache httpd. Cette fonctionnalitĂ© en est au stade <em>de production</em>, et les interfaces et directives devraient donc ĂȘtre dorĂ©navant relativement stables. </p> </div> <div id="quickview"><a href="https://www.apache.org/foundation/contributing.html" class="badge"><img src="https://www.apache.org/images/SupportApache-small.png" alt="Support Apache!" /></a><ul id="toc"><li><img alt="" src="../images/down.gif" /> <a href="#protocol">Le protocole HTTP/2</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#implementation">HTTP/2 dans Apache httpd</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#building">Compilation de httpd avec le support de HTTP/2</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#basic-config">Configuration de base</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#mpm-config">Configuration du MPM</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#clients">Clients</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#tools">Outils efficaces pour dĂ©boguer HTTP/2</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#push">Push serveur</a></li> <li><img alt="" src="../images/down.gif" /> <a href="#earlyhints">Suggestions prĂ©coces</a></li> </ul><h3>Voir aussi</h3><ul class="seealso"><li><code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code></li><li><a href="#comments_section">Commentaires</a></li></ul></div> <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="protocol" id="protocol">Le protocole HTTP/2</a></h2> <p>HTTP/2 est une Ă©volution du protocole de la couche application le plus utilisĂ© au monde, HTTP. Cette Ă©volution permet en particulier une utilisation plus efficace des ressources rĂ©seau. Il ne modifie pas les aspects fondamentaux de HTTP (sa sĂ©mantique). Entre autres, il y a toujours des requĂȘtes, des rĂ©ponses et des en-tĂȘtes. Par consĂ©quent, si vous connaissez HTTP/1, vous connaissez dĂ©jĂ 95% de HTTP/2.</p> <p>Beaucoup a dĂ©jĂ Ă©tĂ© Ă©crit Ă propos de HTTP/2 et de son fonctionnement. La documentation la plus officielle est bien entendu sa <a href="https://tools.ietf.org/html/rfc7540">RFC 7540</a> (ou <a href="http://httpwg.org/specs/rfc7540.html">cette version au format plus lisible</a>). Vous trouverez ici une description des rouages de HTTP/2 dans leurs moindres dĂ©tails.</p> <p>Le premier document Ă lire lorsqu'on ne connaĂźt pas un mĂ©canisme n'est cependant pas sa RFC. Il est prĂ©fĂ©rable de comprendre tout d'abord <em>ce que</em> ce mĂ©canisme est censĂ© faire, et seulement ensuite de lire sa RFC pour comprendre <em>comment</em> il fonctionne. <a href="https://daniel.haxx.se/http2/">http2 explained</a> de Daniel Stenberg (l'auteur de <a href="https://curl.haxx.se">curl</a>) est un bien meilleur document pour dĂ©marrer l'Ă©tude de HTTP/2. En outre, de nouveaux langages s'ajoutent rĂ©guliĂšrement Ă sa liste de traductions disponibles !</p> <p>Si vous n'avez pas envie de le lire parce que vous le trouvez trop long, voici certains piĂšges Ă Ă©viter et nouveaux termes Ă connaĂźtre avant de lire ce document :</p> <ul> <li>A la diffĂ©rence de HTTP/1 qui est en texte pur, HTTP/2 est un <strong>protocole binaire</strong>, et alors que le premier est lisible par un humain (par exemple pour sniffer le trafic rĂ©seau), le second ne l'est pas. Voir la <a href="https://http2.github.io/faq/#why-is-http2-binary">FAQ officielle</a> pour plus de dĂ©tails.</li> <li><strong>h2</strong> correspond Ă HTTP/2 sur TLS (nĂ©gociation de protocole via ALPN).</li> <li><strong>h2c</strong> correspond Ă HTTP/2 sur TCP.</li> <li>Une <strong>frame</strong> ou trame est la plus petite unitĂ© de communication au sein d'une connexion HTTP/2 et comporte une en-tĂȘte et une sĂ©quence d'octets de longueur variable dont la structure correspond au type de trame. Voir la <a href="http://httpwg.org/specs/rfc7540.html#FramingLayer">section correspondante</a> de la documentation officielle pour plus de dĂ©tails.</li> <li>Un <strong>stream</strong> est un flux bidirectionnel de frames au sein d'une connexion HTTP/2. La notion correspondante dans HTTP/1 est un Ă©change de messages de type requĂȘte et rĂ©ponse. Voir la <a href="http://httpwg.org/specs/rfc7540.html#StreamsLayer">section correspondante</a> de la documentation officielle pour plus de dĂ©tails.</li> <li>HTTP/2 peut gĂ©rer <strong>plusieurs streams</strong> de donnĂ©es sur la mĂȘme connexion TCP, ce qui permet d'Ă©viter le point de blocage classique de HTTP/1 pour les requĂȘtes lentes, et de ne pas avoir Ă ouvrir de nouvelles connexions TCP pour chaque requĂȘte/rĂ©ponse (les connexions persistantes ou KeepAlive avaient contournĂ© le problĂšme dans HTTP/1 mais ne l'avaient pas entiĂšrement rĂ©solu)</li> </ul> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="implementation" id="implementation">HTTP/2 dans Apache httpd</a></h2> <p>Le protocole HTTP/2 est implĂ©mentĂ© dans Apache httpd via un module propre, pertinemment nommĂ© <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code>. Ce module implĂ©mente toutes les fonctionnalitĂ©s dĂ©crites par la RFC 7540 et supporte les connexions en texte pur (http:), ou sĂ©curisĂ©es (https:). La variante texte pur se nomme '<code>h2c</code>', et la variante sĂ©curisĂ©e '<code>h2</code>'. <code>h2c</code> peut ĂȘtre en mode <em>direct</em> ou <code>Upgrade:</code> via une requĂȘte initiale en HTTP/1.</p> <p><a href="#push">Server Push</a> est une nouvelle fonctionnalitĂ© offerte aux dĂ©veloppeurs web par HTTP/2. La section correspondante de ce document vous indiquera comment votre application peut en tirer parti.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="building" id="building">Compilation de httpd avec le support de HTTP/2</a></h2> <p><code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> se base sur la bibliothĂšque de <a href="https://nghttp2.org">nghttp2</a> pour son implĂ©mentation. Pour pouvoir compiler <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code>, <code>libnghttp2</code> version 1.2.1. ou supĂ©rieure doit ĂȘtre installĂ©e dans votre systĂšme.</p> <p>Pour dĂ©clencher la compilation de <code>mod_http2</code>, vous devez ajouter l'argument '<code>--enable-http2</code>' au script <code>./configure</code> que vous exĂ©cutez Ă la racine de l'arborescence des sources de httpd. Si <code>libnghttp2</code> est installĂ©e dans un rĂ©pertoire non connu du chemin de vos bibliothĂšques, vous devez indiquer ce rĂ©pertoire au script <code>./configure</code> via l'argument '<code>--with-nghttp2=<path></code>'.</p> <p>Alors que cette mĂ©thode de compilation conviendra Ă la plupart, certains prĂ©fĂ©reront lier statiquement <code>nghttp2</code> Ă ce module. Pour ce faire, utilisez l'argument <code>--enable-nghttp2-staticlib-deps</code>. Cette mĂ©thode est pratiquement la mĂȘme que celle utilisĂ©e pour lier statiquement openssl Ă <code class="module"><a href="../mod/mod_ssl.html">mod_ssl</a></code>.</p> <p>En parlant de SSL, vous devez savoir que la plupart des navigateurs ne communiqueront en HTTP/2 que sur des URLs sĂ©curisĂ©es de type <code>https:</code> ; votre serveur doit donc supporter SSL. Mais de plus, votre bibliothĂšque SSL devra supporter l'extension <code>ALPN</code>. Enfin, si la bibliothĂšque que vous utilisez est OpenSSL, sa version devra ĂȘtre 1.0.2. ou supĂ©rieure.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="basic-config" id="basic-config">Configuration de base</a></h2> <p>Maintenant que vous disposez d'un binaire <code>httpd</code> compilĂ© avec le module <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code>, l'activation de ce dernier nĂ©cessite un minimum de configuration supplĂ©mentaire. En premier lieu, comme pour tout module Apache, vous devez le charger :</p> <pre class="prettyprint lang-config">LoadModule http2_module modules/mod_http2.so</pre> <p>La seconde directive que vous devez ajouter Ă votre fichier de configuration est</p> <pre class="prettyprint lang-config">Protocols h2 http/1.1</pre> <p>Ceci permet de dĂ©finir h2, la variante sĂ©curisĂ©e, comme le protocole prĂ©fĂ©rĂ© pour les connexions Ă votre serveur. Si vous souhaitez que toutes les variantes soient disponibles, utilisez la directive suivante :</p> <pre class="prettyprint lang-config">Protocols h2 h2c http/1.1</pre> <p>Selon l'endroit oĂč vous placez cette directive, elle affectera l'ensemble de votre serveur, ou seulement un ou plusieurs serveurs virtuels. Vous pouvez aussi l'imbriquer comme dans l'exemple suivant :</p> <pre class="prettyprint lang-config">Protocols http/1.1 <VirtualHost ...> ServerName test.example.org Protocols h2 http/1.1 </VirtualHost></pre> <p>Seules les connexions en HTTP/1 seront alors permises, sauf pour le serveur virtuel <code>test.example.org</code> qui acceptera aussi les connexions SSL en HTTP/2.</p> <div class="note"><h3>Utilisez une chaĂźne d'algorithmes de chiffrement forte</h3> <p>La directive <code class="directive"><a href="../mod/mod_ssl.html#sslciphersuite">SSLCipherSuite</a></code> doit ĂȘtre dĂ©finie avec une chaĂźne d'algorithmes de chiffrement TLS forte. MĂȘme si la version actuelle de <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> n'impose pas d'algorithmes de chiffrement particuliers, la plupart des clients le font. Faire pointer un navigateur vers un serveur oĂč <code>h2</code> est activĂ© avec une chaĂźne d'algorithmes de chiffrement inappropriĂ©e entraĂźnera un rejet et une retrogradation vers HTTP 1.1. C'est une erreur que l'on fait couramment lorsqu'on configure httpd pour HTTP/2 pour la premiĂšre fois ; donc gardez la Ă l'esprit si vous voulez Ă©viter de longues sessions de dĂ©bogage ! Si vous voulez ĂȘtre sĂ»r de dĂ©finir une chaĂźne d'algorithmes de chiffrement appropriĂ©e, Ă©vitez ceux qui sont listĂ©s dans la <a href="http://httpwg.org/specs/rfc7540.html#BadCipherSuites"> </a>liste des algorithmes de chiffrement TLS HTTP/2 Ă proscrire.</p> </div> <p>L'ordre des protocoles indiquĂ©s est aussi important. Par dĂ©faut, le premier sera le protocole prĂ©fĂ©rĂ©. Lorsqu'un client offre plusieurs choix, c'est le plus Ă gauche qui sera sĂ©lectionnĂ©. Dans</p> <pre class="prettyprint lang-config">Protocols http/1.1 h2</pre> <p>le protocole prĂ©fĂ©rĂ© sera HTTP/1 et il sera toujours sĂ©lectionnĂ© sauf si un client ne supporte <em>que</em> h2. Comme nous souhaitons communiquer en HTTP/2 avec les clients qui le supportent, la meilleure dĂ©finition de la directive est</p> <pre class="prettyprint lang-config">Protocols h2 h2c http/1.1</pre> <p>Toujours Ă propos de l'ordre des protocoles, le client a lui aussi ses propres prĂ©fĂ©rences en la matiĂšre. Ă ce titre, si vous le souhaitez, vous pouvez configurer votre serveur pour qu'il sĂ©lectionne non plus son protocole prĂ©fĂ©rĂ©, mais au contraire le protocole prĂ©fĂ©rĂ© du client :</p> <pre class="prettyprint lang-config">ProtocolsHonorOrder Off</pre> <p>Avec cette directive, l'ordre des protocoles que <em>vous</em> avez dĂ©fini devient caduque et seul l'ordre dĂ©fini par le client sera pris en compte.</p> <p>Une derniĂšre chose : les protocoles que vous dĂ©finissez ne sont pas vĂ©rifiĂ©s quant Ă leurs validitĂ© ou orthographe. Vous pouvez trĂšs bien dĂ©finir des protocoles qui n'existent pas, et il n'est donc pas nĂ©cessaire de filtrer le contenu de la directive <code class="directive"><a href="../mod/core.html#protocols">Protocols</a></code> avec des vĂ©rifications de type <code class="directive"><a href="../mod/core.html#ifmodule"><IfModule></a></code>.</p> <p>Pour des conseils plus avancĂ©s Ă propos de la configuration, voir la <a href="../mod/mod_http2.html">Documentation de mod_http2</a>, et en particulier la section Ă propos de la <a href="../mod/mod_http2.html#dimensioning">consommation supplĂ©mentaire de ressources</a>, ainsi que la section expliquant comment gĂ©rer les <a href="../mod/mod_http2.html#misdirected">serveurs multiples avec certificat commun</a>.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="mpm-config" id="mpm-config">Configuration du MPM</a></h2> <p>Tous les modules multiprocessus (MPM) fournis avec httpd supportent HTTP/2. Cependant, si vous utilisez le MPM <code class="module"><a href="../mod/prefork.html">prefork</a></code>, vous allez faire face Ă de sĂ©vĂšres restrictions.</p> <p>Avec le MPM <code class="module"><a href="../mod/prefork.html">prefork</a></code>, <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> ne traitera qu'une requĂȘte Ă la fois par connexion alors que les clients tels que les navigateurs internet envoient de nombreuses requĂȘtes au mĂȘme moment. Si l'une d'entre elles est longue Ă traiter (ou implique une longue interrogation), les autres requĂȘtes seront mises en attente.</p> <p>Par dĂ©faut, <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> ne passe pas outre cette limitation pour la simple et bonne raison que le MPM <code class="module"><a href="../mod/prefork.html">prefork</a></code> n'est aujourd'hui choisi que si vous exĂ©cutez des moteurs de traitement qui ne sont pas prĂ©parĂ©s pour le multithreading (par exemple qui se crashent lorsque plusieurs requĂȘtes arrivent).</p> <p>Si votre plateforme et votre installation de httpd le supportent, la meilleur solution consiste actuellement Ă utiliser le MPM <code class="module"><a href="../mod/event.html">event</a></code>. </p> <p>Si vous n'avez pas d'autre choix que d'utiliser le MPM <code class="module"><a href="../mod/prefork.html">prefork</a></code>, mais souhaitez tout de mĂȘme traiter plusieurs requĂȘtes simultanĂ©ment, vous pouvez jouer avec la directive <code class="directive"><a href="../mod/mod_http2.html#h2minworkers">H2MinWorkers</a></code>, sans garantie que cela fonctionne.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="clients" id="clients">Clients</a></h2> <p>La plupart des navigateurs modernes supportent HTTP/2, mais seulement sur des connexions SSL : Firefox v43, Chrome v45, Safari v9, iOS Safari v9, Opera v35, Chrome pour Android v49 et Internet Explorer v11 sous Windows10 (selon cette <a href="http://caniuse.com/#search=http2">source</a>).</p> <p>D'autres clients et serveurs sont listĂ©s dans le <a href="https://github.com/http2/http2-spec/wiki/Implementations">wiki des implĂ©mentations</a> ; entre autres des implĂ©mentations pour c, c++, common lisp, dart, erlang, haskell, java, nodejs, php, python, perl, ruby, rust, scala et swift.</p> <p>De nombreuses implĂ©mentations clientes autres que les navigateurs supportent HTTP/2 en texte pur, h2c. L'une des plus efficaces d'entre elles est <a href="https://curl.haxx.se">curl</a>.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="tools" id="tools">Outils efficaces pour dĂ©boguer HTTP/2</a></h2> <p>Le premier d'entre eux est bien entendu <a href="https://curl.haxx.se">curl</a>. Assurez-vous au prĂ©alable que votre version supporte HTTP/2 en vĂ©rifiant ses <code>FonctionnalitĂ©s</code> :</p> <pre class="prettyprint lang-config"> $ curl -V curl 7.45.0 (x86_64-apple-darwin15.0.0) libcurl/7.45.0 OpenSSL/1.0.2d zlib/1.2.8 nghttp2/1.3.4 Protocols: dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 [...] Features: IPv6 Largefile NTLM NTLM_WB SSL libz TLS-SRP <strong>HTTP2</strong> </pre> <div class="note"><h3>homebrew sous Mac OS :</h3> brew install curl --with-openssl --with-nghttp2 </div> <p>Pour une inspection en profondeur : <a href="https://wiki.wireshark.org/HTTP2">wireshark</a>.</p> <p>Le paquet <a href="https://nghttp2.org">nghttp2</a> inclut aussi des outils comme :</p> <ul> <li><a href="https://nghttp2.org/documentation/nghttp.1.html">nghttp</a> - permet de visualiser les trames HTTP/2 et ainsi de se faire une meilleure idĂ©e du protocole.</li> <li><a href="https://nghttp2.org/documentation/h2load-howto.html">h2load</a> - permet de tester votre serveur dans des conditions extremes.</li> </ul> <p>Chrome fournit des journaux dĂ©taillĂ©s des connexions HTTP/2 via la page <a href="chrome://net-internals/#http2">special net-internals page</a>. Il y a aussi cette extension intĂ©ressante pour <a href="https://chrome.google.com/webstore/detail/http2-and-spdy-indicator/mpbpobfflnpcgagjijhmgnchggcjblin?hl=en">Chrome</a> et <a href="https://addons.mozilla.org/en-us/firefox/addon/spdy-indicator/">Firefox</a> qui permet d'indiquer que votre navigateur utilise HTTP/2.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="push" id="push">Push serveur</a></h2> <p>Le protocole HTTP/2 permet au serveur de proposer (PUSH) des rĂ©ponses pour lesquelles le client n'a rien demandĂ©. La communication autour de ces rĂ©ponses est du style : "voici une requĂȘte que vous n'avez jamais envoyĂ©e, et la rĂ©ponse vous parviendra bientĂŽt tout de mĂȘme ..."</p> <p>Il y a cependant des conditions : le client peut dĂ©sactiver cette fonctionnalitĂ© et le serveur ne pourra alors lui proposer des rĂ©ponses que pour les requĂȘtes qu'il a effectivement envoyĂ©es.</p> <p>Cette fonctionnalitĂ© a pour but de permettre au serveur d'envoyer au client des ressources dont il va probablement avoir besoin : par exemple une ressource css ou javascript appartenant Ă une page html que le client a demandĂ©e, un jeu d'images rĂ©fĂ©rencĂ© par un css, etc...</p> <p>Cette anticipation a pour avantage de permettre au client d'Ă©conomiser le temps qu'il lui aurait fallu pour envoyer une requĂȘte, quelques millisecondes Ă une demi-seconde en fonction de l'Ă©loignement du serveur. Elle a cependant pour inconvĂ©nient d'imposer au client le tĂ©lĂ©chargement de ressources qu'il possĂšde peut-ĂȘtre dĂ©jĂ dans son cache. Bien entendu, HTTP/2 permet d'annuler prĂ©maturĂ©ment de telles requĂȘtes, mais des ressources sont tout de mĂȘme gaspillĂ©es.</p> <p>En rĂ©sumĂ© : il n'existe pas encore de stratĂ©gie efficace pour faire le meilleur usage de cette fonctionnalitĂ© de HTTP/2 et tout le monde en est encore au stade de l'expĂ©rimentation. Ă ce titre, voici des conseils pour procĂ©der vous-mĂȘme Ă ces expĂ©rimentations :</p> <p><code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> inspecte l'en-tĂȘte de la rĂ©ponse et recherche les en-tĂȘtes <code>Link</code> sous un certain format :</p> <pre class="prettyprint lang-config">Link </xxx.css>;rel=preload, </xxx.js>; rel=preload</pre> <p>Si la connexion supporte PUSH, ces deux ressources seront envoyĂ©es au client. En tant que dĂ©veloppeur web vous pouvez dĂ©finir ces en-tĂȘtes soit directement au niveau de la rĂ©ponse de votre application, soit en configurant votre serveur via</p> <pre class="prettyprint lang-config"><Location /xxx.html> Header add Link "</xxx.css>;rel=preload" Header add Link "</xxx.js>;rel=preload" </Location></pre> <p>Si vous souhaitez utiliser des liens <code>preload</code> sans dĂ©clencher de PUSH, vous pouvez utiliser le paramĂštre <code>nopush</code> comme suit :</p> <pre class="prettyprint lang-config">Link </xxx.css>;rel=preload;nopush</pre> <p>Vous pouvez aussi dĂ©sactiver les PUSHes pour l'ensemble de votre serveur via la directive</p> <pre class="prettyprint lang-config">H2Push Off</pre> <p>Ă savoir aussi :</p> <p>Le module maintient un journal des ressources ayant fait l'objet d'un PUSH pour chaque connexion (en gĂ©nĂ©ral des condensĂ©s hash des URLs), et n'effectuera pas deux fois un PUSH pour la mĂȘme ressource. Cependant, lorsque la connexion est fermĂ©e, le journal de ses PUSHes est supprimĂ©.</p> <p>Certains dĂ©veloppeurs planchent sur la maniĂšre de permettre au client d'informer le serveur des ressources qu'il possĂšde dĂ©jĂ dans son cache afin d'Ă©viter les PUSHes pour ces derniĂšres, mais ceci n'en est actuellement qu'Ă un stade trĂšs expĂ©rimental.</p> <p>L'<a href="https://tools.ietf.org/html/draft-ruellan-http-accept-push-policy-00"> en-tĂȘte Accept-Push-Policy</a> est un autre dispositif expĂ©rimental implĂ©mentĂ© dans <code class="module"><a href="../mod/mod_http2.html">mod_http2</a></code> ; il permet au client de dĂ©finir pour chaque requĂȘte quels genres de PUSHes il accepte.</p> <p> La fonctionnalitĂ© PUSH n'apportera pas toujours le gain de performances dans l'obtention de rĂ©ponses aux requĂȘtes. Vous trouverez plusieurs Ă©tudes sur ce sujet sur internet qui en expliquent les avantages et inconvĂ©nients et comment les particularitĂ©s des clients et du rĂ©seau en influencent le fonctionnement. Par exemple, le seul fait que le serveur PUSHes une ressource n'implique pas forcĂ©ment que le navigateur l'utilisera.</p> <p>Ce qui influence le plus la rĂ©ponse PUSHed, c'est la requĂȘte qui a Ă©tĂ© simulĂ©e. En effet, l'URL de la requĂȘte pour un PUSH est fournie par l'application, mais d'oĂč viennent les en-tĂȘtes ? Par exemple, La requĂȘte PUSH requiert-elle un en-tĂȘte <code>accept-language</code> et si oui, quelle sera sa valeur ?</p> <p>httpd va consulter la requĂȘte originale (celle qui a dĂ©clenchĂ© le PUSH) et copier les en-tĂȘtes suivants vers la requĂȘte PUSH : <code>user-agent</code>, <code>accept</code>, <code>accept-encoding</code>, <code>accept-language</code> et <code>cache-control</code>.</p> <p>Tous les autres en-tĂȘtes sont ignorĂ©s. Les cookies eux non plus ne seront pas copiĂ©s. PUSHer des ressources qui requiĂšrent la prĂ©sence d'un cookie ne fonctionnera pas. Ceci peut ĂȘtre sujet Ă dĂ©bat, mais tant que ce ne sera pas clairement discutĂ© avec les navigateurs, restons prudents et Ă©vitons d'exposer les cookies lĂ oĂč ils ne sont pas censĂ©s ĂȘtre visibles.</p> </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> <div class="section"> <h2><a name="earlyhints" id="earlyhints">Suggestions prĂ©coces</a></h2> <p>A l'instar des ressources PUSHĂ©es, une autre mĂ©thode consiste Ă envoyer des en-tĂȘtes <code>Link</code> au client avant mĂȘme que la rĂ©ponse ne soit prĂȘte. Cette mĂ©thode utilise la fonctionnalitĂ© appelĂ©e "Suggestions prĂ©coces" (Early Hints) dĂ©crite dans la <a href="https://tools.ietf.org/html/rfc8297">RFC 8297</a>.</p> <p>Pour utiliser cette fonctionnalitĂ©, vous devez l'activer explicitement sur le serveur via :</p> <pre class="prettyprint lang-config">H2EarlyHints on</pre> <p>Elle n'est en effet pas activĂ©e par dĂ©faut car certains navigateurs anciens perdent pied avec de telles rĂ©ponses.</p> <p>Une fois cette fonctionnalitĂ© activĂ©e, vous pouvez utiliser la directive <code class="directive"><a href="../mod/mod_http2.html#h2pushresource">H2PushResource</a></code> pour dĂ©clencher les suggestions prĂ©coces et les PUSHes de ressources :</p> <pre class="prettyprint lang-config"><Location /xxx.html> H2PushResource /xxx.css H2PushResource /xxx.js </Location></pre> <p>Le serveur enverra alors au client une rĂ©ponse <code>"103 Early Hints"</code> dĂšs qu'il <em>commencera</em> Ă traiter la requĂȘte. Selon votre application web, cet envoi peut intervenir beaucoup plus tĂŽt que le moment oĂč les premiers en-tĂȘtes de rĂ©ponse auront Ă©tĂ© dĂ©terminĂ©s.</p> <p>Si <code class="directive"><a href="../mod/mod_http2.html#h2push">H2Push</a></code> est activĂ©, ceci dĂ©clenchera aussi le PUSH juste aprĂšs la rĂ©ponse 103. Mais si <code class="directive"><a href="../mod/mod_http2.html#h2push">H2Push</a></code> n'est pas activĂ©, la rĂ©ponse 103 sera quand-mĂȘme envoyĂ©e au client.</p> </div></div> <div class="bottomlang"> <p><span>Langues Disponibles: </span><a href="../en/howto/http2.html" hreflang="en" rel="alternate" title="English"> en </a> | <a href="../es/howto/http2.html" hreflang="es" rel="alternate" title="Español"> es </a> | <a href="../fr/howto/http2.html" title="Français"> fr </a></p> </div><div class="top"><a href="#page-header"><img src="../images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">Commentaires</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Libera.chat, or sent to our <a href="https://httpd.apache.org/lists.html">mailing lists</a>.</div> <script type="text/javascript"><!--//--><![CDATA[//><!-- var comments_shortname = 'httpd'; var comments_identifier = 'http://httpd.apache.org/docs/2.4/howto/http2.html'; (function(w, d) { if (w.location.hostname.toLowerCase() == "httpd.apache.org") { d.write('<div id="comments_thread"><\/div>'); var s = d.createElement('script'); s.type = 'text/javascript'; s.async = true; s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier; (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s); } else { d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>'); } })(window, document); //--><!]]></script></div><div id="footer"> <p class="apache">Copyright 2021 The Apache Software Foundation.<br />AutorisĂ© sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p> <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.html">Directives</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">Glossaire</a> | <a href="../sitemap.html">Plan du site</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!-- if (typeof(prettyPrint) !== 'undefined') { prettyPrint(); } //--><!]]></script> </body></html>
Upload File
Create Folder