Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/user-interface/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在nginx中与rtmp模块一起使用时,使用ffmpeg命令失败_Nginx_Ffmpeg - Fatal编程技术网

在nginx中与rtmp模块一起使用时,使用ffmpeg命令失败

在nginx中与rtmp模块一起使用时,使用ffmpeg命令失败,nginx,ffmpeg,Nginx,Ffmpeg,我在一个“bash”文件中测试了一段代码。它在贝壳上工作得很好。我只更改了参数以使其与nginx rtmp模块一起工作,但ffmpeg表示始终存在可理解的错误。代码如下: exec_push ffmpeg -re -y -i rtmp://localhost:1935/live/$name \ -c:v libx264 -c:a aac \ -g 24 -keyint_min 24

我在一个“bash”文件中测试了一段代码。它在贝壳上工作得很好。我只更改了参数以使其与nginx rtmp模块一起工作,但ffmpeg表示始终存在可理解的错误。代码如下:

exec_push ffmpeg -re -y -i rtmp://localhost:1935/live/$name  \
                            -c:v libx264 -c:a aac  \
                            -g 24 -keyint_min 24   -preset veryfast -tune zerolatency -movflags +faststart -vsync passthrough  \
                            -filter_complex '[0:v]format=pix_fmts=yuv420p,split=3[in1][in2][in3];[in1]scale=320:-2[320x];[in2]scale=640:-2[HQ640x];[in3]scale=1280:-2[HD1280x];[0:a]aresample=44100[audio]'  \
                            -map '[320x]'       -profile:v baseline -level 3.0 -crf 31 -maxrate 170k -bufsize 170k      -f mp4 rtmp://localhost:1935/rtmp_hls/$name_320x  \
                            -map '[HQ640x]'     -profile:v baseline -level 3.1 -crf 25 -maxrate 1000k -bufsize 1000k    -f mp4 rtmp://localhost:1935/rtmp_hls/$name_HQ640x  \
                            -map '[HD1280x]'    -profile:v main -level 3.1 -crf 19 -maxrate 4000k -bufsize 4000k        -f mp4 rtmp://localhost:1935/rtmp_hls/$name_HD1280x  \
                            -map '[audio]'      -b 128k                                                                 -f mp4 rtmp://localhost:1935/rtmp_hls/$name_audio 2>>/var/www/html/ffmpeg-live-output-$name.log;
这就是mmpeg所引发的错误

ffmpeg version 3.2.4-1~bpo8+1 Copyright (c) 2000-2017 the FFmpeg developers
  built with gcc 4.9.2 (Debian 4.9.2-10)
  configuration: --prefix=/usr --extra-version='1~bpo8+1' --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --enable-gpl --disable-stripping --enable-avresample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --disable-libebur128 --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libmodplug --enable-libmp3lame --enable-libopenjpeg --enable-libopus --enable-libpulse --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-omx --enable-openal --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-libopencv --enable-libx264 --enable-shared
  libavutil      55. 34.101 / 55. 34.101
  libavcodec     57. 64.101 / 57. 64.101
  libavformat    57. 56.101 / 57. 56.101
  libavdevice    57.  1.100 / 57.  1.100
  libavfilter     6. 65.100 /  6. 65.100
  libavresample   3.  1.  0 /  3.  1.  0
  libswscale      4.  2.100 /  4.  2.100
  libswresample   2.  3.100 /  2.  3.100
  libpostproc    54.  1.100 / 54.  1.100
[flv @ 0x55e430547740] video stream discovered after head already parsed
[flv @ 0x55e430547740] audio stream discovered after head already parsed
Input #0, flv, from 'rtmp://localhost:1935/live/directo':
  Metadata:
    Server          : NGINX RTMP (github.com/sergey-dryabzhinsky/nginx-rtmp-module)
    displayWidth    : 1280
    displayHeight   : 720
    fps             : 24
    profile         : 
    level           : 
  Duration: 00:00:00.00, start: 26.023000, bitrate: N/A
    Stream #0:0: Video: h264 (Constrained Baseline), yuv420p(progressive), 1280x720 [SAR 1:1 DAR 16:9], 24.42 fps, 24 tbr, 1k tbn, 48 tbc
    Stream #0:1: Audio: aac (LC), 44100 Hz, mono, fltp
[NULL @ 0x55e4305e0b40] Unable to find a suitable output format for '
'

: Invalid argument
有人能帮我吗


谢谢

不需要换行
\
。Nginx使用正则表达式解析配置:

exec_push ffmpeg line 1
                 line 2
                  ...
                 line n;

你救了我的命!!!这解决了一个问题。然而,现在我有一些其他的“错误”,你可以读到:。。。正如您在上面的代码中所读到的
code
[flv@0x560B9161A0]在头已经解析后发现的视频流[flv@0x560B9161A0]在头已经解析后发现的音频流muxer不支持不可查找的输出无法为输出文件0写入头(编解码器参数不正确?):argumentStream映射无效:
code
尽管流源的格式相同(但一个保存在mp4文件中,另一个通过rtmp流传输),但这些mesages在bash版本中不会出现。@RafaelLinuxUser
-f flv
我决定不使用“filter_complex”,而是按照aergistal所说的将输出更正为“flv”。现在它开始工作了。。。。但是阿布正在做一些奇怪的事情。但这应该是另一个问题。非常感谢。