Почему я получаю ошибку ввода / вывода с testsrc ffmpeg? - PullRequest
0 голосов
/ 18 декабря 2018

Я пытаюсь написать интеграционный тест, который на самом деле требует потоковой передачи по RTMP стороннему сервису. Как создать тестовый поток RTMP с помощью команды ffmpeg? кажется правильным ответом, однако я не могу заставить его работать.

В качестве базовой линии, без RTMP, ffmpeg -f lavfi -i testsrc -t 30 -pix_fmt yuv420p test.mp4 работает.

ffmpeg -f lavfi -i testsrc -t 30 -pix_fmt yuv420p -f flv rtmp://mylocation выдает мне ошибку rtmp://mylocation: Input/output error

Я должен отметить, что URL-адрес действителен, в противном случае я получаю сообщение об ошибке, в котором говорится, что не удается открыть соединение.

Я тоже пытался ffmpeg -f lavfi -i testsrc -pix_fmt yuv420p -f flv rtmp://mylocatiom.Я читал, что если вы не предоставите время, оно будет длиться вечно, и я подумал, что оно может понадобиться для потока RTMP.Я получил ту же ошибку.

Вот полный вывод из последней попытки, с добавленными параметрами, предложенными @Gyan ниже, вместе с подробным ведением журнала.

ffmpeg -loglevel verbose -f lavfi -i testsrc -pix_fmt yuv420p -f flv -c:v libx264 -g 50 rtmp://myhost:1935/identifier
ffmpeg version 4.1 Copyright (c) 2000-2018 the FFmpeg developers
  built with Apple LLVM version 10.0.0 (clang-1000.11.45.5)
  configuration: --prefix=/usr/local/Cellar/ffmpeg/4.1 --enable-shared --enable-pthreads --enable-version3 --enable-hardcoded-tables --enable-avresample --cc=clang --host-cflags= --host-ldflags= --enable-ffplay --enable-gpl --enable-libmp3lame --enable-libopus --enable-libsnappy --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-libxvid --enable-lzma --enable-opencl --enable-videotoolbox
  libavutil      56. 22.100 / 56. 22.100
  libavcodec     58. 35.100 / 58. 35.100
  libavformat    58. 20.100 / 58. 20.100
  libavdevice    58.  5.100 / 58.  5.100
  libavfilter     7. 40.101 /  7. 40.101
  libavresample   4.  0.  0 /  4.  0.  0
  libswscale      5.  3.100 /  5.  3.100
  libswresample   3.  3.100 /  3.  3.100
  libpostproc    55.  3.100 / 55.  3.100
[Parsed_testsrc_0 @ 0x7fddf34022c0] size:320x240 rate:25/1 duration:-1.000000 sar:1/1
Input #0, lavfi, from 'testsrc':
  Duration: N/A, start: 0.000000, bitrate: N/A
    Stream #0:0: Video: rawvideo, 1 reference frame (RGB[24] / 0x18424752), rgb24, 320x240 [SAR 1:1 DAR 4:3], 25 tbr, 25 tbn, 25 tbc
[tcp @ 0x7fddf3404880] Starting connection attempt to {theIP} port 1935
[tcp @ 0x7fddf3404880] Successfully connected to {theIP} port 1935
rtmp://myhost:1935/identifier: Input/output error

Добавлено обновление до debugеще несколько таких данных до ошибки:

[tcp @ 0x7fc4e1601a00] Starting connection attempt to 34.224.30.155 port 1935
[tcp @ 0x7fc4e1601a00] Successfully connected to 34.224.30.155 port 1935
[rtmp @ 0x7fc4e1411200] Handshaking...
[rtmp @ 0x7fc4e1411200] Type answer 3
[rtmp @ 0x7fc4e1411200] Server version 3.0.1.1
[rtmp @ 0x7fc4e1411200] Proto = rtmp, path = /identifier, app = identifier, fname = 
[rtmp @ 0x7fc4e1411200] Window acknowledgement size = 2500000
[rtmp @ 0x7fc4e1411200] Max sent, unacked = 2500000
[rtmp @ 0x7fc4e1411200] New incoming chunk size = 4096
[rtmp @ 0x7fc4e1411200] Releasing stream...
[rtmp @ 0x7fc4e1411200] FCPublish stream...
[rtmp @ 0x7fc4e1411200] Creating stream...
[rtmp @ 0x7fc4e1411200] Sending publish command for ''
rtmp://myhost:1935/identifier: Input/output error

Sending publish command for '' подозрительно, но не уверен, что с этим делать.

Ответы [ 2 ]

0 голосов
/ 19 декабря 2018

rtmp: // localhost: 1935 / app / streamkey обычно является конечной точкой для потоковой передачи на основе rtmp ... в ваших примерах вы показываете только rtmp: // host: 1935 / app, и в зависимости от того, какой сервис вы публикуетек, может не работать.Тем не менее, я проверил это на ванильной установке потокового движка wowza на rtmp: // wowza: 1935 / app, и на самом деле это сработало, и я смог просмотреть поток в той же конечной точке с помощью ffplay

0 голосов
/ 18 декабря 2018

Я не заметил - fname пусто в выводе отладки.Я пропустил имя потока / ключ.Мне нужно было сделать rtmp://myhost:1935/identifier/streamkey.Журналы показали, что мое имя потока было пустым.Я копировал, вставляя URL-адрес без ключа, так как я совершенно случайно забыл об этом - моя OBS настроена так, чтобы всегда иметь один и тот же ключ, но URL-адрес меняется, и это было тем, что я вставлял снова и снова.

...