用于MPEG视频流的使能服务质量中间件

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
性能测试 PTS,5000VUM额度
简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/3278708 用于MPEG视频流的使能服务质量中间件(1)介绍在线视频流业务近几年在互联网上非常流行。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/3278708
用于MPEG视频流的使能服务质量中间件

(1)介绍



在线视频流业务近几年在互联网上非常流行。视频流是一种并发处理,它从服务器发送视频图像通过网络到达客户端,由客户端视频播放器播放这些视频图像。


在线视频流业务系统是一个在线的、严格实时的多用户系统,它在开放网络(例如因特网)运行无法控制,性能不稳定,不可预测。MPEG逐渐成为视频编码事实上的标准,MPEG视频流系统的一个挑战是向客户端提供了很高的服务质量(QoS)。此处有许多软件,如Real Player,用于在线视频流的播放。由于开放网络的特性,它是低效的,因为靠调节网络性能来改进在线视频流的服务质量几乎不可能。人们对如何增强在线视频流的服务质量做了大量研究,这些研究主要分为下列三类:


1、通过新编码算法和数据结构取代现有的视频编码数据格式,使开放网络更适合处理视频图像。


2、通过新协议和新的视频图像传输机制代替现有的流行协议。


3、视频预先准备几个版本,每个版本有不同的解析度或帧尺寸,即有不同的QoS级。这些版本在不同的流下能并发播放。根据网络的性能,服务器选择客户端最适合的QoS质量的流。


前两个方法的主要缺点在于需要新的视频播放器或通信系统。实际上,这两个方法都不可行。最后一个方法的缺点在于需要大量资源,包括处理器和宽带。因此,这些方法都得不到流行。


我们考虑在服务器和客户端之间放置一个中间件软件系统,目的是提供增值业务给C/S系统。这就是使能服务质量多媒体中间件。大多数中间件设计实现了此方法。他们在服务器端调节可观察到带宽的QoS。然而,在开放网络上的服务器和每个单独客户端之间的吞吐量是不同的,此方法不能为每个客户端提供一个可定制的QoS调节。更为重要的是,这些研究没有考虑多种不同的编码格式。因此,QoS调节模式也不适合MPEG视频编码格式的特点。


为了允许用户用他们喜爱的播放器播放视频,我们解决了此问题。那就是利用“分布式使能QoS中间件”。此中间件位于视频服务器和客户端视频播放器之间,它由服务端件(Serverware)和一些客户端件(clientware)组成。既然服务器和每个单独的客户端之间的吞吐量不同,每一客户端的视频QoS质量也不相同。而且,当网络阻塞时,一些帧会下降。下降的QoS可以映射到一些跳过的MPEG帧模式。因此,服务端件不需传输所有MPEG帧给客户端,而是只有一些根据选定与QoS一致的帧才传输给客户端。这就是分布式中间件提供的增值业务。


服务质量QoS是视频流系统的一个关键的成功因素。有两个测量因子:一是字节传输率,二是帧传输率。


MPEG由三种不同的帧组成,这些帧有不同的尺寸和不同的视频质量。这是一种组帧模式(Group Frame Scheme)。

目录
相关文章
|
编解码 中间件 网络性能优化
用于MPEG视频流的使能服务质量中间件
用于MPEG视频流的使能服务质量中间件 (1)介绍 在线视频流业务近几年在互联网上非常流行。视频流是一种并发处理,它从服务器发送视频图像通过网络到达客户端,由客户端视频播放器播放这些视频图像。
755 4
|
6月前
|
消息中间件 存储 负载均衡
消息中间件的选择:RabbitMQ是一个明智的选择
消息中间件的选择:RabbitMQ是一个明智的选择
105 0
|
5月前
|
消息中间件 存储 中间件
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
1241 0
|
4月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
270 3
|
23天前
|
消息中间件 编解码 Docker
【Docker项目实战】Docker部署RabbitMQ消息中间件
【10月更文挑战第8天】Docker部署RabbitMQ消息中间件
61 1
【Docker项目实战】Docker部署RabbitMQ消息中间件
|
3月前
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
3月前
|
消息中间件 Docker 容器
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
这篇文章提供了RabbitMQ的安装和基本使用教程,包括如何使用Docker拉取RabbitMQ镜像、创建容器、通过浏览器访问管理界面,以及如何创建交换机、队列、绑定和使用direct、fanout和topic三种类型的交换器进行消息发布和接收的测试。
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
|
3月前
|
消息中间件 存储 网络协议
消息中间件RabbitMQ---概述和概念 【一】
该文章提供了对消息中间件RabbitMQ的全面概述,包括其核心概念、工作原理以及与AMQP和JMS的关系。
消息中间件RabbitMQ---概述和概念 【一】
|
4月前
|
消息中间件 监控 负载均衡
中间件RabbitMQ性能瓶颈
【7月更文挑战第13天】
245 11
|
4月前
|
消息中间件 NoSQL Kafka
消息中间件(RocketMQ、RabbitMQ、ActiveMQ、Redis、kafka、ZeroMQ)以及之间的区别
消息中间件(RocketMQ、RabbitMQ、ActiveMQ、Redis、kafka、ZeroMQ)以及之间的区别