Olej писал(а):
Этот tools - ONVIF, но читает real-video он по протоколу RTSP, и ниже изображения потока выписывается для каждого профиля строка источника видеопотока (именно для этого образца камеры):
Код: Выделить всё
rtsp://192.168.1.10:554/user=admin_password=6QNMIQGe_channel=1_stream=0.sdp?real_stream
И подсмотрев строку источника потока, запускаем командой успешную сессию ffmpeg записи в файл:
Код: Выделить всё
olej@ACER:~/2019_WORK/own.WORK/IP-camera$ ffmpeg -i rtsp://192.168.1.10:554/user=admin_password=6QNMIQGe_channel=1_stream=0.sdp?real_stream tmp1.avi
ffmpeg version 4.1.4-1~deb10u1 Copyright (c) 2000-2019 the FFmpeg developers
built with gcc 8 (Debian 8.3.0-6)
configuration: --prefix=/usr --extra-version='1~deb10u1' --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --arch=amd64 --enable-gpl --disable-stripping --enable-avresample --disable-filter=resample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libaom --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libjack --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-libpulse --enable-librsvg --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-lv2 --enable-omx --enable-openal --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-libx264 --enable-shared
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
Input #0, rtsp, from 'rtsp://192.168.1.10:554/user=admin_password=6QNMIQGe_channel=1_stream=0.sdp?real_stream':
Metadata:
title : RTSP Session
Duration: N/A, start: 0.857133, bitrate: N/A
Stream #0:0: Video: h264 (Baseline), yuv420p(progressive), 1280x720, 7 fps, 7 tbr, 90k tbn, 14 tbc
Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> mpeg4 (native))
Press [q] to stop, [?] for help
Output #0, avi, to 'tmp1.avi':
Metadata:
INAM : RTSP Session
ISFT : Lavf58.20.100
Stream #0:0: Video: mpeg4 (FMP4 / 0x34504D46), yuv420p, 1280x720, q=2-31, 200 kb/s, 7 fps, 7 tbn, 7 tbc
Metadata:
encoder : Lavc58.35.100 mpeg4
Side data:
cpb: bitrate max/min/avg: 0/0/200000 buffer size: 0 vbv_delay: -1
[rtsp @ 0x555b7b830740] max delay reached. need to consume packet
[rtsp @ 0x555b7b830740] RTP: missed 31 packets
[h264 @ 0x555b7b876ac0] corrupted macroblock 16 31 (total_coeff=-1)
[h264 @ 0x555b7b876ac0] error while decoding MB 16 31
[h264 @ 0x555b7b876ac0] concealing 1153 DC, 1153 AC, 1153 MV errors in I frame
[h264 @ 0x555b7b95da80] Increasing reorder buffer to 1
frame= 233 fps=7.6 q=31.0 Lsize= 1204kB time=00:00:33.28 bitrate= 296.2kbits/s dup=0 drop=5 speed=1.09x
video:1192kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.935158%
Exiting normally, received signal 2.
Завершаю запись по Ctrl+C, и это нормальное завершение записи с сохранением результата.
Результат:
Код: Выделить всё
olej@ACER:~/2019_WORK/own.WORK/IP-camera$ ls -l *.avi
-rw-r--r-- 1 olej olej 1232496 сен 25 20:15 tmp1.avi
И теперь на этоn tmp1.avi можно напустить любой штатный видео-проигрыватель Linux (на картинке это Totem)...
Код: Выделить всё
olej@ACER:~/2019_WORK/own.WORK/IP-camera$ totem tmp1.avi
(totem:2259): Gtk-WARNING **: 20:50:29.564: Drawing a gadget with negative dimensions. Did you forget to allocate a size? (node slider owner GtkScale)
(totem:2259): GLib-GObject-WARNING **: 20:50:42.990: invalid (NULL) pointer instance
(totem:2259): GLib-GObject-CRITICAL **: 20:50:42.990: g_signal_handlers_disconnect_matched: assertion 'G_TYPE_CHECK_INSTANCE (instance)' failed
(totem:2259): GLib-GObject-WARNING **: 20:50:42.990: invalid (NULL) pointer instance
(totem:2259): GLib-GObject-CRITICAL **: 20:50:42.990: g_signal_handlers_disconnect_matched: assertion 'G_TYPE_CHECK_INSTANCE (instance)' failed
(totem:2259): GLib-GObject-WARNING **: 20:50:42.990: invalid (NULL) pointer instance
(totem:2259): GLib-GObject-CRITICAL **: 20:50:42.990: g_signal_handlers_disconnect_matched: assertion 'G_TYPE_CHECK_INSTANCE (instance)' failed
(totem:2259): Totem-CRITICAL **: 20:50:42.990: totem_object_empty_menu_section: assertion 'TOTEM_IS_OBJECT (totem)' failed