HOME > CN > Architecture
SRS最关键是Simple,最简单的方案就是最佳方案;这个文章记录了SRS关键的Simple方案,也就是50%代码完成200%功能,100%代码完成400%功能的要点。
ST带来的问题简化,在一个状态空间时至少一个数量级;多个状态空间时就是百个数量级,譬如edge回源,http-flv和hstrs。在网络服务器中st的思路是与众不同,也是很巧妙的思路。
SRS是单进程使用epoll进行异步socket操作的高性能服务器,架构和nginx同源(同为非阻塞、异步、单线程),除了nginx是多进程SRS是单进程之外。
SRS没有直接使用epoll进行状态处理,而是使用了协程库state-threads,简称st(详细介绍可以看文章:高性能、高并发、高扩展性和可读性的网络服务器架构:StateThreads)。
关于setjmp和longjmp,以及为何st必须自己分配stack,参考st(state-threads) coroutine和setjmp/longjmp的关系
关于st如何分配栈,以及进行协程切换,以及协程的生命周期,参考:st(state-threads)线程和栈分析
ST参考:ST
关于HLS热备,在流媒体中是比较难以处理的一个问题,具体可以参考hls。所谓HLS热备,是指编码器(它自己可以热备)输出两路相同的RTMP流给两个不同地方的机房的流媒体服务器,然后这两个服务器生成的切片一样,这样任何一个机房宕机都不会影响hls流的生成。
比较典型的做法,是利用ATC时间戳,然后按照指定的规则生成切片。这样两个服务器输出的切片完全一样。
悟空提出了更好的方案,即使用standby方案替代完全热备:
这个方案确实很巧妙,使用另外不同的思路解决切片同步的问题。虽然在服务器切换时会有点切片间隙或不同步,但实际上并不会有大的影响。这点点瑕疵,至少简化了几个数量级的难度,是我见过所有HLS热备中最牛逼的一个方案~
这个方案可以加以改进,不依赖存储,不需要服务器做同步,更加简单:
Winlin 2015.5
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。