您的位置:首页 > 其它

一只视频程序猿的移动直播SDK初体验

2017-12-09 15:17 155 查看
本文转自一只视频程序猿的移动直播SDK初体验,此处仅做排版改动。

今早老板召开站会,“移动直播这么火,市面上有一百多个APP,小斌,你下周交个原型APP瞅瞅!”

小弟心中一万匹草泥马奔过,这玩意儿哪儿是几天就能弄出来的?问候归问候,咱还是赶紧调研吧,端午还约了妹子游泳呢。

方案选项

作为公司音视频大神,对流媒体基本概念还是OK的。咱首先看看市面上火热的某客、某椒APP怎么工作的。主播端推流使用RTMP推向流媒体源站,服务器内部通过RTMP协议多级拉流至边缘CDN节点,播放端从边缘CDN节点获取直播内容,大致如下图:



其中上行RTMP推流很普遍了,很多游戏直播都使用obs推RTMP流。

在整个过程中,涉及很多流媒体的基本概念,先说说GOP。

GOP即Group of picture(图像组),指两个I帧之间的距离。即几秒有一个关键帧。分析线上主流的移动直播APP,大都在2、3秒之间。



一般的云服务公司都会提供多种协议的拉流方式,优缺点如下:

HLS协议,移动h5浏览器支持较好,但是延迟较大。移动端播放前需要产生三个分片,每个分片至少得是一个GOP。一个GOP即使是2秒,也意味着这个环节耗费了6秒的延时。

RTMP协议,需要访问1935端口,支持双向互动,实时性很好,PC flash原生支持。

HTTP-FLV,不支持双向互动,实时性和RTMP协议一致。

基于以下几点理由,小弟准备采用HTTP-FLV作为拉流协议:

国内网络情况的恶劣程度,并不是每个网络防火墙都允许1935包通过。

RTMP协议和HTTP-FLV,实际传输的内容都是相同的FLV,实时性也一样。

RTMP协议握手方式比HTTP复杂。

确定好了拉流协议,再看看推流侧依赖的参数。

FPS,每秒编码传输的视频帧数;

码率,每秒编码传输的音视频比特数;

GOP,关键帧间隔;

分辨率。

在相同码率的情况下,FPS和分辨率越大,视频的图像质量越差。为了平衡主播上行带宽、用户观看下行带宽和图像质量的关系,需要很好处理这几个值。

SDK下载

首先,Android/iOS系统上,并不包含RTMP推流组件,这块需要自己开发。系统自带的播放器也不支持flv文件的播放。小弟只能去阿里云、腾讯云、百度云、金山云等大牛云服务公司找解决方案了。把每个帐号都注册一遍,大致情形如下。



其中,腾讯云ILVB实名认证后需要人工审核5个工作日,反正至今没有看到SDK。

更令人震惊的是,虽然阿里云提供多媒体云服务,但是至今尚未提供移动直播SDK。

总体来说,开放较好的是金山云,SDK放到了github上,每次change log都很清楚,几乎每周都有更新。 腾讯云就有些犹抱琵琶半遮面,给SDK试用都不痛快。

SDK功能对比

拿到SDK,首先对比一下相关功能。其中腾讯云LVB直播只提供了播放SDK,还仅只支持HLS播放,这个方案首先扑街。ILVB互动直播未拿到SDK,暂且不表。这样一来,可供选择的大型云服务商的方案就剩下金山云和百度云。

移动直播SDK涉及的功能比较多,我先解释一下几个基本功能点:

推流编码,涉及软件编码和硬解编码。相同码率,软编图像质量更清晰,但是耗电更高;

网络自适应,当网络抖动时根据网络情况调整发送速率;

美颜,对主播图像进行美白、液化、磨皮等处理;

a92c

混音,当主播聊天时,可以把背景音乐混到音视频里面;

播放视频旋转,可以根据视频宽高,决定横屏还是竖屏播放;

直播重加载,当播放状况不佳时,重新拉流播放。

为了对比其他方案,做了几张表格。

Android推流功能列表如下:



从表中可以看到,

百度云接口还很粗糙,连移动直播必选的美颜功能都不支持,首先淘汰。

小弟想有噪声抑制功能,但是这些SDK都没有支持,不过令人欣喜的是,金山云支持自定义音频数据处理,可以把自己的噪声抑制代码挂载进去。

相比而已,金山云的接口较开放。其中金山云SDK支持的功能更丰富些,能满足当前移动直播的要求。

iOS推流功能列表如下:



从表中可以看出,iOS推流功能丰富程度普遍较高,这和市面上主播大量使用iPhone推流有密切关系。

从特色功能来看,只有金山云支持画中画和美声功能。

自定义滤镜和原始数据处理,体现了SDK的开放程度,这方面百度云是严重失分的。

在细节功能上,对声音和美颜的处理,体现了当前SDK对移动直播市场的重视程度。

Android播放功能列表如下:



iOS播放功能列表如下:



播放端关注点和推流端还有些不一样,播放侧除了考虑功能丰富以外,还需要考虑稳定性、功耗、包大小、开播速度等,静态对比可以作为参考。金山云支持直播重加载,能有效降低播放卡顿率。

总结一下,通过试用大型云服务商的移动直播SDK,得出以下结论:

能完全运行起来的是金山云、百度云提供的SDK。腾讯云、阿里云尚未提供真正可用的移动直播SDK。

从Android/iOS推流功能以及播放功能来看,金山云提供的功能最为丰富。

百度云提供的推流功能还比较简单,离市面的要求有些距离。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: