mediasoup v3
data:image/s3,"s3://crabby-images/ba79e/ba79ef0fe572bcaa46721fcfce94d4c81b3a3458" alt=""
data:image/s3,"s3://crabby-images/56e43/56e43937854161590b05031023a9cb3987484050" alt=""
data:image/s3,"s3://crabby-images/062a1/062a1e7b83ac165e1c3aee36bfd0a7dc80574811" alt=""
data:image/s3,"s3://crabby-images/c2025/c202528ff6e93512687399a88ca43dccee4fe304" alt=""
data:image/s3,"s3://crabby-images/9746d/9746d23e3d00dde1989ff8413ab6b49aec8d89dc" alt=""
data:image/s3,"s3://crabby-images/2aa7a/2aa7a7410ada8f66fbb6d51470268ea9e613838d" alt=""
data:image/s3,"s3://crabby-images/31fc1/31fc12da6338eaa339ea0f68b2349e6ad6af4af0" alt=""
data:image/s3,"s3://crabby-images/1255c/1255c092592da683975c9f2b8a74ccdfa0c9acda" alt=""
Website and Documentation
Support Forum
Design Goals
mediasoup and its client side libraries are designed to accomplish with the following goals:
- Be a SFU (Selective Forwarding Unit).
- Support both WebRTC and plain RTP input and output.
- Be a Node.js module or Rust crate in server side.
- Be a tiny TypeScript and C++ libraries in client side.
- Be minimalist: just handle the media layer.
- Be signaling agnostic: do not mandate any signaling protocol.
- Be super low level API.
- Support all existing WebRTC endpoints.
- Enable integration with well known multimedia libraries/tools.
Architecture
data:image/s3,"s3://crabby-images/7f087/7f0879ec1783879984d7983ca61c98ce4e0fc2b5" alt=""
Use Cases
mediasoup and its client side libraries provide a super low level API. They are intended to enable different use cases and scenarios, without any constraint or assumption. Some of these use cases are:
- Group video chat applications.
- One-to-many (or few-to-many) broadcasting applications in real-time.
- RTP streaming.
Features
- ECMAScript 6/Idiomatic Rust low level API.
- Multi-stream: multiple audio/video streams over a single ICE + DTLS transport.
- IPv6 ready.
- ICE / DTLS / RTP / RTCP over UDP and TCP.
- Simulcast and SVC support.
- Congestion control.
- Sender and receiver bandwidth estimation with spatial/temporal layers distribution algorithm.
- Data message exchange (via WebRTC DataChannels, SCTP over plain UDP, and direct termination in Node.js/Rust).
- Extremely powerful (media worker thread/subprocess coded in C++ on top of libuv).
Demo Online
data:image/s3,"s3://crabby-images/64719/647199d6141051e3639dc692960f329a25d16e9e" alt=""
Try it at v3demo.mediasoup.org (source code).
Authors
Social
Sponsor
You can support mediasoup by sponsoring it. Thanks!
License
ISC