TCP/IP (компьютерное)
Aug. 23rd, 2004 10:01 pm1. А могли ведь, наверное (подумалось мне как-то недавно) внести в TCP встроенную возможность передавать много параллельных потоков по одному каналу. Самым простым и примитивным способом: ввести в заголовок TCP поле “номер потока”, размером в байт, например (256 потоков).
О, да кстати там и поле reserved в 6 бит есть, вижу (64 потока). Дать к номеру потока доступ на уровне сокетов или других интерфейсов с помощью соответствующих расширенных функций. И пусть те аппликации, кому удобно, используют. По умолчанию всегда будет один поток, нулевой.
Зачем это нужно и почему просто не открыть несколько TCP-соединений? Несколько соединений могут легко рассинхронизироваться и вообще пойти через разные раутеры даже. Несколько потоков в одном соединении будут ползти одним потоком с точки зрения самого TCP.
Предположим, мне нужно транслировать фильм по сети, чтобы на втором конце его могли проигрывать в realtime. Что сейчас делают? Используют формат, который мультиплексирует видео- и аудио-поток вместе, так, чтобы они были синхронизированы в общем потоке. Попеременно идут фреймы видео-аудио-видео-аудио (ясно, что удельный вес видео больше). Например, формат AVI, или MPEG, или новые OGM и Matroska. Но чем плохо было бы просто пустить фильм по TCP, пометив видео и аудио как разные потоки? Посылающая программа следила бы за синхронизацией, а сам протокол TCP обеспечивал бы тот факт, что они не рассинхронизируются по пути. И не нужен отдельный файловый формат.
Ещё, наверное, всякие примеры можно придумать.
P.S. Забыл упомянуть, что, собственно, весьма примитивная поддержка этого дела в TCP есть — но только двух потоков: обычного и "срочного" (с помощью urgent pointer). Этого, ясно, недостаточно, да и семантика тут чуть другая. Я вообще-то не знаю, пользуется ли кто-то серьёзно этими самыми urgent-данными в TCP (кажется, telnet пользуется для чего-то там — и больше никого не знаю).
2. Наивный немного вопрос: а что там вообще происходит с IPv6, кто-то следит за этим делом? А то я уже, наверное, лет восемь слышу разговоры о том, что у нас вот-вот кончатся 32-битные адреса, и что мы вот-вот перейдём все на IPv6. Тем временем адреса вроде бы не кончаются (или кончаются всё-таки?) и на IPv6 мы не переходим. В каком состоянии вообще всё это находится?
О, да кстати там и поле reserved в 6 бит есть, вижу (64 потока). Дать к номеру потока доступ на уровне сокетов или других интерфейсов с помощью соответствующих расширенных функций. И пусть те аппликации, кому удобно, используют. По умолчанию всегда будет один поток, нулевой.
Зачем это нужно и почему просто не открыть несколько TCP-соединений? Несколько соединений могут легко рассинхронизироваться и вообще пойти через разные раутеры даже. Несколько потоков в одном соединении будут ползти одним потоком с точки зрения самого TCP.
Предположим, мне нужно транслировать фильм по сети, чтобы на втором конце его могли проигрывать в realtime. Что сейчас делают? Используют формат, который мультиплексирует видео- и аудио-поток вместе, так, чтобы они были синхронизированы в общем потоке. Попеременно идут фреймы видео-аудио-видео-аудио (ясно, что удельный вес видео больше). Например, формат AVI, или MPEG, или новые OGM и Matroska. Но чем плохо было бы просто пустить фильм по TCP, пометив видео и аудио как разные потоки? Посылающая программа следила бы за синхронизацией, а сам протокол TCP обеспечивал бы тот факт, что они не рассинхронизируются по пути. И не нужен отдельный файловый формат.
Ещё, наверное, всякие примеры можно придумать.
P.S. Забыл упомянуть, что, собственно, весьма примитивная поддержка этого дела в TCP есть — но только двух потоков: обычного и "срочного" (с помощью urgent pointer). Этого, ясно, недостаточно, да и семантика тут чуть другая. Я вообще-то не знаю, пользуется ли кто-то серьёзно этими самыми urgent-данными в TCP (кажется, telnet пользуется для чего-то там — и больше никого не знаю).
2. Наивный немного вопрос: а что там вообще происходит с IPv6, кто-то следит за этим делом? А то я уже, наверное, лет восемь слышу разговоры о том, что у нас вот-вот кончатся 32-битные адреса, и что мы вот-вот перейдём все на IPv6. Тем временем адреса вроде бы не кончаются (или кончаются всё-таки?) и на IPv6 мы не переходим. В каком состоянии вообще всё это находится?
no subject
Date: 2004-08-23 12:15 pm (UTC)Необходимо также учитывать, что открытие множественных ТСР-сессий может быть предпочтительнее в ряде ситуаций, т.к. каждая сессия регулирует свой размер окна независимо от других.
no subject
Date: 2004-08-23 12:18 pm (UTC)рынок регулировал-регулировал, и нарегулировал ситуацию, в которой куча народу сидит за NAT-router'ами и не жужжит. IPv6 может особо не торопиться, насколько я понимаю.
перспектива тоже не видится мне ужасной: NAT-routing, насколько я опять же понимаю, допускает многоуровневое вложение.
no subject
Date: 2004-08-23 12:18 pm (UTC)no subject
Date: 2004-08-23 12:22 pm (UTC)2. В довольно медленном. Адреса действительно не кончаются, да в IPv6 есть нерешенных проблем.
no subject
Date: 2004-08-23 12:23 pm (UTC)no subject
Date: 2004-08-23 12:31 pm (UTC)а всё живо из-за проклятого NAT'а. если бы не он, давно бы адреса кончились.
no subject
Date: 2004-08-23 12:35 pm (UTC)Сегодня - да, но я как раз предлагаю "спустить" эту возможность на transport layer, путём внесения её в сам протокол TCP.
Необходимо также учитывать, что открытие множественных ТСР-сессий может быть предпочтительнее в ряде ситуаций, т.к. каждая сессия регулирует свой размер окна независимо от других.
Да, это понятно.
no subject
Date: 2004-08-23 12:36 pm (UTC)no subject
Date: 2004-08-23 12:38 pm (UTC)no subject
Date: 2004-08-23 12:42 pm (UTC)no subject
Date: 2004-08-23 12:44 pm (UTC)no subject
Date: 2004-08-23 12:45 pm (UTC)no subject
Date: 2004-08-23 12:46 pm (UTC)Использование бита TCP пакета предполагает что надо изменить все TCP стеки, а это нереально. Выигрыш же в количестве передаваемых данных относительно мал.
no subject
Date: 2004-08-23 12:50 pm (UTC)Я полагаю, что понятие мультиплексирования потоков достаточно общее, чтобы не нужно было заставлять разные application-level protocols его пере-изобретать и пере-воплощать.
no subject
Date: 2004-08-23 12:51 pm (UTC)Т.е. технически это верно, конечно, "триллионы" новых адресов. Очень-очень много триллионов... ;)
no subject
Date: 2004-08-23 12:59 pm (UTC)no subject
Date: 2004-08-23 12:59 pm (UTC)Курица и яйцо
Date: 2004-08-23 12:59 pm (UTC)Даже если пренебречь сушествующими компьютерами, внедерение мультиплексирования на уровне битов TCP пакета требует от производителей ОС поддерживать протокол для которого нет аппликаций, а разработчиков аппликаций - использовать протокол который еще не поддерживается ОС.
no subject
Date: 2004-08-23 01:00 pm (UTC)no subject
Date: 2004-08-23 01:00 pm (UTC)вот и весь вопрос.
no subject
Date: 2004-08-23 01:02 pm (UTC)no subject
Date: 2004-08-23 01:20 pm (UTC)Курица и яйцо
эта проблема всегда стоит.
no subject
Date: 2004-08-23 01:26 pm (UTC)а для клиентского режима хватит одного IP-адреса на сеть, да.
no subject
Date: 2004-08-23 01:27 pm (UTC)no subject
Date: 2004-08-23 01:31 pm (UTC)