测试环境:
server:srs2client:librestreaming / yasea srs 配置 dvr录制24分钟flv文件。e:\flv$ lltotal 518312drwxr-xr-x 1 Administrator 197121 0 七月 24 11:55 ./drwxr-xr-x 1 Administrator 197121 0 七月 24 11:55 ../-rw-r--r-- 1 Administrator 197121 530743006 七月 22 18:17 07-22-17.52.30.193.flv
pc上使用最新版本vlc、potplayer播放,均显示35分钟;使用mpc-be播放,显示24分钟。
而使用mediainfo查看显示24分钟,实际上确实是24分钟。和srs群好友们讨论了一下,是srs写flv文件时metadata的问题。可以通过添加配置time_jitter full;修复metadata的时间戳。e:\flv$ flvtool2.exe -P 07-22-17.52.30.193.flv---e:/flv/07-22-17.52.30.193.flv: audiodatarate: 64 framerate: 25 service: SRS/2.0.223(ZhouGuowen) videocodecid: 7 audiosamplerate: 44100 height: 720 filesize: 530743006 duration: 2103.602 audiocodecid: 10 width: 1280...
很明显duration: 2103.602 这个字段对应的是35分钟是错误的。
既然用到了flvtool2 那么就展示一下本次使用的工具。e:\flv$ flvflvmdi.exe flvmeta.exe flvtool2.exe
1. 测试flvmdi
e:\flv$ cp 07-22-17.52.30.193.flv test01.flve:\flv$ flvmdi.exe /vManitu Group FLV MetaData Injector 2.96Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdi usage: flvmdi inFile [outFile] [/v] [/s] [/x] [/k] [/l] [/eExtraData] [/p]e:\flv$ flvmdi.exe test01.flv testflvmdi.flvManitu Group FLV MetaData Injector 2.96Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdiCompleted.e:\flv$ flvmdi.exe /k test01.flv testkflvmdi.flvManitu Group FLV MetaData Injector 2.96Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdiCompleted.e:\flv$ flvmdi.exe test01.flvManitu Group FLV MetaData Injector 2.96Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdiCompleted.e:\flv$ lltotal 2073252drwxr-xr-x 1 Administrator 197121 0 七月 24 13:44 ./drwxr-xr-x 1 Administrator 197121 0 七月 24 11:55 ../-rw-r--r-- 1 Administrator 197121 530743006 七月 22 18:17 07-22-17.52.30.193.flv-rw-r--r-- 1 Administrator 197121 530764769 七月 24 13:39 testkflvmdi.flv-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:48 test01.flv-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:38 testflvmdi.flv
/k是把keyframes写入metadata,所以生成的文件比其他两个命令生成的文件大。
三个命令均耗时13s,均完成修复。播放器均可以识别正确的时长。2. 测试flvmeta
e:\flv
$ cp 07-22-17.52.30.193.flv test02.flve:\flv
$ flvmeta.exe -Vflvmeta 1.2.1Copyright (C) 2007-2016 Marc Noirot <marc.noirot AT gmail.com>
This is free software; see the source for copying conditions. There is NOwarranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.e:\flv
$ flvmeta.exe -f test02.flv testfflvmeta.flv e:\flv $ flvmeta.exe -t test02.flv testtflvmeta.flv e:\flv $ flvmeta.exe -U test02.flv testUflvmeta.flv e:\flv$ flvmeta.exe -U test02.flve:\flv
$ lltotal 4146564drwxr-xr-x 1 Administrator 197121 0 七月 24 13:57 ./drwxr-xr-x 1 Administrator 197121 0 七月 24 11:55 ../-rw-r--r-- 1 Administrator 197121 530743006 七月 22 18:17 07-22-17.52.30.193.flv-rw-r--r-- 1 Administrator 197121 530764769 七月 24 13:39 flvmdi.flv-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:48 test01.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:59 test02.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:55 testfflvmeta.flv-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:38 testflvmdi.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:56 testtflvmeta.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:57 testUflvmeta.flvflvmeta 命令行耗时2s 生成的文件大小一致。
均完成修复。播放器均可以识别正确的时长。3. 测试flvtool2
e:\flv
$ flvtool2 -VFLVTool2 1.0.6e:\flv$ flvtool2.exe -U test03.flv testflvtool.flvERROR: undefined method `[]' for #<Object:0x23b5fcc>ERROR: flv/stream.rb:138:in `add_meta_tag'ERROR: flvtool2/base.rb:184:in `add_meta_data_tag'ERROR: flvtool2/base.rb:137:in `update'ERROR: flvtool2/base.rb:47:in `send'ERROR: flvtool2/base.rb:47:in `execute!'ERROR: flvtool2/base.rb:46:in `each'ERROR: flvtool2/base.rb:46:in `execute!'ERROR: flvtool2/base.rb:239:in `process_files'ERROR: flvtool2/base.rb:225:in `each'ERROR: flvtool2/base.rb:225:in `process_files'ERROR: flvtool2/base.rb:44:in `execute!'ERROR: flvtool2.rb:168:in `execute!'ERROR: flvtool2.rb:228e:\flv
$ ll testflvtool.flv-rw-r--r-- 1 Administrator 197121 0 七月 24 14:13 testflvtool.flvflvtool2 在执行30s以后报错,生成的文件大小为0.
我之前成功过其他文件,这个处理时间是这样的,估计我的文件错误超出了flvtool2的处理能力。4. 对比ffmpeg
e:\flv$ ffmpeg -i test04.flv -acodec copy -vcodec copy -f flv testffmpeg.flve:\flv$ ffmpeg -i test04.flv -acodec copy -vcodec copy -f mp4 testffmpeg.mp4e:\flv$ lltotal 6219296drwxr-xr-x 1 Administrator 197121 0 七月 24 14:23 ./drwxr-xr-x 1 Administrator 197121 0 七月 24 11:55 ../-rw-r--r-- 1 Administrator 197121 530743006 七月 22 18:17 07-22-17.52.30.193.flv-rw-r--r-- 1 Administrator 197121 530764769 七月 24 13:39 flvmdi.flv-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:48 test01.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:59 test02.flv-rw-r--r-- 1 Administrator 197121 530743006 七月 24 14:04 test03.flv-rw-r--r-- 1 Administrator 197121 530743006 七月 24 14:19 test04.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:55 testfflvmeta.flv-rw-r--r-- 1 Administrator 197121 530743115 七月 24 14:20 testffmpeg.flv-rw-r--r-- 1 Administrator 197121 530246130 七月 24 14:23 testffmpeg.mp4-rw-r--r-- 1 Administrator 197121 530743230 七月 24 13:38 testflvmdi.flv-rw-r--r-- 1 Administrator 197121 0 七月 24 14:13 testflvtool.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:56 testtflvmeta.flv-rw-r--r-- 1 Administrator 197121 530764891 七月 24 13:57 testUflvmeta.flv
ffmpeg两条命令均耗时3s 播放器均可以识别正确的时长。发现生成mp4文件大小比原文件还小一些。
另外,在一些metadata错误信息存在的情况下,使用ffmpeg比其他几个修复的更好。
还有一个工具yamdi 未测试。