аналог дискорда, чтобы экранчик постримить группе людей. Как я понял из гуглежа, есть webrtc, он умеет в p2p коннект, может обходить NAT юзая STUN/TURN сервера, но... p2p это же по идее 1 на 1 коннект? Я же не могу сконнектить так более двух человек? Если отойти чуть дальше от WEBRTC и просто брать с браузера поток видео с экрана и слать на сервер - чем это ретранслировать? Какой протокол?
Ты можешь устанавливать коннект со всеми участниками конфы отдельно Но у webrtc есть одна существенная проблема: если у тебя человек, который стримит, подвиснет - клиент залагает у всех Потому что закрыть этот коннект, когда проблема у другого человека - задача не самая простая Вообще, для стримов отдельные есть апишки И готовые серверные приложухи Лучше покапать куда-нибудь туда, потому что даже если ты решишь сетевые проблемы (а там еще реальный ip надо получать, и прочее), тебе еще довольно долгая война с кодеками предстоит
https://developer.mozilla.org/en-US/docs/Web/Guide/Audio_and_video_delivery/Live_streaming_web_audio_and_video
https://habr.com/ru/company/flashphoner/blog/478884/?ysclid=l7eb8w9a9b367207008
И еще чуть-чуть докину Делали мы как-то стриминг n-часовой И для поддержи кодеков на фронт залили пару либ-конверторов Потом было очень неприятно ловить out of memory в рандомный момент времени Так что, имеет смысл еще клиентскую часть хорошо отметить, после того, как выберешь одно из решений
Поищу, про коннект нескольких вотчеров к единому броадкастеру инфу нашёл и даже тестовый код написал - работает. Про залагивание броадкастера: там энивей висит вебсокет рядом, можно по нему определять, пингами например, если долго не пингует - отвалился, можно задушить коннект p2p. Но пока не тестил. > реальный ip надо получать Из того, что я пока накопал - не нужно. Для пробивания NAT есть STUN (помогает коннектиться сквозь NAT) / TURN (прокси ретранслятор, если STUN тоже не смог). Но варианты с готовыми движками для стриминга поищу. Поддержка браузерная в целом не критична, главное latest версии основных.
https://github.com/feross/simple-peer Можно one 2 many, но будет нормально так нагружать источник. Фактически если не нужны MFU, то есть если это не Google meet/zoom то работает все без сервера, достаточно ли просто обменятся "signal" между браузерами.
Обсуждают сегодня