Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Investigate possible performance with Pion and compare it to LiveKit #23

Open
SimonBrandner opened this issue Aug 13, 2022 · 8 comments
Labels
T-Enhancement New feature or request

Comments

@SimonBrandner
Copy link
Contributor

Currently, the SFU using a little too much CPU - we should fix that

@SimonBrandner SimonBrandner added the T-Defect Something isn't working label Aug 13, 2022
@SimonBrandner SimonBrandner self-assigned this Aug 13, 2022
@daniel-abramov daniel-abramov changed the title Fix performance issues Investigate and fix performance issues Nov 10, 2022
@SimonBrandner SimonBrandner removed their assignment Nov 12, 2022
@daniel-abramov daniel-abramov added T-Task T-Enhancement New feature or request and removed T-Defect Something isn't working T-Task labels Dec 9, 2022
@daniel-abramov
Copy link
Contributor

UPD. So far the performance looks okayish, i.e. nothing particularly crazy in our code that would kill the performance, it seems like this performance is ok for Pion (after all, we're using a very weak machine and videos and screen-sharing of quite good quality and high FPS).

The only thing that we might want to do is to compare it to the competition, e.g. to LiveKit. If the performance is more or less identical, then we can't do much about it.

Since it's not a bug in our code, I've changed the tag from Defect to Enhancement.

@daniel-abramov daniel-abramov changed the title Investigate and fix performance issues Investigate possible performance with Pion and compare it to LiveKit Dec 9, 2022
@Sean-Der
Copy link
Contributor

Sean-Der commented Dec 9, 2022

Hey @daniel-abramov i would love to help with this!

Pion does some things that aren’t as performant as can be. If you are interested would love your help to fix that :)

@daniel-abramov
Copy link
Contributor

Ah, thanks @Sean-Der 🙂

I think It would be great to hear your expert opinion on the following: we're running an SFU on a very weak VM with a single 2.8 GHz core and 1.9 GB of RAM. Our SFU consumes about 30% CPU in a conference with 5 participants (each publishes video and audio) + 1 screen sharing track.

When the screen sharing track is removed, then the CPU is about 23%. WIthout the screen sharing, a conference of about 6-7 participants (all sharing video and audio) consumes about 30% of CPU.

I'm not really sure if it's actually that bad (provided we have a very weak machine and the quality of video and screen sharing, as well as the FPS, are all pretty good).

Since we’re not decoding anything, the only expensive thing that Pion seems to be doing in such cases is encryption/decryption, right? Do you think that such a usage with our use case could be considered ok? (I believe that if/once we reduce the quality of videos and introduce simulcast, the CPU usage might drop)

@poVoq
Copy link

poVoq commented Aug 31, 2023

Looking at the element-call repo it seems like they prefer using LiveKit these days?

What does this mean for the future of this very interesting cascading approach?

@daniel-abramov are you still willing to work on this? Maybe as a more general SFU that systems other than Matrix could use as well? Would be a shame if this idea ends up being totally abandoned.

@daniel-abramov
Copy link
Contributor

daniel-abramov commented Aug 31, 2023

What does this mean for the future of this very interesting cascading approach?

As to my knowledge, the cascading approach is not abandoned (just postponed a bit) and I believe that it will be implemented eventually (I think not in the nearest future though). Note that the latest versions of the waterfall and element-call that worked together did not really support proper cascading either. That being said, it's possible to have cascading with Element Call and LiveKit (albeit some work must be done in both Element Call and LiveKit to add support of it), so the choice of LiveKit does not really hold folks from implementing cascading in the future (not to mention that one can exchange the SFU for a different one should this be necessary).

@daniel-abramov are you still willing to work on this?

Not in the context of waterfall. My personal opinion is that it does not really make much sense to invest too much time into waterfall (or any other Go/Pion SFU for that matter) for the pure reason that LiveKit SFU does most of the things that waterfall did except that it does not support native Matrix signalling yet. In other words, it's easier to add Matrix signaling support in LiveKit SFU than writing a new SFU from scratch (signalling and related parts of code are at best 10-15% of the code). The thing is that both LiveKit and waterfall use the same tech stack for the SFU and I very often got a feeling that at least 75% of the code will end up being very similar to that of LiveKit, because there are so many things that are in common. Also LiveKit was much more mature and battle-tested with a bigger ecosystem of tools, benchmarks and tests and the best thing is that it's open source!

Maybe as a more general SFU that systems other than Matrix could use as well?

This is certainly a great approach! I think that it would be amazing to have a scalable and performant SFU that is similar to LiveKit yet also supports different flavors of signaling that allows the support of cascading. That being said, if I were to start with the design of such SFU, I would definitely go for a different (Rust-based) tech stack. As for Go/Pion SFU, IMHO LiveKit is the most performant, reliable and versatile open-source option one could get (truth being told, I have not checked any newer SFUs within the past couple of months).

@poVoq
Copy link

poVoq commented Aug 31, 2023

I see, thanks for the detailed answer!

There seems to be a project reimplementing Pion in Rust in case you are interested in contributing a cascading mode: https://github.com/webrtc-rs/webrtc

@daniel-abramov
Copy link
Contributor

daniel-abramov commented Sep 1, 2023

There seems to be a project reimplementing Pion in Rust in case you are interested in contributing a cascading mode: https://github.com/webrtc-rs/webrtc

Indeed, I tried webrtc-rs back in December 2022, but back then it was not mature enough, also the API surface was very hard to use (not paritcularly ergonomic as it tried to mimic the API surface of Pion, whereas Pion's API surface seem to have drawn certain inspiration from the JavaScript API; in Rust such API is not particularly useful as it is possible to design a more robust set of types to ensure certain invariants in the code on compile time; there are also some other interesting Rust-based projects that are related to the SFUs or WebRTC in general, such as such as str0m and Signal SFU).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
T-Enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

4 participants