2. Скорость подключения к интернет
растет не по дням а по часам
Европа - 5,6 Mbs
Северная Америка - 5,53 Mbs
Австралия - 4,42 Mbs
Азия - 3,69 Mbs
Южная Америка - 1,64 Mbs
Африка - 1,03 Mbs
Белорусь - 1.8 Mbs (ByFly 1.6-2.0)
Гомельская область 2.06 Mbs
Минск 2.01 Mbs
Гродненская область 1.25 Mbs
Витебская область 1.03 Mbs
Могилевская область 0.8Mbs
По данным speedtest.net
www.jatv.by
3. Новые цифровые форматы все
быстрее входят в нашу жизнь
Видео
на смену DVD пришел BlueRay
прыжек от 720x576 до FullHD 1920x1080
Аудио
на смену CD пришел multichannel DTS MA + DolbyTrueHD
44,1KHz 16bit - 96KHz 24bit
www.jatv.by
4. Строим видеоресурс за 5 минут
Основные функциональные модули
Front-end – взаимодействоие с пользовтелем
Back-end – обработка информации
Проигрыватель – воспроизведение медиаконтента
Транскодер – конвертация
Хранилище – хранение и доставка контента
www.jatv.by
5. Front-end Back-end
Платформа
PHP Ruby, Pyton, Java, .Net
Технологии и концепции
Юзабилити
Web 2.0
AJAX
Тесная интеграция Fron-end и Back-end
Внедрение новых медиа форматов (многоканальный звук)
Загрузка больших файлов (от 1Гб)
Воспроизведение видео
Adobe Flash
Microsoft Silverlight
www.jatv.by
6. Медиа проигрыватель
Воспроизведение видео файлов
Поддержка списков воспроизведения
Поддержка модулей расширения
Внешнее API позволяющее работать с плеером
JW FLV Media Player - longtailvideo.com
Flowplayer - flowplayer.org
www.jatv.by
7. Транскодер
Контейнер != Формат
Контейнер позволяет объединять различные мультимедийные потоки (в
большинстве случаев аудио и видео) в один файл.
Большое количество контейнеров
TS (transport stream), AVI, MP4, OGM, Windows Media
Matroska - самый прогрессивный контейнер
Большое количество кодеков (более 100)
DivX, Xvid, Realmedia, WMV, Mpeg-2
H.264, MPEG-4 Part 10 или AVC - самый перспективный кодек
www.jatv.by
8. Выбор кодека для видеохостинга
Silverlight
WMV
H.264
Adobe Flash
Flash video
H.264
Хоть здесь не налажали ;-) оба конкурента поддерживают H264
H264 - промышленный стандарт
Используется в цифровом телевидении высокого разрешения (HDTV) и как
основной кодек для видеозаписей Министерством обороны
США, компанией Apple и во многих других областях цифрового видео.
www.jatv.by
9. Самое дорогое - это время
99,8% времени тратится на преобразование исходного материала в
формат понятный браузеру
Способы кодирования
Большая и жирная машина - много CPU (ядер) - очень дорого
Распределенная конвертация - много слабых машин вполне приемлемо
Использование GPU для тяжелых просчетов
нет открытого кодека, последний писк моды ;-)
www.jatv.by
10. Хранилище
1=3
Храним все видео на HDD (RAID)
•стандартная файловая система (много файлов - много проблем)
•ограничение по объему
•довольно ненадежно и дорого
•трудно масшабируется
Внешние хранилища
•большая скорость доступа к данным
•очень !!! дорого
•очень тяжело масшабируется
Распределенные файловые системы (DFS)
•дешево
•надежно
•хорошо масшабируется
www.jatv.by
11. Запуск или хороший Индеец
мертвый индеец...
Nginx - http сервер нового поколения
•легкий
•быстрый
•множество модулей (наличие модулей для псевдо стриминга FLV и H.264/AVC)
• PHP-FPM
•плавный рестарт php без потери запросов, в том числе при обновлении php binary или
extensions
•запуск php workers с разными uid/gid/chroot/environment
•все настройки в одном conf файле
• real-time статистика исполнения php запросов
Трансокдер
•FFmpeg — это набор свободных библиотек с открытым исходным кодом, которые
позволяют записывать, конвертировать и передавать цифровое аудио и видео в различных
форматах.
База данных
•MySQL
•PostgreSQL
•MsSQL - это что бы не забывать про Микрософт ;-)
www.jatv.by
12. Начало…
Простая архитектура
Низкий уровень кода
Приложения не дублируются
Борьба за ресурсы
www.jatv.by
13. Разделяй и властвуй
•Один web сервер
•Выделенный сервер для
контента и конвертации
www.jatv.by
14. Первая кровь
•Пара web серверов
•Используется балансировщик
•Выделенный сервер БД
•Выделенный сервер для
хранения медиа файлов
•Проводится незначительный
рефакторинг кода
Web Web File
DB DB www.jatv.by
15. Зубная боль
•Используется кеширование в
memcache
•Процесс записи в приложениях
делается медленно - репликация
задерживается либо делается очень
долго, начали использовать
партиционирование в БД,
используется множество хранилищь
Web Web File File File для контента
•Тербуется существенный
рефакторинг архитектуры БД
DB DB Memcache Sphinx
www.jatv.by
16. Болевой шок
•Основательный рефакторинг
системы
ЦОД •Разделение нагрузки от
ЦОД пользователей по какому либо
параметру - логин, страна и тд.
•Группы разделенных пользователей
ЦОД
обслуживаются отдельными
кластерами.
www.jatv.by