Re: Вопросы по http2 push
Ruslan Ermilov
ru на nginx.com
Вт Фев 27 14:32:39 UTC 2018
On Tue, Feb 27, 2018 at 10:17:07AM +0300, Nick Lavlinsky - Method Lab wrote:
> Здравствуйте!
>
> Начал тестировать http2_push сразу после релиза. Появилось 2 вопроса.
>
> 1. Есть ли возможность пушить ресурсы до ответа на основной запрос (так
> делает у себя Fastly, называя async push)? Таким образом можно получить
> экономию не только в 1RTT, но и за счет серверного времени на генерацию
> html (https://www.fastly.com/blog/optimizing-http2-server-push-fastly).
Нет, сейчас такой возможности нет и вряд ли она появится.
Сейчас nginx дожидается заголовка ответа на основной запрос,
прежде чем отправить PUSH_PROMISE'ы и собственно начать пушить
ответы. Причин тому несколько. Во-первых, это единственный
способ при конвертации Link preload'ов в push'и. Во-вторых,
если так не делать, и ответа на основной запрос нет (например,
бэкенд неживой), то непонятно, на каком основании вообще мы
должны делать push.
> 2. При использовании директивы http2_push в конфиге сайта браузеры
> (Chrome Stable и 66, FF 58.0.2) показывают, что только 1 ресурс был
> запушен, хотя стоят сразу несколько (смотрю в DevTools с отключенным
> кэшем). Например:
>
> location / {
> proxy_pass http://127.0.0.1:9090/pcgi/index.pl?$uri?&$args;
> proxy_redirect off;
>
> proxy_set_header Host $host;
> proxy_set_header X-Real-IP $remote_addr;
> proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
>
> http2_push /css/colorbox.css;
> http2_push /img/design/logo.png;
> http2_push /js/core.js;
> http2_push /images/border.png;
> http2_push /img/no_foto.png;
> http2_push /js/jq/jquery-2.1.3.min.js;
>
> }
>
> В браузерах отображается в виде push только /img/design/logo.png, так
> как этот ресурс используется на странице (остальные - нет). Поведение
> одинаково и в Chrome и в FF.
>
> Если делать push через заголовок Link (http2_push_preload on;), то в
> Chrome все ресурсы показываются в DevTools.
При этом внизу выдаётся warning, что некоторые ресурсы не используются.
> В FF показываются только те
> ресурсы, которые используются на странице.
>
> При анализе загрузки ресурсов через nghttp -ans или Webpagetest всегда
> (и в http2_push, и в http2_push_preload) видны все push запросы.
>
> Не знаю, бага это или фича, может будет полезно.
В chrome://net-internals/#http2 видно, что они push'атся. Почему
так по-разному показывает DevTools, я лично не знаю. Но это точно
не вопрос к nginx'у.
Подробная информация о списке рассылки nginx-ru