> А как вообще управление пропускной способностью происходит? По хорошему роутер должен сообщать
> источникам пакетов о том что у него затык, да и свитч
> должен, хотя к нему спроса меньше, ну не может такого быть
> чтобы не было такого механизма?Управляет потоком тот, кто посылает данные. Есть три подхода - по потерям, по задержкам и по ECN. Посылающий не знает пропускной способности полосы и шлёт (я тут упрощаю, т.к. механизмы SACK и контроль последовательности по TS чуток изменили, улучшили ситуацию)... и шлёт пакетов заведомо больше, чем может линия принять. Определённый алгоритм (по определённой кривой) увеличивает кол-во посылаемых данных (CWND - серия пакетов, на которые приходит один ACK, подтверждающий получение), пока не получится первый дроп.
Тут мы делаем оговорку о том, кто делает этот дроп. Т.к. кабель обычно ничего не теряет. Дропает пакеты промежуточное сетевое устройство (может быть роутером). Как только у него переполняется буфер приёма пакетов, он начинает дропать вновь прибывающие. Это random early detection (RED). Есть разные алгоритмы того, что дропать, но смысл в том, что что-то должно быть убрано, чтобы освободить буфер.
Возвращаемся к посылающему пакеты. Как только посылающий не получает подтверждения пакета, то он должен его вновь послать и, заодно, уменьшить кол-во посылаемых данных, т.к. сеть не готова принять такое их кол-во. Потом он вновь начинает посылать их больше, пытаясь понять, вдруг пропускная способность увеличилась (например, закрылись конкурирующие потоки). Поэтому в классике график отдельного соединения выглядит как "пила" в пике которых происходят дропы. Дропы - это обязательный элемент такого алгоритма.
Cubic является его улучшенной реализацией (кубик он из-за кубической кривой, по которой увеличивается кол-во передаваемых пакетов)...