-
Notifications
You must be signed in to change notification settings - Fork 2
Product
关于SRS的来源,定位,愿景和计划。
SRS定位是运营级的互联网直播服务器集群,追求更好的概念完整性和最简单实现的代码。
- 运营级:商业运营追求极高的稳定性,良好的系统对接,以及错误排查和处理机制。譬如日志文件格式,reload,系统HTTP接口,提供init.d脚本,转发,转码,边缘回多源站,都是根据CDN运营经验作为判断这些功能作为核心的依据。
- 互联网:互联网最大的特征是变化,唯一不变的就是不断变化的客户要求,唯一不变的是基础结构的概念完整性和简洁性。互联网还意味着参与性,听取用户的需求和变更,持续改进和维护。
- 直播服务器:直播和点播这两种截然不同的业务类型,导致架构和目标完全不一致,从运营的设备组,应对的挑战都完全不同。两种都支持只能说明没有重心,或者低估了代价。
- 集群:FMS(AMS)的集群还是很不错的,虽然在运营容错很差。SRS支持完善的直播集群,Vhost分为源站和边缘,容错支持多源站切换、测速、可追溯日志等。
- 概念完整性:虽然代码甚至结构都在变化,但是结构的概念完整性是一直追求的目标。从SRS服务器,P2P,ARM监控产业,MIPS路由器,服务器监控管理,ARM智能手机,SRS的规模不再是一个服务器而已。
- 简单实现:对于过于复杂的实现,宁可不加入这个功能,也不牺牲前面提到的要求。对于已经实现的功能的代码,总会在一个版本release前给予充分的时间来找出最简答案。不求最高性能,最优雅,最牛逼,但求最简单易懂。
备注:概念完整性可以参考Brooks的相关文献,在宏观方面他还是很有造诣。
SRS release 1.0,预计研发周期为1年左右。主要的目标是:
- 提供互联网直播的核心业务功能,即RTMP/HLS直播。能对接任意的编码器和播放器,集群支持对接任意的源站服务器。
- 提供丰富的外围流媒体功能,譬如Forward,Transcode,Ingest,DVR。方便开展多种源站业务。
- 完善的运维接口,reload,HTTP API,完善和保持更新的wiki。另外,提供配套的商业监控和排错系统。
- 完备的utest机制,还有gperf(gmc,gmp,gcp)和gprof性能以及优化机制。提供c++层次足够满意的性能和内存错误查找机制。
- 在ARM/MIPS等嵌入式CPU设备Linux上运行。另外,提供配套的内网监控和排错,cubieboard/raspberry-pi的嵌入式服务器。
目前,功能均已实现,处于测试和改进阶段。预计在2014年年底之前发布release 1.0.
SRS release 2.0,预计研发周期为6个月左右。主要的目标是:
- 学习和简化st,只保留linux/arm/darwin部分代码。
- 简化RTMP包发送逻辑,在充分了解st的基础上,使用最高效直接的方式管理连接。
- 其他小功能的完善,譬如dvr录制为一个文件,srslibrtmp支持h264之类。
SRS 3.0+ 的功能列表,可能的方向:
- HTTP方向: HLS边缘, HTTP FLV分发, HTTP API认证, HLS快速缓存技术, HTTP支持vhost, HTTP访问时回调, HTTP-MP4流
- 增强的RTMP方向: 转发调用, 支持RTMP302跳转, RTMP推流认证, 支持AMF3, SharedObject和文本分发, 一个连接多个流, Forward支持额外参数, Edge支持额外参数, 支持RTMFP协议
- 超低延迟方向: FRSC百毫秒延迟, 集群内部使用UDP
- 监控RTSP方向: 支持RTSP
SRS对于所有新功能都持推延态度;有悖于系统一致性和概念完整性的功能绝对不做,譬如支持Windows系统就有悖于一致性和完整性(服务器系统的差异太大);对于确定要做的功能SRS也会仔细斟酌最佳方案,譬如支持多进程就是在选最佳方案;对于已有方案要做到最好,譬如最低延迟方案。对于功能点,只要属于系统一致性和概念完整性范围内都会考虑添加,或者说,大部分都不做,要做就要做到最好,the best or nothing!
SRS是2013.9(2013.8.22提离职申请,理论上2013.9.22就离职,为了交接平稳我增加了交接时间)我从蓝汛离职后,我参考nginx_rtmp写了个简洁直播源站服务器。蓝汛接我工作的同事也可以看到服务器如何一步步构建。蓝汛的客户也可以用这个源站,那些乱七八糟的源站对接太麻烦。我想用业余时间构建不受客户随意影响的产品,只遵循核心价值而加入功能,而不是为了赚钱或者客户头脑发热,总之,实现我对于产品价值和质量,真正实现客户核心要求,定位清晰,一个实践现代软件工程和研发理念的服务器。
2013.10底加入观止负责研发管理工作。后来观止创想做编码器,编码器需要输出到rtmp服务器,nginx-rtmp又经常出问题,就打算用我的SRS替换nginx-rtmp。后来编码器上线过程中,我也逐步完善了SRS,是快速成长期。开放服务器,就让客户可以更好的用我们编码器,而且我们编码器可以支持拉模式。这个阶段主要是源站阶段。
2014.3进入反馈期,树苺派,极路由,cubieboard等嵌入式设备上有人问是否能支持。我自己买了树苺派,在上面运行成功,改了st的一个bug。从这个时候开始,是功能爆发的时期,得到群里童鞋们的反馈。转码,转发,采集,录制都是这个时期的工作。
2014.5,SRS功能冻结,测试和解决问题。我们公司扩大产品线,准备做VDN,视频分发网络,自然srs成为最佳选择。公司各位老大也一致认为srs的定位比较合适,一致商议决定直播服务器使用srs。SRS的功能都已经完善,VDN其他业务系统譬如监控和计费开始研发,我只有周末时间做SRS了。
2014.10,SRS1.0beta发布,坐等大家反馈bug,如果没有bug就在2014年底发布1.0release。观止创想也准备在1.0release的基础上上研发下一代商用流媒体服务器。从0到1.0,SRS花了1年时间,17个里程碑,7个开发版,223个修订版,43700行功能代码,15616行utest代码,1803次提交,161个bug和功能,解决了117个,可在1个平台运行,支持4种cpu(x86/x64/arm/mips),11个核心功能(origin、 edge、 vhost、 transcode、 ingest、 dvr、 forward、 http-api、 http-callback、 reload、 tracable-log),35个功能点,58篇wiki,SRS的QQ群有245位成员,活跃成员141人,2位主作者,12位贡献者,14位捐赠者,至少有蓝汛、VeryCloud、VeryCDN、清华电视台在使用或基于SRS改自己的服务器,数百位各种行业的公司在使用SRS主要包含视频监控、移动端、在线教育、秀场和KTV、互动视频、电视台、学生。
我们公司各位老大信任和支持我的管理方法和工作,观止技术团队也贡献了部分代码譬如ATC(HSS录制是FlashP2P我去掉了),所以把观止创想的联合创始人都写入感谢名单。还感谢蓝汛时期Micheal热情大气无私,以及精湛的能力教我解决蓝汛边缘服务器的异步状态问题,让我领悟到要不断学习和进步。
SRS虽然是重新编码和架构,实际上过去三年在直播集群中积累的经验最重要。SRS是我对于软件设计和开发的一个总结,是我对于产品研发的最好诠释。周末没多少时间,不过好产品不是靠人力的,靠的是毅力,经验和信仰。我要做的是不断成长的产品,几十年的产品,不着急这一时半会儿。
入软件行业有10年,写代码有7年了,一直看一些书、反思、实践、再看书;书上众说纷纭,总得试一试看谁说的是对的;所以我做SRS只是当作形成自己体系的一个机会。古人说,不能记住你给别人的帮助,不能忘记别人对你的帮助。开源项目更多是不能记住你给别人的帮助。能做大的开源项目,往往聚集了一些同样是“不忘记别人对你的帮助”的这些人,才能一起推动项目发展。
商业公司永远无法做出我个人满意的产品,不是时间的原因。SRS一定会出现众多的修改闭源商业版本,但没有一个能比我的分支更完整和可延续。这就是因为不考虑利益时才能考虑长远的缘故。
srs必定广泛使用,如同漫天繁星散布渺渺宇宙,灿漫夏花开遍地球月球火星太阳系,愿蓝汛和观止创想财源广进,SRSTeam永垂不朽,彪炳千古,哈哈哈!
Beijing, 2014.3
Winlin