HTTP: відмінності між версіями

[перевірена версія][неперевірена версія]
Вилучено вміст Додано вміст
Basio (обговорення | внесок)
Немає опису редагування
→‎HTTP/2: Виправлено переклад
Мітки: Редагування з мобільного пристрою Редагування через мобільну версію
Рядок 98:
* Застосування бінарного протоколу, що оперує передачею бінарних кадрів. Кожен кадр має заголовок з інформацією про тип, розмір, опції та ідентифікаторі потоку. Кадри з типом DATA використовуються для передачі даних, HEADERS — HTTP-заголовків, RST_STREAM — для дострокового переривання відправлення даних;
* Мультиплексування і розпаралелювання потоків в рамках одного TCP-з'єднання. Пакети різних потоків змішуються і, на відміну від конвеєрної передачі HTTP/1.1, не очікують закінчення відправлення запиту. Підтримка ефективної двобічної передачі даних. Можливість мультиплексування при зверненні до різних хостів, що дозволяє додатково прискорити одночасне завантаження веб-контенту з різних сайтів (у SPDY мультиплексування підтримується тільки для одного хоста);
* Можливість установкивстановлення пріоритетів і залежностей для потоків, що дозволяє виділити найважливіші потоки, які потрібно виконати в першу чергу, а також визначити залежність одного потоку від іншого;
* Стиснення HTTP-заголовків. У тому числі підтримується усунення дублікатів заголовків і Cookie, повторюваних для серії запитів до одного сайту. Допускається визначення окремих заголовків що не підлягають стисненню;
* Низька чутливість до затримок;
* Засоби для узгодження протоколу між клієнтом і сервером, що дозволяють вибрати HTTP/1.1, HTTP/2.0 і інші протоколи: сервер надає список підтримуваних протоколів, які може вибрати клієнт. Для шифрованих з'єднань параметри TLS узгоджуються за допомогою протоколу [[APLN]], при якому клієнт повідомляє список підтримуваних опцій, а сервер вибирає найоптимальніший для себе варіант;
* Забезпечення високого рівня сумісності з HTTP/1.1: збережені заголовки, схема [[URI]], коди стану і методи (GET, POST тощо). Забезпечена можливість створення проксі для доступу клієнтів HTTP/1.1 до серверів HTTP/2.0;
* Можливість установкивстановлення шифрованих ([[HTTPS]]) і не шифрованих з'єднань (HTTP). Шифрування здійснюється з використанням TLS 1.2 або новішої версії. Незважаючи на те, що специфікація допускаєдозволяє створення нешифрованих сполучень, розробники [[Firefox]] і [[Google Chrome]] мають намір забезпечити роботу HTTP/2.0 тільки поверх TLS;
* Підтримка технології Server push для передачі даних від сервера до клієнта (наприклад, коли сервер вважає, що після певного запиту обов'язково будуть затребувані інші дані, він може відправити ці дані не чекаючи фактичного запиту);
* Підтримка HTTP/2.0 на час пропозиції стандарту вже реалізована в браузерах [[Firefox]] 36+, Chrome (потрібна побудова з «--enable-spdy4») і IE 11. Серверні реалізації поки обмежуються [[OpenLiteSpeed]]​, H2O, nghttp2 і деякими бібліотеками на високорівневих мовах.