The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Пакет multifiles - распространение файлов поверх IP-мультикаста

01.12.2008 16:32

Компания НетАП опубликовала исходные коды системы распространения файлов, использующей для своей работы мультикаст потоки. Лицензия GPLv2, GPLv3.

Использование multicast позволяет оперативно передать файл на любое количество клиентов, задействовав только один поток. Распространяемый файл циклически передается в сеть в виде UDP multicast-потока на определенный multicast-адрес (по умолчанию – 224.2.2.4, порт 2222). При этом клиент, желающий скачать этот файл, подключается к этой группе, посылая IGMP-запрос, и начинает получать этот файл. Как только получен весь файл, клиент отключается от группы и проверяет целостность полученного файла.

Данная система позволяет элегантно и с минимальными аппаратными затратами решить задачу распространения обновленных прошивок на большое количество клиентских приставок IPTV ( IP STB ).

  1. Главная ссылка к новости (http://www.netup.tv/ru-RU/mult...)
Автор новости: netup
Лицензия: CC BY 3.0
Короткая ссылка: https://opennet.ru/19163-multicast
Ключевые слова: multicast, file
При перепечатке указание ссылки на opennet.ru обязательно


Обсуждение (23) Ajax | 1 уровень | Линейный | +/- | Раскрыть всё | RSS
  • 1.1, fa (??), 18:56, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Интересно, какие модели STB такое умеют?
     
     
  • 2.2, veillard (ok), 18:58, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    В какую вставишь эту систему - такая и будет уметь ...
     
  • 2.13, Cyrill Malevanov (?), 00:15, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    dlink dib-120, например
     

  • 1.3, shutdown now (?), 19:40, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    это только для LAN подойдёт и только если процент потерь очень низкий, переповторять "битые" данные придётся обычным unicast
     
     
  • 2.4, Аноним (4), 19:45, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    а что мешает применить par2 ? скажем пропорционально степени потерь.
     
     
  • 3.19, Дмитрий Ю. Карпов (?), 15:45, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    > а что мешает применить par2 ? скажем пропорционально степени потерь.

    Только то, что сервер не знает процента потерь, да и для каждого клиента процент потерь разный.

     
  • 2.5, Анонимус (?), 19:48, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    http://sourceforge.net/projects/rscode/ - простенькая либа для Reed–Solomon error correction ... прикручивается за 5 минут.
     
  • 2.12, Аноним (4), 22:12, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    Только для LAN? Ну ты сказал... а, например, для DVB-S?
     
  • 2.18, Дмитрий Ю. Карпов (?), 15:44, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    Есть масса способов обеспечить передачу данных в случае даже пропажи некоторого количества пакетов; общее название - Error Correction Codes (Коды Исправления Ошибок). Пример такого кода, удобного для IP-пакетов, применяется в RAID-5 - каждый пакет/сектор содержит CRC, и к каждой группе пакетов добавляется ещё один с XOR всех остальных. Система выдерживает пропажу/искажение одного (любого) пакета из группы.
     

  • 1.6, КтулхЪ (?), 19:54, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    >Как только получен весь файл, клиент отключается от группы и проверяет целостность полученного файла.

    а если у мну диалапЪ? источник снизойдет до ширины моего канала?

     
     
  • 2.7, ximaera (?), 20:34, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    ..."Ага!", - сказали вятские мужики и пошли рубить лес топорами.

    Вы что, хотите это для торрентов использовать?!

    У каждой технологии есть своя область применения. Область применения данной указана в конце поста. Конечно, можно эту хитрость использовать и для других вещей, но не как замену FTP.

     
     
  • 3.11, Аноним (4), 21:33, 01/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    спутниковые операторы такого клиента использовали...

    качают в 30 Мбит/с канале уникастом фильмо, как только скорость падает до 50 килобайт/с сразу наступает прозрение :) лучше пусть все новые киношки прокачает со скоростью 3 мега в секунду (4 минуты на обычное кино, 8 на двд (ну пусть на минуту дольше в смысле коррекции ошибок, все равно от 8 киношек в час --- 160-300 за 24 часа)), чем одно и тоже будут доить по капле.

     

  • 1.8, spamtrap (??), 20:37, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    >Данная система позволяет элегантно

    не очень-то и элегантно - потерялся один пакет - жди следующей передачи...
    хотя, если учесть, что раньше и такого не было - прогресс!

     
     
  • 2.16, User294 (ok), 02:13, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    >не очень-то и элегантно - потерялся один пакет - жди следующей передачи...

    А избыточность придумал трус, да?Ну вон рида-соломона вроде посоветовали выше =).При должной избыточности не слишком большие потери будут просто пофигу.

     

  • 1.9, Skylord (??), 20:50, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Фигня... НетАп как всегда выложил то, что им уже не нужно и на чем - как НетАп осознал - денег они не заработают.
    У меня на столе стоит IPTV приставка D-Link DIB-120 (а под столом коробка еще с десятком их же) - стоит дешевле Амины (а также других девайсов с HDMI) и не требует написания middleware (только html-страницы с управляющим javascript'ом - API доступен бесплатно по первой просьбе у производителя). Производитель тоже дает (правда без исходников, если мне память не изменяет) готовую утилиту для обновления по мультикасту - спрашивается - и что толку? У своем интерфейсе я сделал, что при обращении на сервер за программой передач, приставка отсылает свою версию и если доступна версия новее - включается скачиванием и обновление прошивки юникастом. И все. Легко и просто - безо всяких заморочек с мультикастом, боязнью - как бы чего не дошло битым и как бы пользователь не выключил приставку в процессе прошивки....
    НетАп пытается продать свою систему для предоставления услуг IPTV и, видать, не очень получается. И чем больше будет девайсов типа упомянутого DIB-120 - тем будет хуже.
     
     
  • 2.22, sergdsv (??), 09:59, 02/06/2009 [^] [^^] [^^^] [ответить]  
  • +/
    >[оверквотинг удален]
    >не изменяет) готовую утилиту для обновления по мультикасту - спрашивается -
    >и что толку? У своем интерфейсе я сделал, что при обращении
    >на сервер за программой передач, приставка отсылает свою версию и если
    >доступна версия новее - включается скачиванием и обновление прошивки юникастом. И
    >все. Легко и просто - безо всяких заморочек с мультикастом, боязнью
    >- как бы чего не дошло битым и как бы пользователь
    >не выключил приставку в процессе прошивки....
    >НетАп пытается продать свою систему для предоставления услуг IPTV и, видать, не
    >очень получается. И чем больше будет девайсов типа упомянутого DIB-120 -
    >тем будет хуже.

    А можно подробнее?
    Подскажите пожалуйста.
    Ситуация следующая:

    Есть сервер с VLC плеером который вещает в сеть по мультикасту каналы.
    Как со спутника принял так в сеть и отдал.
    С компа можно смотреть с помощью того же VLC плеера прописав либо
    адрес канала либо подрузив плейлист.
    Адреса вида для VLC - udp://@233.255.12.45:1234
    Подскажипе пожалуйста какую прошивку применить для DIB-120? Как ее
    туда залить? И где коректировать список каналов?
    Есть ли описание этого всего?

     

  • 1.10, Аноним (10), 21:15, 01/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Гы. В коде после каждой закрывающей фигурной скобки стоит ";". Не думал, что у кого-то есть *такие* привычки.
     
     
  • 2.15, pavlinux (ok), 00:42, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    >Гы. В коде после каждой закрывающей фигурной скобки стоит ";". Не думал,
    >что у кого-то есть *такие* привычки.

    Похоже на автоформатирование, типа как у Eclipse, Visual Studio, и т.п.

    Ну что, домашнее задание по C - смоделировать такую ситуацию когда употребление ";"
    после "}" вызовет ошибку программы!!!

     
     
  • 3.20, Аноним (-), 21:53, 02/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    ошибку программы не знаю, а компиляции -пожалуйста
    do {}; while(0);
    что-нибудь еще есть?
     
     
  • 4.21, pavlinux (ok), 02:46, 03/12/2008 [^] [^^] [^^^] [ответить]  
  • +/
    >ошибку программы не знаю, а компиляции -пожалуйста
    >do {}; while(0);
    >что-нибудь еще есть?

    main(){
           for(;;)
              {
               if(0) {
                ;
              };
              else {
                  return 0;
              };
          };
    };

     

  • 1.14, pavlinux (ok), 00:21, 02/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Во!!! Так этож можно замутить Torrent-over-DVB
     
  • 1.17, deepwalker (??), 08:29, 02/12/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    http://udpcast.linux.lu/
     
  • 1.23, Аноним (-), 12:41, 26/03/2012 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    http://depositfiles.com/files/ybqaos84l
    http://depositfiles.com/files/5hf8fqejh
    http://depositfiles.com/files/6syej8h2t
     
     Добавить комментарий
    Имя:
    E-Mail:
    Текст:



    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2024 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру