v5 实现动态时移播放

背景

有用户提出需要从当前时间前一段时间开始播放,比如 10s 前开始播放,或者 1 分钟前开始播放等。

在 v4 中有一个时光回溯功能,可以在配置中指定缓存时间,然后播放时可以指定 submode: 2来播放。

但是弊端是无法动态指定时间,v5 中实现了动态指定开始时间,每个订阅者都可以在不同的开始时间进行播放。

使用方法

通过配置文件

在配置文件中的 subscribe 配置中新增了 buffertime 配置。

global:
  subscribe:
    buffertime: 10s

不一定要放在 global 下面,这个只是一个示例,可以放在任意的插件配置下面

通过订阅的 URL参数

例如:http://localhost:8080/hdl/live/test?buffertime=10s

在 v5 中发布和订阅的 URL 参数会自动覆盖发布和订阅的配置中的值

实现原理

发布者缓存

发布者的数据会缓存在一个 RingBuffer 中,这个 RingBuffer 具有动态大小,可以根据需要扩大或者缩小

记录关键帧位置

将缓存中的关键帧记录下来,订阅者根据需要来从指定的关键帧位置进行读取

扩大缓存

如果订阅者需要比较老的数据,则需要等待缓冲,使得 RingBuffer 足够大

也可以在发布者中配置 buffertime 使得一开始就缓存足够多的数据,此时订阅者就无需再等待了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,183评论 19 139
  • 前言 本文介绍下Linux如何从入门开始到高级进阶的学习路线。 整个体系专注于服务器后台开发,知识点包括C/C++...
    探索Linux服务器架构师阅读 4,042评论 0 0
  • 1. redis介绍 Redis 是一种基于内存的数据库,对数据的读写操作都是在内存中完成,因此读写速度非常快,常...
    小pig阅读 3,157评论 0 0
  • 一、消息队列 1. 消息队列的介绍 消息(Message)是指在应用之间传送的数据,消息可以非常简单,比如只包含文...
    米斯特白阅读 4,400评论 0 0
  • 视频 视频实质:纯粹的视频(不包括音频)实质上就是一组帧图片,经过视频编码成为视频(video)文件再把音频(au...
    勇敢的_心_阅读 8,269评论 1 30

友情链接更多精彩内容