avconv: Salvando o processo MP4 trava

1

não tenho certeza se devo postar isso em askubuntu ou stackoverflow.

Estou configurando um site no qual os usuários podem enviar vídeos e compartilhá-los. Estou usando o avconv para reduzir o tamanho do vídeo e salvá-lo duas vezes, uma vez como um mp4 e novamente como um webm.

Fazendo upload de um .MOV de um telefone, a conversão de vídeo é rápida e gerenciável.

Fazendo upload de um .mp4 de um Samsung Galaxy S3, a conversão de vídeo para webm também é rápida. Mas, a conversão para outro mp4 leva FOREVER - literalmente horas. Por quê? Alguém é capaz de esclarecer o problema?

Minha saída do avconv está abaixo.

avconv -i /path/video.mp4 -c:v libx264 -vf transpose=1,transpose=1,transpose=1 -s 640x480 /path/video-out.mp4
avconv version 0.8.17-4:0.8.17-0ubuntu0.12.04.1, Copyright (c) 2000-2014 the Libav developers
built on Mar 16 2015 13:26:50 with gcc 4.6.3
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/path/video.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 0
    compatible_brands: isom3gp4
    creation_time   : 2015-09-04 15:08:21
Duration: 00:00:07.76, start: 0.000000, bitrate: 11756 kb/s
Stream #0.0(eng): Video: h264 (Constrained Baseline), yuv420p, 1280x720, 11967 kb/s, 29.81 fps, 90k tbr, 90k tbn, 180k tbc
Metadata:
  creation_time   : 2015-09-04 15:08:21
Stream #0.1(eng): Audio: aac, 48000 Hz, stereo, s16, 119 kb/s
Metadata:
  creation_time   : 2015-09-04 15:08:21
File '/path/video-out.mp4' already exists. Overwrite ? [y/N] y
[buffer @ 0xc3d580] w:1280 h:720 pixfmt:yuv420p
[scale @ 0xc3dac0] w:1280 h:720 fmt:yuv420p -> w:640 h:480 fmt:yuv420p flags:0x4
[transpose @ 0xc3e280] w:640 h:480 dir:1 -> w:480 h:640 rotation:clockwise vflip:0
[transpose @ 0xc3e7c0] w:480 h:640 dir:1 -> w:640 h:480 rotation:clockwise vflip:0
[transpose @ 0xc3ede0] w:640 h:480 dir:1 -> w:480 h:640 rotation:clockwise vflip:0
[libx264 @ 0xc2b100] MB rate (108000000) > level limit (983040)
[libx264 @ 0xc2b100] using cpu capabilities: MMX2 SSE2Fast SSSE3 FastShuffle SSE4.2 AVX
[libx264 @ 0xc2b100] profile Main, level 5.1
[libx264 @ 0xc2b100] 264 - core 120 r2151 a3f4407 - H.264/MPEG-4 AVC codec - Copyleft 2003-2011 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x1:0x111 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=0 me_range=16 chroma_me=1 trellis=1 8x8dct=0 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=3 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=0 b_adapt=1 b_bias=0 direct=1 weightb=0 open_gop=1 weightp=2 keyint=250 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.25 aq=1:1.00
Output #0, mp4, to '/path/video-out.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 0
    compatible_brands: isom3gp4
    creation_time   : 2015-09-04 15:08:21
    encoder         : Lavf53.21.1
    Stream #0.0(eng): Video: libx264, yuv420p, 480x640, q=-1--1, 180k tbn, 90k tbc
    Metadata:
      creation_time   : 2015-09-04 15:08:21
    Stream #0.1(eng): Audio: libvo_aacenc, 48000 Hz, stereo, s16, 200 kb/s
    Metadata:
      creation_time   : 2015-09-04 15:08:21
Stream mapping:
  Stream #0:0 -> #0:0 (h264 -> libx264)
  Stream #0:1 -> #0:1 (aac -> libvo_aacenc)
Press ctrl-c to stop encoding

Veja um exemplo de saída de quadros:

frame=124398 fps=142 q=33.0 size=   16885kB time=1.38 bitrate=100110.2kbits/s dup=124356 drop=0

Eu tive o processo em execução o tempo todo em que estive escrevendo esta pergunta, e até agora está feito ... 22 quadros.

Qual poderia ser o problema?

EDIT: E isso não é um arquivo enorme, também. É algo como 11 megas, 1280 x 720.

EDITAR NOVAMENTE: Desde que postou a pergunta, o processo começou a ser interrompido e não passa do quadro ... 32 ou mais.

EDIT NOVAMENTE: Reinicialize o servidor caso a CPU esteja apenas sobrecarregada com outros processos. Não há dados, mesmo problema.

    
por CGriffin 04.09.2015 / 17:53

1 resposta

3

Obter ffmpeg

avconv e a falsificação " ffmpeg " do Libav estão com bugs. Obtenha uma compilação ffmpeg recente. Você tem 4 opções principais:

  • Faça o download de uma versão estática . Fácil e rápido, mas não pode ser personalizado e não suporta material não livre, como alguns codificadores. Não interferindo no sistema.

  • Compile . Você pode seguir uma cópia & amp; colar o guia passo a passo. Não irá interferir com o sistema.

  • Use um PPA (para usuários confiáveis).

  • Atualize para o Ubuntu Vivid 15.04 ou mais recente. Vivid contém ffmpeg 2.5.8 do FFmpeg. No entanto, o desenvolvimento do FFmpeg é tão ativo que você ainda pode querer usar uma compilação ou compilação estática.

Uso de construção estática

Depois de baixá-lo e extraí-lo, você pode usá-lo assim (supondo que esteja no diretório Downloads em sua casa).

  • Inclua o caminho completo:

    /home/user/Downloads/ffmpeg -i …
    

    ou

    ~/Downloads/ffmpeg -i …
    
  • Ou navegue até o diretório que contém ffmpeg e execute:

    ./ffmpeg -i …
    
  • Ou mova-o para um diretório em PATH . O diretório ~/bin é um desses locais (assumindo que o mesmo usuário estará executando ffmpeg ).

    1. Crie um diretório chamado bin em seu diretório inicial.
    2. Mova o binário ffmpeg para ~/bin .
    3. Execute source ~/.profile ou simplesmente efetue logout e efetue login.
    4. Agora é só executar o comando ffmpeg em qualquer terminal e ele deve funcionar.
por LordNeckbeard 04.09.2015 / 21:16