srs2录制flv文件metadata不准确

测试环境:
server:srs2
client:librestreaming / yasea
srs 配置 dvr
录制24分钟flv文件。

e:\flv
$ ll
total 518312
drwxr-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
$ flv
flvmdi.exe    flvmeta.exe   flvtool2.exe

1. 测试flvmdi

e:\flv
$ cp 07-22-17.52.30.193.flv test01.flv

e:\flv
$ flvmdi.exe /v

Manitu Group FLV MetaData Injector 2.96
Copyright (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.flv

Manitu Group FLV MetaData Injector 2.96
Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdi

Completed.

e:\flv
$ flvmdi.exe /k test01.flv testkflvmdi.flv

Manitu Group FLV MetaData Injector 2.96
Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdi

Completed.

e:\flv
$ flvmdi.exe test01.flv

Manitu Group FLV MetaData Injector 2.96
Copyright (c) 2004-2010 Manitu Group. http://www.buraks.com/flvmdi

Completed.

e:\flv
$ ll
total 2073252
drwxr-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.flv

e:\flv
$ flvmeta.exe -V
flvmeta 1.2.1

Copyright (C) 2007-2016 Marc Noirot <marc.noirot AT gmail.com>
This is free software; see the source for copying conditions. There is NO
warranty; 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.flv

e:\flv
$ ll
total 4146564
drwxr-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.flv

flvmeta 命令行耗时2s 生成的文件大小一致。
均完成修复。播放器均可以识别正确的时长。

3. 测试flvtool2

e:\flv
$ flvtool2 -V
FLVTool2 1.0.6
e:\flv
$ flvtool2.exe -U test03.flv testflvtool.flv
ERROR: 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:228

e:\flv
$ ll testflvtool.flv
-rw-r--r-- 1 Administrator 197121 0 七月 24 14:13 testflvtool.flv

flvtool2 在执行30s以后报错,生成的文件大小为0.
我之前成功过其他文件,这个处理时间是这样的,估计我的文件错误超出了flvtool2的处理能力。

4. 对比ffmpeg

e:\flv
$ ffmpeg -i test04.flv -acodec copy -vcodec copy -f flv testffmpeg.flv

e:\flv
$ ffmpeg -i test04.flv -acodec copy -vcodec copy -f mp4 testffmpeg.mp4

e:\flv
$ ll
total 6219296
drwxr-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 未测试。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章