Параметр масштаба окна TCP - TCP window scale option

В Параметр масштаба окна TCP вариант увеличения окно приема размер разрешен в Протокол управления передачей выше своего прежнего максимального значения 65 535 байт. Этот параметр TCP, наряду с некоторыми другими, определен в IETF. RFC 1323 который имеет дело с длинные толстые сети (LFN).

TCP окна

Пропускная способность связи ограничена двумя окнами: окно скопления и окно приема. Окно перегрузки старается не превышать пропускную способность сети (контроль перегрузки ); окно приема пытается не превышать возможности получателя для обработки данных (управление потоком ). Получатель может быть перегружен данными, например, если он очень занят (например, веб-сервер). Каждый сегмент TCP содержит текущее значение окна приема. Если, например, отправитель получает подтверждение, которое подтверждает байт 4000 и указывает окно приема 10000 (байтов), отправитель не будет отправлять пакеты после байта 14000, даже если окно перегрузки позволяет это.

Теория

Параметр масштабирования окна TCP необходим для эффективной передачи данных, когда продукт задержки полосы пропускания (BDP) больше 64К. Например, если Т1 Линия передачи 1,5 Мбит / сек использовалась по спутниковой линии связи со скоростью 513 миллисекунд. время поездки туда и обратно (RTT) произведение задержки полосы пропускания равно бит или около 96 187 байт. Использование максимального размера буфера 64 КиБ позволяет заполнить буфер только до (65 535/96 187) = 68% теоретической максимальной скорости 1,5 Мбит / с или 1,02 Мбит / с.

Используя опцию масштабирования окна, размер окна приема может быть увеличен до максимального значения байтов. Это делается путем указания двухбайтового счетчика сдвига в поле параметров заголовка. Истинный размер окна приема сдвигается влево на значение счетчика сдвигов. Максимальное значение 14 может использоваться для значения счетчика сдвигов. Это позволит одному TCP-соединению передавать данные по примерному спутниковому каналу со скоростью 1,5 Мбит / с, используя всю доступную пропускную способность.

По существу, не более одного полного окна передачи может быть передано в течение одного периода времени приема-передачи. Опция масштабирования окна позволяет одному TCP-соединению полностью использовать LFN с BDP до 1 ГБ, например канал 10 Гбит / с с временем приема-передачи 800 мс.

Возможные побочные эффекты

Поскольку некоторые брандмауэры не реализуют масштабирование окна TCP должным образом, это может вызывать периодические сбои в подключении пользователя к Интернету в течение нескольких минут, а затем снова запускать его без причины. Также существует проблема, если брандмауэр не поддерживает расширения TCP.[1]

Конфигурация операционных систем

Windows

Масштабирование окна TCP реализовано в Windows поскольку Windows 2000.[2][3] Он включен по умолчанию в Windows Vista / Server 2008 и новее, но при необходимости может быть отключен вручную.[4]Виндоус виста и Windows 7 иметь фиксированный буфер приема TCP по умолчанию размером 64 КБ, масштабирование до 16 МБ с помощью «автонастройки», ограничивающее ручную настройку TCP. длинные толстые сети.[5]

Linux

Ядра Linux (с 2.6.8, август 2004 г.) по умолчанию включено масштабирование окна TCP. Параметры конфигурации находятся в Файловая система / proc, см. псевдо-файл / proc / sys / net / ipv4 / tcp_window_scaling и его товарищи / proc / sys / net / ipv4 / tcp_rmem и / proc / sys / net / ipv4 / tcp_wmem (Дополнительная информация: человек tcp, раздел sysctl).[6]

Масштабирование можно отключить, введя следующую команду.

$ sudo sysctl -w "net.ipv4.tcp_window_scaling = 0"

Чтобы сохранить изменения после перезапуска, включите строку "net.ipv4.tcp_window_scaling = 0" в /etc/sysctl.conf (или же /etc/sysctl.d/99-sysctl.conf с systemd 207).

FreeBSD, OpenBSD, NetBSD и Mac OS X

Настройка по умолчанию для FreeBSD, OpenBSD, NetBSD и Mac OS X должно иметь масштабирование окна (и другие функции, связанные с RFC 1323 ) включено.
Чтобы проверить свой статус, пользователь может проверить значение "net.inet.tcp.rfc1323"переменная через sysctl команда:

$ sysctl net.inet.tcp.rfc1323

Значение 1 (вывод "net.inet.tcp.rfc1323 = 1") означает, что масштабирование включено, 0 означает" отключено ". Если включено, его можно отключить, выполнив команду:

$ sudo sysctl -w net.inet.tcp.rfc1323=0

Этот параметр теряется при перезапуске системы. Чтобы убедиться, что он установлен во время загрузки, добавьте следующую строку в /etc/sysctl.conf:net.inet.tcp.rfc1323 = 0

Однако в macOS 10.14 эта команда выдает ошибку

sysctl: неизвестный oid 'net.inet.tcp.rfc1323'

Источники

  1. ^ «Сетевое подключение может не работать при попытке использовать Windows Vista за брандмауэром». Support.microsoft.com. Получено 11 июля, 2019.
  2. ^ «Описание возможностей TCP в Windows 2000 и Windows Server 2003». Support.microsoft.com. Получено 11 июля, 2019.
  3. ^ «Размер окна приема TCP и масштабирование окна». Архивировано из оригинал 1 января 2008 г.
  4. ^ «Сбой подключения к сети при попытке использовать Windows Vista за брандмауэром». Microsoft. 8 июля 2009 г.
  5. ^ «MS Windows». Fasterdata.es.net. Получено 11 июля, 2019.
  6. ^ "/ proc / sys / net / ipv4 / * Переменные".