FFServer streaming H.264 da Logitech C920

2

Estou tendo problemas para tentar implementar uma transmissão ao vivo da Web da minha webcam Logitech C920 com codificação H.264 usando ffmpeg / ffserver .

Aqui está o arquivo de configuração que estou usando para o ffserver :

# Port on which the server is listening. You must select a different
# port from your standard HTTP web server if it is running on the same
# computer.
Port 8090

# Address on which the server is bound. Only useful if you have
# several network interfaces.
BindAddress 0.0.0.0

# Number of simultaneous HTTP connections that can be handled. It has
# to be defined *before* the MaxClients parameter, since it defines the
# MaxClients maximum limit.
MaxHTTPConnections 2000

# Number of simultaneous requests that can be handled. Since FFServer
# is very fast, it is more likely that you will want to leave this high
# and use MaxBandwidth, below.
MaxClients 1000

# This the maximum amount of kbit/sec that you are prepared to
# consume when streaming to clients.
MaxBandwidth 1000

# Access log file (uses standard Apache log file format)
# '-' is the standard output.
CustomLog -

##################################################################
# Definition of the live feeds. Each live feed contains one video
# and/or audio sequence coming from an ffmpeg encoder or another
# ffserver. This sequence may be encoded simultaneously with several
# codecs at several resolutions.

<Feed feed.ffm>

# You must use 'ffmpeg' to send a live feed to ffserver. In this
# example, you can type:
#

File /tmp/feed.ffm
FileMaxSize 100M

# You could specify
# ReadOnlyFile /saved/specialvideo.ffm
# This marks the file as readonly and it will not be deleted or updated.

# Only allow connections from localhost to the feed.
ACL allow 127.0.0.1

</Feed>


##################################################################
# Now you can define each stream which will be generated from the
# original audio and video stream. Each format has a filename (here
# 'test1.mpg'). FFServer will send this stream when answering a
# request containing this filename.

<stream stream.mp4>

Feed feed.ffm
Format mp4

# Audio settings
NoAudio

# Video Settings
#VideoSize 1280x720                      # Video resolution
#VideoFrameRate 30                      # Video FPS
#AVOptionVideo flags +global_header          # Parameters passed to encoder
#AVOptionVideo cpu-used 0
#AVOptionVideo qmin 10
#AVOptionVideo qmax 42
#AVOptionVideo quality good
PreRoll 0
StartSendOnKey
#VideoBitRate 400                      # Video bitrate

</stream>

# Server status

<Stream stat.html>
Format status

# Only allow local people to get the status
ACL allow localhost
ACL allow 192.168.0.0 192.168.255.255

</Stream>

E aqui está o comando que estou emitindo por meio da linha de comando e a respectiva saída:

$ ffmpeg -s 1280x720 -f video4linux2 -r 30 -vcodec h264 -re -i /dev/video0 \
    -copyinkf -codec copy h**p://localhost:8090/feed.ffm

ffmpeg version N-67036-g04a4fb8 Copyright (c) 2000-2014 the FFmpeg developers
  built on Oct 20 2014 17:39:50 with gcc 4.8 (Ubuntu 4.8.2-19ubuntu1)
  configuration: --enable-gpl --enable-libx264
  libavutil      54. 10.100 / 54. 10.100
  libavcodec     56.  8.102 / 56.  8.102
  libavformat    56.  9.101 / 56.  9.101
  libavdevice    56.  1.100 / 56.  1.100
  libavfilter     5.  2.100 /  5.  2.100
  libswscale      3.  1.101 /  3.  1.101
  libswresample   1.  1.100 /  1.  1.100
  libpostproc    53.  3.100 / 53.  3.100
Input #0, video4linux2,v4l2, from '/dev/video0':
  Duration: N/A, start: 12614.859199, bitrate: N/A
    Stream #0:0: Video: h264 (Constrained Baseline), yuvj420p(pc), 1280x720 [SAR 1:1 DAR 16:9], -5 kb/s, 30 fps, 30 tbr, 1000k tbn, 60 tbc
Output #0, ffm, to 'h**p://localhost:8090/feed.ffm':
  Metadata:
    creation_time   : now
    encoder         : Lavf56.9.101
    Stream #0:0: Video: h264, yuvj420p, 1280x720 [SAR 1:1 DAR 16:9], q=2-31, -5 kb/s, 30 fps, 1000k tbn, 30 tbc
Stream mapping:
  Stream #0:0 -> #0:0 (copy)
Press [q] to stop, [?] for help
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 0, current: -166263; changing to 1. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 1, current: -134365; changing to 2. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 2, current: -102381; changing to 3. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 3, current: -66434; changing to 4. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 4, current: -34548; changing to 5. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 5, current: -2645; changing to 6. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 232857, current: 138514; changing to 232858. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 232858, current: 167942; changing to 232859. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 232859, current: 197415; changing to 232860. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 232860, current: 227037; changing to 232861. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 997959, current: 938599; changing to 997960. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 997960, current: 995052; changing to 997961. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 1240745, current: 1232841; changing to 1240746. This may result in incorrect timestamps in the output file.
[ffm @ 0x28c7ea0] Non-monotonous DTS in output stream 0:0; previous: 1293561, current: 1282157; changing to 1293562. This may result in incorrect timestamps in the output file.
frame=   69 fps= 34 q=-1.0 Lsize=     912kB time=00:00:02.01 bitrate=3702.1kbits/s

Quando tento reproduzir o fluxo com o VLC, por exemplo - vlc h**p://localhost:8090/stream.mp4 - recebo o seguinte erro:

[00007f5234003948] core stream error: cannot pre fill buffer

E também não posso assistir ao stream no lado do navegador da Web.

Alguém poderia me dar uma dica sobre isso?

    
por Ricardo Frederico Leote Mota 24.10.2014 / 12:32

2 respostas

1

Eu tenho jogado com a câmera ffmpeg e logitech C920 no meu roteador OpenWRT (TP-Link WDR3600, CPU MIPS a 560 MHz) usando sua configuração. Em 640x480 e acima do meu sistema não funcionou de forma confiável. Eu tentei lançar o ffmpeg sozinho sem transcodificação (meu roteador não é capaz de qualquer transcodificação, CPU fraca demais) e assistir o stream com o VLC:

ffmpeg -f v4l2 -input_format h264 -video_size 320x400 -i /dev/video0 -copyinkf -codec copy -f mpegts udp://192.168.1.100:20000

Em 640x480 o vídeo estava ficando distorcido, resoluções de 800x600 ou melhores não funcionavam, com o ffmpeg dando toneladas dessas mensagens "Non-monotonous DTS ...". 320x400 estava OK. A saída de vídeo MJPEG funcionou muito melhor e eu consegui executar o C920 a 1920x1080 e 15 fps, com taxas de dados superiores a 50 Mbit / s, mas o MJPEG também não estava 100% livre de erros. Parece que a câmera tem alguns problemas no H264, pelo menos com o ffmpeg. No H264, a câmera deu uma taxa de bits constante de cerca de 3,2 Mbit / s, não importando qual resolução / taxa de quadros eu estivesse tentando definir.

Mas voltando aos negócios. Para obter o h264 trabalhando com o ffserver, modifiquei sua seção Feed, alterando "Format" e comentando StartSendOnKey na seção "stream":

Format mpegts
...
#StartSendOnKey

adicionando a string "Launch" do ffmpeg na seção "Feed":

Launch ffmpeg -f v4l2 -input_format h264 -video_size 320x400 -i /dev/video0 -copyinkf -codec copy

e alterando a MaxBandwidth para 50000

Eu usei o vlc como software cliente.

    
por 08.12.2014 / 02:04
0

Estou usando essa configuração e está funcionando bem arquivo server.conf:

HTTPPort 1235
RTSPPort 1234
HTTPBindAddress 0.0.0.0
MaxHTTPConnections 2000
MaxClients 1000
MaxBandwidth 100000
#CustomLog –
#########################################
## usb cam:  logitec c920
#########################################
<Feed camfeed.ffm>
    File /tmp/camfeed.ffm
    FileMaxSize 500K
    #allow only localhost to publish feed
    ACL allow 192.168.1.149
</Feed>


<Stream usbcam.mov>
    Feed camfeed.ffm
    Format rtp

    #cam defaults:
    VideoSize 800x600
    VideoFrameRate 24
    VideoBitRate 400
    VideoCodec libx264

    NoLoop
    NoAudio
    Preroll 0
    StartSendOnKey
</Stream>

######################################
# ffmpeg cmd:
######################################
# ffmpeg -y -s 800x600 -f video4linux2 -i /dev/video0 -c:v libx264 -tune zerolatency -an http://192.168.1.149:1235/camfeed.ffm
    
por 04.07.2016 / 10:29