我使用PHP exec
命令通过avconv linux库转换视频:
exec("avconv -i $mp4FilePath -acodec libvorbis -aq 5 -ac 2 -qmax 25 -threads 2 $webmFilePath > /dev/null &" , $output, $return);
echo PHP_EOL . 'Script output: ' . $return . PHP_EOL;
die;
现在当我运行php脚本时输出为:
developers
built on Mar 16 2015 13:19:10 with gcc 4.8 (Ubuntu 4.8.2-19ubuntu1)
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/var/www/html/domain/videos/avIBS0ZJmjCQBZV7eWqSWSe0u8lBgRCc.mp4':
Metadata:
major_brand : mp42
minor_version : 0
compatible_brands: isommp42
creation_time : 2014-09-08 00:58:51
Duration: 00:02:50.38, start: 0.000000, bitrate: 414 kb/s
Stream #0.0(und): Video: h264 (Constrained Baseline), yuv420p, 640x360 [PAR 1:1 DAR 16:9], 315 kb/s, 24 fps, 24 tbr, 24 tbn, 48 tbc
Stream #0.1(und): Audio: aac, 44100 Hz, stereo, fltp, 95 kb/s
Metadata:
creation_time : 2014-09-08 00:58:51
[libvpx @ 0x17bb220] v1.3.0
Output #0, webm, to '/var/www/html/domain/videos/avIBS0ZJmjCQBZV7eWqSWSe0u8lBgRCc.webm':
Metadata:
major_brand : mp42
minor_version : 0
compatible_brands: isommp42
creation_time : 2014-09-08 00:58:51
encoder : Lavf54.20.4
Stream #0.0(und): Video: libvpx, yuv420p, 640x360 [PAR 1:1 DAR 16:9], q=-1-25, 200 kb/s, 1k tbn, 24 tbc
Stream #0.1(und): Audio: libvorbis, 44100 Hz, stereo, fltp
Metadata:
creation_time : 2014-09-08 00:58:51
Stream mapping:
Stream #0:0 -> #0:0 (h264 -> libvpx)
Stream #0:1 -> #0:1 (aac -> libvorbis)
Press ctrl-c to stop encoding
frame= 4089 fps= 21 q=0.0 Lsize= 7151kB time=170.38 bitrate= 343.8kbits/s
video:5288kB audio:1751kB global headers:4kB muxing overhead 1.538016
当Script运行并且转换成功时,它在最后一行等待没有任何反应并且echo
命令没有执行,我的脚本等待信号停止(我想是这样)。当我按下回车键时,我会回到shell。
为什么返回输出没有打印出来?如何检查视频转换是否成功?
编辑1:
当我删除> /dev/null &
时,我可以看到该脚本已成功结束,并且$return
已返回0
以便成功转换(如果我错误地纠正了我)。但是$output
是一个空数组。虽然我可以看到我在上面展示的shell中的整个输出。我想将整个数据记录到日志文件中。
答案 0 :(得分:0)
首先,我删除了> /dev/null &
,以便在脚本工作完成后能够返回终端。然后在$output
内部获取avconv输出,我将2>&1
附加到脚本的末尾。