本文首要分享播映器的性能优化,本文只是方法论的总结,不会触及具体的方法,假如想深化学习播映器优化请检查:

mp.weixin.qq.com/s/oL22a68Tm…

mp.weixin.qq.com/s/K8DLM4X-s…

1.播映指标

  • 播映成功率
    • 播映成功次数 / 播映总次数
  • 视频播映首帧(秒开率)
    • 调用start ~ 视频首帧送入Render
    • 首帧在1s的次数 / 总次数
  • 视频播映卡顿率
    • 卡顿总时长 / 观看时长
  • seek拖动卡顿
    • seek拖动卡顿次数 / seek总次数

视频播映成功率现在都比较高了,一般都是自建的源或许运用头部云平台的服务,不会存在格局不支持的问题了。

现在比较重要的两个指标便是视频播映首帧和视频播映卡顿率

2.视频首帧优化

  • TCP恳求衔接复用
    • 恳求的域名可以枚举出来,可以预衔接,后续复用
  • 预建解码器
    • 后台下发视频信息,预先创建解码器
    • 解码器复用
  • 预烘托
    • 首先将首帧烘托出来
  • 预加载
    • 头部设置probesize和analyzeduration设置恳求的巨细,保证预先恳求满足的数据以供后续烘托
  • 指定格局
    • 指定特定的解封装格局
    • 指定特定的解码格局
  • 边下边播
    • 本地代理实现边下边播,可以复用之前缓存
  • video-id复用
    • 同一个视频url会经常变,可是video-id不变,用video-id作为视频缓存的key
  • 低码率首帧加载
    • 开端播映运用低码率的片源,等后续播映稳定切换到高码率的片源

3.视频卡顿优化

  • 解决烘托卡顿
    • 播映帧烘托不能有耗时操作,例如视频播映中美颜、滤镜等操作不能耗时
  • 加载Buffer优化
    • 网络好的情况下缓冲Buffer调大点
    • 网络差的情况下缓冲Buffer调小点
  • 多码率习惯
    • HLS多码率习惯,弱网情况下核算load buffer自动切换到低码率
  • 丢帧控制
    • 极端情况下适当丢帧,丢帧要优先丢非参考帧,或许得话丢一整个GOP的数据,避免呈现花屏
  • 音视频同步
    • 推流端推的视频timestamp和音频timestamp有问题,拉流端音视频同步存在问题,导致播映卡顿,需要推流端校准

4.Seek优化

拖动进度条是一个比较重要的优化项,ffmpeg中的av_seek_frame有下面几种选项:

  • AVSEEK_FLAG_BACKWARD:第一个 Flag 是 seek 到恳求的时刻戳之前最近的关键帧。通常情况下,seek 以 ms 为单位,若指定的 ms 时刻戳刚好不是关键帧(大几率),会自动往回 seek 到最近的关键帧。虽然这种 flag 定位并不是非常精确,但可以较好地处理掉马赛克的问题,因为 BACKWARD 的方法会向回查找关键帧处,定位到关键帧处。
  • AVSEEK_FLAG_BYTE :第二个 Flag 是 seek 到文件中对应的方位(字节表示),和 AVSEEK_FLAG_FRAME 完全一致,但查找算法不同。
  • AVSEEK_FLAG_ANY:第三个 Flag 是可以 seek 到任意帧,不一定是关键帧,因此运用时或许呈现花屏(马赛克),但进度和手滑完全一致。
  • AVSEEK_FLAG_FRAME:第四个 Flag 是 seek 的时刻戳对应 frame 序号,可以理解为向后找到最近的关键帧,与 BACKWARD 的方向是相反的。



  • 当时播映时刻点是cur_time,拖动到的时刻点是seek_time,假如seek_time和cur_time在同一个GOP内部,那就不需要清空video frame queue中数据,优化seek性能。