SRS6.0: 七年长跑,全面支持H.265

2023-10-08 15:10

本文主要是介绍SRS6.0: 七年长跑,全面支持H.265,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

经过七年的酝酿和开发,SRS在6.0中终于正式支持了HEVC(H.265),几乎全面支持,包括RTMP、FLV、SRT、TS、HLS、DASH、GB28181、WebRTC(Safari)、DVR FLV、DVR MP4、WordPress SrsPlayer等等。

在大多数商业公司中,七年,黄花菜都凉了。开源项目只要能做出来,哪怕慢一些,也能活久见。

1、Why Important?

H.265比H.264的编码效率更高,不过一个编解码的更新换代,一般是以N个10年为基准的,现在也不能说H.265就能完全替换H.264,还有不少遗留问题。

H.265的收益就不用说了,可以用更少的带宽,传输同样的质量,这就是省钱啊。

此外,8K的朋友必须H.265,大约在9Mbps码率,而H.264得30Mbps而且最高分辨率无法支持8K。

但省钱的前提是不出问题,如果用户的设备支持H.265有问题,那就会引起投诉和体验问题,反而造成更大的成本。

当然了可以将 H.265转码一个H.264的流出来,给那些只支持H.264的设备用,不过这样一样会引入转码成本了。

而H.265正有这一堆的问题,所以如果你想要选择H.265,一定要想好了,看看你的场景下收益是否能超过要付出的成本。

2、Status of H.265

下面是各种场景下,H.265的支持情况,可以阅读原文,看详细的Commit。

第一部分,推流,推流端基本是支持的,通过打Patch也可以支持:

  • • 原生支持:使用FFmpeg推SRT流,目前支持得最好的方式。

  • • 原生支持:OBS推SRT流,需要有硬件支持。

  • • 原生支持:摄像头推GB28181流,基本上都支持。

  • • 补丁支持:使用FFmpeg推RTMP流,需要打Patch

  • • 配置支持:Safari浏览器推WebRTC流,需要手动点下菜单栏的选项才能开启。

  • • 不支持:Chrome/Firefox推WebRTC流。

  • • 不支持:使用OBS推流RTMP流。

第二部分,FFmpeg/ffplay拉流,支持度是比较完善的:

  • • 原生支持:使用FFmpeg拉HTTP-TS流。

  • • 原生支持:使用FFmpeg拉HLS流。

  • • 原生支持:使用FFmpeg拉MPEG-DASH流。

  • • 原生支持:使用FFmpeg拉SRT流。

  • • 原生支持:使用ffplay播放HTTP-TS流。

  • • 原生支持:使用ffplay播放HLS流。

  • • 原生支持:使用ffplay播放MPEG-DASH流。

  • • 原生支持:使用ffplay播放SRT流。

  • • 补丁支持:使用FFmpeg拉RTMP流。

  • • 补丁支持:使用FFmpeg拉HTTP-FLV流。

  • • 补丁支持:使用ffplay播放RTMP流。

  • • 补丁支持:使用ffplay播放HTTP-FLV流。

第三部分,浏览器H5播放流,MSE支持,但也需要上层播放器库支持:

  • • 原生支持:使用Chrome播放HTTP-TS流,需要硬解支持,SRS使用mpegts.js。

  • • 原生支持:使用Chrome播放HTTP-FLV流,需要硬解支持,SRS使用mpegts.js。

  • • 配置支持:使用Safari拉WebRTC流,需要手动点下菜单栏开启。

  • • 不支持:使用Chrome hls.js播放HLS流。底层MSE支持,但hls.js是负责将HLS转fMP4,也需要支持才行。

  • • 不支持:使用Chrome dash.js播放DASH流。底层MSE支持,但dash.js是负责将DASH转fMP4,也需要支持才行。

  • • 不支持:使用Chrome/Firefox拉WebRTC流。暂时没有看到有支持的可能,Chrome主要是在做AV1方向。

第四部分,VLC播放流,对于TS和MP4封装支持比较好:

  • • 原生支持:VLC播放HTTP-TS流。

  • • 原生支持:VLC播放SRT流。

  • • 原生支持:VLC播放HLS流。

  • • 原生支持:VLC播放MPEG-DASH流。

  • • 不支持:VLC播放RTMP流。暂时没看到支持的可能。

  • • 不支持:VLC播放HTTP-FLV流。暂时没看到支持的可能。

第五部分,辅助功能,关于HEVC的重要的辅助能力:

  • • 原生支持:录制为FLV/MP4文件。FLV是非标准的,MP4是标准的。

  • • 原生支持:解析HEVC元数据,通过HTTP API提供。

  • • 原生支持:黑盒测试支持HEVC。

  • • 原生支持:SRS镜像支持补丁的FFmpeg。可以不用自己编译FFmpeg,使用SRS镜像提供的FFmpeg即可。

  • • 原生支持:WordPress plugin SrsPlayer插件支持HEVC。由于云SRS使用的是4.0稳定版本,还需要几年才能切换到6.0。

  • • 不支持:Update srs-cloud for HEVC.

  • • 不支持:Edge server supports publish HEVC stream to origin.

  • • 不支持:Edge server supprots play HEVC stream from origin.

  • • 不支持:HTTP Callback takes HEVC metadata.

  • • 不支持:Prometheus Exporter supports HEVC metadata.

  • • 不支持:Improve coverage for HEVC.

  • • 不支持:Supports benchmark for HEVC by srs-bench.

至于iOS或Android Native,可以用FFmpeg硬解码,早就可以自己支持了。

由于Chrome 105 MSE已经支持了HEVC,所以浏览器上的完善度就很高了,感谢头条的开发者。

【学习地址】:FFmpeg/WebRTC/RTMP/NDK/Android音视频流媒体高级开发

【文章福利】:免费领取更多音视频学习资料包、大厂面试题、技术视频和学习路线图,资料包括(C/C++,Linux,FFmpeg webRTC rtmp hls rtsp ffplay srs 等等)有需要的可以点击1079654574加群领取哦~

3、Usage: Live

我们看一个最简单的H.265直播的例子。

首先,编译SRS,注意开启HEVC(H.265)支持,SRS 6.0.31+:

git checkout develop./configure --h265=on && make

然后,启动SRS服务器,我们启动了SRT、HTTP-FLV和HLS:

env SRS_LISTEN=1935 SRS_DAEMON=off SRS_LOG_TANK=console \  SRS_SRT_SERVER_ENABLED=on SRS_VHOST_SRT_ENABLED=on SRS_VHOST_SRT_TO_RTMP=on \  SRS_HTTP_SERVER_ENABLED=on SRS_VHOST_HTTP_REMUX_ENABLED=on \  SRS_VHOST_HTTP_REMUX_MOUNT=[vhost]/[app]/[stream].flv SRS_VHOST_HLS_ENABLED=on \  ./objs/srs -e

接着,启动FFmpeg推流,我们选择SRT推流,天然兼容HEVC:

ffmpeg -stream_loop -1 -re -i doc/source.flv -acodec copy -vcodec libx265 \  -pes_payload_size 0 -f mpegts 'srt://127.0.0.1:10080?streamid=#!::r=live/livestream,m=publish'

就可以直接打开网页播放HTTP-FLV流了,也可以使用ffplay或VLC播放HLS:

  • • http://localhost:8080/live/livestream.flv

  • • http://localhost:8080/live/livestream.m3u8

Note: 注意不能用H5播放HLS,因为hls.js还不支持,但可以用H5播放HTTP-FLV或HTTP-TS,因为mpegts.js支持。

其他协议请参考SRS的文档开启即可。

4、Usage: WebRTC

特别解释下WebRTC H.265:只有Safari支持HEVC,Chrome和Firefox还不支持。

Safari默认没有开启,需要手动点下开发 > 实验性功能 > WebRTC H265 codec

具体使用方法,请参考#465的Safari WebRTC部分的使用说明。

WebRTC对于AV1的支持更完善,Safari/Chrome/Firefox也都支持,具体请参考#1070,当然MSE对于AV1目前还没有支持。

Note: Media Source Extensions (MSE)是浏览器支持流媒体的底层接口,可以认为是把点播或直播转成fMP4切片送给H5 video对象,比如mpegts.js、hls.js和dash.js都是基于MSE,具体可以参考MDN: MSE。

5、FFmpeg Patch

众所周知,FFmpeg/ffplay是不支持HEVC over RTMP/HTTP-FLV,当然一般用FFmpeg的朋友都是有自己改代码的能力,下面是一些相关的Patch:

  • • 施维(runner365),支持FFmpeg 4/5/6版本的patch,参考ffmpeg_rtmp_h265,SRS使用的是这个Patch。

  • • Intel 0001-Add-SVT-HEVC-FLV-support-on-FFmpeg.patch

  • • 金山云修改的FLV的specfication以及对应的usage。

SRS提供了打过Patch的FFmpeg、ffplay和ffprobe,可以直接用SRS Docker推流:

# For macOSdocker run --rm -it ossrs/srs:encoder ffmpeg -stream_loop -1 -re -i doc/source.flv \  -acodec copy -vcodec libx265 -f flv rtmp://host.docker.internal/live/livestream# For linuxdocker run --net=host --rm -it ossrs/srs:encoder ffmpeg -stream_loop -1 -re -i doc/source.flv \  -acodec copy -vcodec libx265 -f flv rtmp://127.0.0.1/live/livestream

Note: 也可以把二进制拷贝出来使用,或者参考Dockerfile编译。

可以详细参考FFmpeg Tools

6、Known Issues

目前已知的问题,总结下:

  1. \1. Safari HEVC WebRTC只支持WebRTC,不支持转换其他协议。SRS可以实现,但目前使用的场景比较少,有需要会在未来完善。

  2. \2. Chrome/Firefox WebRTC是不支持HEVC的,也没有计划支持。

  3. \3. 几乎浏览器都支持MSE,除了iOS。注意HEVC MSE是依赖硬件解码的。

  4. \4. H5播放器目前mpegts.js支持,hls.js和dash.js还没有支持。

在某些场景下,HEVC的应用完全成熟了,具体就需要各位开发者自己评估了。

7、Thanks

H.265这个功能,核心的贡献都是社区的朋友,有可能会漏掉哈请多包涵,包括但不限于:

  • • runner365 施维大神,最初的PR的提交者,RTMP、HLS和SRT支持265。

  • • yinjiaoyuan 解决了265的bug,GB28181支持265的Patch。

  • • PieerePi 解决了265的bug。

  • • qichaoshen82 解决了265的bug。

  • • ZSC714725 解决了265的bug。

  • • bluestn MP4和GB28181录制支持265。

  • • mapengfei53 MP4录制支持265。

  • • chundonglinlin SRT支持265。

  • • duiniuluantanqin GB28181支持265。

  • • panda1986 WordPress SrsPlayer插件支持265。

Note: 可以看到大家的工作是有交叉的,虽然有些PR没有直接合并到SRS,但是最终合并到SRS的代码,都参考了大家提交的PR,并且会把大家作为co-author写到Commit中的哈。

最后,特别感谢mpegts.js,谦谦大神的H5播放器,支持了HTTP-FLV和HTTP-TS的H.265能力,这是flv.js的延续的项目,我觉得大家都欠他一个Star哇。

原文链接:SRS6.0: 七年长跑,全面支持H.265

这篇关于SRS6.0: 七年长跑,全面支持H.265的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/166165

相关文章

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

MySQL主从同步延迟问题的全面解决方案

《MySQL主从同步延迟问题的全面解决方案》MySQL主从同步延迟是分布式数据库系统中的常见问题,会导致从库读取到过期数据,影响业务一致性,下面我将深入分析延迟原因并提供多层次的解决方案,需要的朋友可... 目录一、同步延迟原因深度分析1.1 主从复制原理回顾1.2 延迟产生的关键环节二、实时监控与诊断方案

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件