gstreamer 1.0输入选择器

时间:2019-02-22 12:51:17

标签: gstreamer gstreamer-1.0

我想在RTSP流和测试流之间切换。 我使用输入选择器和以下管道:

input-selector name=selector ! rtph264depay ! h264parse ! matroskamux \
streamable=false min-index-interval=100000 ! \
filesink location=test.mkv videotestsrc ! \
video/x-raw, width=1024, height=768, framerate=30/1, clock-rate=90000 ! \
x264enc ! rtph264pay ! selector.sink_0 rtspsrc name=rtspsrc \
location=rtsp://admin:admin@192.168.88.231:554/h264 retry=100 \
udp-buffer-size=30000000 latency=200 caps="application/x-rtp, \
media=(string)video, clock-rate=(int)90000, encoding-name=(string)H264" !  \
selector.sink_1

我编写了python代码,每5秒切换一次源。但是只有测试流才会写入文件。我还在日志中看到警告

0:00:00.353575129 13560      0x23f5540 WARN                 basesrc gstbasesrc.c:2948:gst_base_src_loop:<udpsrc3> error: Internal data flow error.
0:00:00.353602076 13560      0x23f5540 WARN                 basesrc gstbasesrc.c:2948:gst_base_src_loop:<udpsrc3> error: streaming task paused, reason not-linked (-1)
0:00:02.177975961 13560      0x23f2ed0 WARN                 x264enc :0::<x264enc0> VBV underflow (frame 298, -14405 bits)

0:00:02.338993437 13560      0x23f2ed0 WARN                 x264enc :0::<x264enc0> VBV underflow (frame 328, -4872 bits)

如何解决?

当我用fakesink替换selector.sink_0时,RTSP流被正常记录。显然,问题是由切换流引起的。

0 个答案:

没有答案