-
Notifications
You must be signed in to change notification settings - Fork 62
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
RTMP Resolution Probe Issue #137
Comments
Well done tracking this down! The probe could fail if the process exit code is non-zero, or if the string output can't be parsed. I would investigate those two things next. |
@joeyparrish thanks for the input. TL;DR;I've done some more digging and it looks like this is related to having too short of an How would you like to approach this solution? Perhaps provide an option on the input to control the InvestigationWhile digging into it I noticed that back-to-back calls to Proper Resultroot@578709af1cc9:/usr/src/app# result=$(/usr/local/lib/python3.11/site-packages/streamer_binaries/ffprobe-linux-x64 rtmp://nginx-rtmp/live/obs_stream -select_streams v:0 -show_entries stream=width,height -of compact=p=0:nk=1)
ffprobe version n4.4 Copyright (c) 2007-2021 the FFmpeg developers
built with gcc 9 (Ubuntu 9.3.0-17ubuntu1~20.04)
configuration: --pkg-config-flags=--static --disable-ffplay --enable-libvpx --enable-libaom --enable-libx264 --enable-libx265 --enable-libmp3lame --enable-libopus --enable-mbedtls --enable-runtime-cpudetect --enable-gpl --enable-version3 --enable-static --enable-nvenc --enable-vdpau
libavutil 56. 70.100 / 56. 70.100
libavcodec 58.134.100 / 58.134.100
libavformat 58. 76.100 / 58. 76.100
libavdevice 58. 13.100 / 58. 13.100
libavfilter 7.110.100 / 7.110.100
libswscale 5. 9.100 / 5. 9.100
libswresample 3. 9.100 / 3. 9.100
libpostproc 55. 9.100 / 55. 9.100
Input #0, flv, from 'rtmp://nginx-rtmp/live/obs_stream':
Metadata:
|RtmpSampleAccess: true
Server : NGINX RTMP (github.com/arut/nginx-rtmp-module)
displayWidth : 1280
displayHeight : 720
fps : 30
profile :
level :
Duration: 00:00:00.00, start: 686.722000, bitrate: N/A
Stream #0:0: Audio: aac (LC), 48000 Hz, stereo, fltp, 163 kb/s
Stream #0:1: Video: h264 (High), yuv420p(tv, bt709, progressive), 1280x720 [SAR 1:1 DAR 16:9], 2560 kb/s, 30 fps, 30 tbr, 1k tbn, 60 tbc
root@578709af1cc9:/usr/src/app# echo $result
1280|720
No Resultroot@578709af1cc9:/usr/src/app# result=$(/usr/local/lib/python3.11/site-packages/streamer_binaries/ffprobe-linux-x64 rtmp://nginx-rtmp/live/obs_stream -select_streams v:0 -show_entries stream=width,height -of compact=p=0:nk=1)
ffprobe version n4.4 Copyright (c) 2007-2021 the FFmpeg developers
built with gcc 9 (Ubuntu 9.3.0-17ubuntu1~20.04)
configuration: --pkg-config-flags=--static --disable-ffplay --enable-libvpx --enable-libaom --enable-libx264 --enable-libx265 --enable-libmp3lame --enable-libopus --enable-mbedtls --enable-runtime-cpudetect --enable-gpl --enable-version3 --enable-static --enable-nvenc --enable-vdpau
libavutil 56. 70.100 / 56. 70.100
libavcodec 58.134.100 / 58.134.100
libavformat 58. 76.100 / 58. 76.100
libavdevice 58. 13.100 / 58. 13.100
libavfilter 7.110.100 / 7.110.100
libswscale 5. 9.100 / 5. 9.100
libswresample 3. 9.100 / 3. 9.100
libpostproc 55. 9.100 / 55. 9.100
Input #0, flv, from 'rtmp://nginx-rtmp/live/obs_stream':
Metadata:
|RtmpSampleAccess: true
Server : NGINX RTMP (github.com/arut/nginx-rtmp-module)
displayWidth : 1280
displayHeight : 720
fps : 30
profile :
level :
Duration: 00:00:00.00, start: 717.292000, bitrate: N/A
Stream #0:0: Audio: aac (LC), 48000 Hz, stereo, fltp, 163 kb/s
root@578709af1cc9:/usr/src/app# echo $result
To me it's still quite strange that these calls failed given that the |
@joeyparrish friendly ping on this. Happy to submit a PR, just need to know which option you'd want to go with (see above). |
Thanks for the ping! Is there a down side to passing a 5s analyzeduration by default? If you think we might need a configurable duration, could we have a default that works for both RTMP and regular files? You have spent more time on this than me by roughly infinity percent, so I'm happy to review a PR with whatever solution you feel is best. Just explain the choice in the PR description, for posterity and for ease of review. Thanks! |
@joeyparrish the current default is The potential downsides to just increasing the default value:
I think I'd lean towards having a default that could be overridden via pipeline config. I'll send a PR to that effect unless you respond with more thoughts on the matter. Thanks! |
Sounds good. My philosophy is generally to offer a config where it's needed, and to try to set a default that will work for most people most of the time, so that it isn't strictly required to set it. |
@jspizziri, I know it has been a long time, but are you still interested in sending a PR to add a config for this? |
Hey @joeyparrish sorry for ghosting you on this one. My every intention was to do it, but alas, my need for RTMP has gone away and as such, I'm not going to be able to get to it in the foreseeable future. Sorry! |
No worries. I'll leave it open for anyone else who wants to contribute. I think it would be a fairly simple first contribution. |
This is a follow-up to the several comments I left here.
It appears that there might be an issue with the
_probe
function regardingresolution
.shaka-streamer
transcode the RTMP stream.Following these steps results in the following error:
The above error is the result of a failed attempt to autodetect the resolution. The
ffprobe
command that's being logged is the following:So presumeably this command is not returning the
width
andheight
of the stream. I did some debugging, and python is returningNone
for the actual result of the probe call. However, if you run thatffprobe
command directly on the stream you do in fact get a correct result:To further confirm that this was the problem I hardcoded the
resolution
in my input yaml file and my RTMP stream started transcoding the way I expected (given I had bypassed the resolution autodetect).I've done some debugging and my guess is that the issue is related to how the
ffprobe
command is actually invoked here.Going to do some more digging but any guidance would be helpful!
The text was updated successfully, but these errors were encountered: