Форум русскоязычного сообщества Ubuntu


Получить помощь и пообщаться с другими пользователями Ubuntu можно
на irc канале #ubuntu-ru в сети Freenode
и в Jabber конференции ubuntu@conference.jabber.ru

Автор Тема: Проблемы с потоком Ffmpeg Udp -> RTMP  (Прочитано 2359 раз)

0 Пользователей и 1 Гость просматривают эту тему.

Оффлайн EntoniSarov

  • Автор темы
  • Новичок
  • *
  • Сообщений: 2
    • Просмотр профиля
Проблемы с потоком Ffmpeg Udp -> RTMP
« : 13 Ноября 2015, 22:53:17 »
Обратившим внимание,добрый вечер! :coolsmiley:

Появилась проблема с потоком.Схема такая:

#!/bin/sh
exec 2>&1

in="udp://127.0.0.1:10078?reuse=1"
out1="rtmp://127.0.0.1:1935/appname/test.sdp"



exec /usr/bin/ffmpeg -re -i $in -maxrate 3000k -bufsize 256000 -vcodec libx264 -s 1024x576 -x264opts keyint=50 -keyint_min 25 -acodec libmp3lame -ar 44100 -deinterlace -f flv $out1

То,что уже пробовал менять,но не помогло:
#exec /usr/bin/ffmpeg -re -i $in -bufsize 256000 -vcodec copy -acodec libmp3lame -ar 44100 -deinterlace -f flv $out1
#exec /usr/bin/ffmpeg -re -i $in -vcodec libx264 -s 1024x576 -x264opts keyint=50 -keyint_min 25 -acodec libfaac -deinterlace -f flv $out1
#exec /usr/bin/ffmpeg -re -i $in -vcodec libx264 -acodec libfaac -deinterlace -f flv $out1

Сначала поток идёт отлично.Никаких ошибок.Но примерно через час начинает ёкать звук.И ещё через какое-то время(~полчаса ) Звук либо пропадает совсем,либо начинает очень сильно искажаться,при этом всём пропадает видео)

Ffprobe потока показывает,что звук есть,видео есть,от ffprobe только запущенного потока не отличается.

Снял tcpdump входящего udp потока в момент проблемы(udp://127.0.0.1:10078?reuse=1),собрал стрим,никаких проблем со звуком или видео,то есть проблема именно в ffmpeg.

ffprobe исходного:
ffprobe udp://127.0.0.1:10078?reuse=1

ffprobe version 2.3 Copyright (c) 2007-2014 the FFmpeg developers
  built on Jul 25 2014 17:34:36 with gcc 4.4.6 (GCC) 20120305 (Red Hat 4.4.6-4)
  configuration: --prefix=/usr --libdir=/usr/lib64 --shlibdir=/usr/lib64 --mandir=/usr/share/man --incdir=/usr/include --disable-avisynth --extra-cflags='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -fPIC' --enable-avfilter --enable-libmp3lame --enable-libfaac --enable-libvorbis --enable-libx264 --enable-gpl --enable-nonfree --enable-postproc --enable-pthreads --enable-shared --enable-swscale --enable-vdpau --enable-version3
  libavutil      52. 92.100 / 52. 92.100
  libavcodec     55. 69.100 / 55. 69.100
  libavformat    55. 48.100 / 55. 48.100
  libavdevice    55. 13.102 / 55. 13.102
  libavfilter     4. 11.100 /  4. 11.100
  libswscale      2.  6.100 /  2.  6.100
  libswresample   0. 19.100 /  0. 19.100
  libpostproc    52.  3.100 / 52.  3.100
[h264 @ 0x26c7300] non-existing PPS 0 referenced
    Last message repeated 1 times
[h264 @ 0x26c7300] decode_slice_header error
[h264 @ 0x26c7300] no frame!
[h264 @ 0x26c7300] non-existing PPS 0 referenced
    Last message repeated 1 times
[h264 @ 0x26c7300] decode_slice_header error
[h264 @ 0x26c7300] no frame!
Input #0, mpegts, from 'udp://127.0.0.1:10078?reuse=1':
  Duration: N/A, start: 22906.090311, bitrate: 192 kb/s
  Program 2
    Stream #0:0[0x1f4]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(tv, bt470bg), 720x576 [SAR 64:45 DAR 16:9], 25 fps, 25 tbr, 90k tbn, 50 tbc
    Stream #0:1[0x2bc](RUS): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, s16p, 192 kb/s


Пробовал менять размер буффера,увеличивать,уменьшать. Не помогло. Пробовал менять кодек аудио,тоже никаких изменений,через час-другой от стрима остаётся только лагающий звук.Картинки нет.

Что пишет ffmpeg при публикации:

Input #0, mpegts, from 'udp://127.0.0.1:10078?reuse=1':
  Duration: N/A, start: 23271.418311, bitrate: 192 kb/s
  Program 2
    Stream #0:0[0x1f4]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(tv, bt470bg), 720x576 [SAR 64:45 DAR 16:9], 25 fps, 25 tbr, 90k tbn, 50 tbc
    Stream #0:1[0x2bc](RUS): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz, stereo, s16p, 192 kb/s
[libx264 @ 0x22e2780] using SAR=1/1
[libx264 @ 0x22e2780] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX
[libx264 @ 0x22e2780] profile High, level 3.1
[libx264 @ 0x22e2780] 264 - core 130 - H.264/MPEG-4 AVC codec - Copyleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=36 lookahead_threads=4 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=50 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
Output #0, flv, to 'rtmp://pub1.rtmp.s01.l.novoetv.cdnvideo.ru/novoetv/test.sdp?auth=140812jDNr':
  Metadata:
    encoder         : Lavf55.48.100
    Stream #0:0: Video: h264 (libx264) ([7][0][0][0] / 0x0007), yuv420p, 1024x576 [SAR 1:1 DAR 16:9], q=-1--1, 25 fps, 1k tbn, 25 tbc
    Metadata:
      encoder         : Lavc55.69.100 libx264
    Stream #0:1(RUS): Audio: aac (libfaac) ([10][0][0][0] / 0x000A), 48000 Hz, stereo, s16, 128 kb/s
    Metadata:
      encoder         : Lavc55.69.100 libfaac
Stream mapping:
  Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
  Stream #0:1 -> #0:1 (mp2 (native) -> aac (libfaac))
Press [q] to stop, [?] for help
[mpegts @ 0x2239e00] PES packet size mismatchme=00:01:04.29 bitrate=1155.5kbits/s
[mp2 @ 0x2258680] Header missing
Error while decoding stream #0:1: Invalid data found when processing input
[h264 @ 0x5486840] left block unavailable for requested intra mode at 0 12
[h264 @ 0x5486840] error while decoding MB 0 12, bytestream 17756
[h264 @ 0x5486840] concealing 1129 DC, 1129 AC, 1129 MV errors in I frame
[h264 @ 0x510ec00] Reference 4 >= 3
[h264 @ 0x510ec00] error while decoding MB 5 15, bytestream 1702
[h264 @ 0x510ec00] concealing 989 DC, 989 AC, 989 MV errors in B frame
[h264 @ 0x51a2b60] left block unavailable for requested intra4x4 mode -1 at 0 2/s
[h264 @ 0x51a2b60] error while decoding MB 0 2, bytestream 1075
[h264 @ 0x51a2b60] concealing 1579 DC, 1579 AC, 1579 MV errors in I frame
frame= 2938 fps= 22 q=28.0 size=   19379kB time=00:02:00.75 bitrate=1314.7kbits/s

Поймал,когда ёкает звук,ошибка:
Error while decoding stream #0:1: Invalid data found when processing input

 

Страница сгенерирована за 0.018 секунд. Запросов: 22.