-
Notifications
You must be signed in to change notification settings - Fork 28
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
Start streaming parts before first completed segment in HLS Low Latency #92
base: main
Are you sure you want to change the base?
Conversation
Codecov Report
@@ Coverage Diff @@
## main #92 +/- ##
==========================================
- Coverage 68.92% 68.65% -0.27%
==========================================
Files 42 42
Lines 3652 3717 +65
==========================================
+ Hits 2517 2552 +35
- Misses 954 981 +27
- Partials 181 184 +3
📣 We’re building smart automated test selection to slash your CI/CD build times. Learn more |
Hello, by looking at the code, you want to make the playlist available as soon as a certain number of parts is available, is that correct? This approach may work, but did you test it with iOS? |
Hi @aler9, that is correct. When we release the playlist as soon as a certain number of parts are available, we are able to quickly show the stream even with a GOP size of 20seconds. I tried my best testing this in the iOS simulator on my Mac using a downloaded video published by ffmpeg. The behaviour is the same as with the main branch only faster. But using both the main branch as my branch the simulator doesn't show video but it does request the correct files. Maybe you have some tests you normally do in iOS? |
Hi @aler9, Is there something I can do to help getting this PR tested/completed? Maybe you know of some tests I can do or write? Thanks! |
Hello, as previously written, i have to test this on iOS. |
Ok thanks! Will wait for your results. Hopefully it all works :) |
While this approach works with hls.js, it doesn't work on iOS, that requires at least a complete segment before serving the stream. There's an alternative way to make video appear immediately (without even waiting Basically you have to store into the server blank frames encoded with AV1, VP9, H264, H265, generate a 1-second long MP4 segment that contains frames correspondent to the current codec, and serve it instead of gaps. In this way, a playlist is available immediately in full. I don't know if or when this will be implemented, a PR would be welcome. |
That's really unfortunate. About the proposed solution, do you mean instead of sending a playlist with 7 non-existent gap.mp4 files, we should immediately send actual blank mp4 files with a length of 1 sec? Seems doable! Is it an option to add this PR under a feature flag (enable it using the mediamtx.yaml file) while we develop the other proposed solution? Our application really needs the faster startup time right now and we would rather keep using the official images instead of creating and building our own forks. Of course we will commit to developing the more compatible solution |
Hi, we experience similar problems so this feature would be a great asset. Is there any progress on this topic ? |
In #79 I disabled the randomAccess check to start streaming HLS low latency parts before the first segment was completed. This enabled us to display the video feed much faster as our video source GOP size is 20seconds.
The PR was rejected because it was creating segments without a starting IDR frame.
This PR solves the same problem in a (hopefully) supported manner.