本文采用的 SRS 版本是 4.0-b8 , 下载地址:
github
本文开始讲解 SRS 的入口文件。SRS 源码里 其实有 3 个
main()
函数,分别在
srs_main_ingest_hls.cpp
,
srs_main_mp4_parser.cpp
,
srs_main_server.cpp
3 个文件里面,如图:
不过
srs
可执行文件,是
srs_main_server.cpp
生成的,所以先分析
srs_main_server.cpp
,其他两个文件不管。
main()
函数的流程图如下:
main()
函数的内部逻辑实际上比较简单,因为所有的操作都封装在其他函数里面。特别是
srs_thread_initialize()
跟
run_directly_or_daemon()
函数。
所以 main() 函数本文只会提及一些重点,重点如下:
1,
srs_thread_initialize()
里面有非常多的初始化操作,日志操作,配置文件,等等,请看《SRS4.0源码分析-srs_thread_initialize》。
2,
srs_assert(srs_is_little_endian());
,srs 只支持小端序机器,大端序机器不支持。
3,用了大量的
GPERF
来检测内存泄漏,具体请看 《SRS4.0源码分析-内存泄漏检测》。
3,
show_macro_features()
,这个函数打印 srs 支持哪些功能,例如 srt,dvr 是否支持。
4,
run_directly_or_daemon()
,此函数开始运行 SRS,可能在前台运行,也可能以守护进程运行。
相关阅读:
TODO:
1,写一篇文章讲解
gperftools
的使用。
由于笔者的水平有限, 加之编写的同时还要参与开发工作,文中难免会出现一些错误或者不准确的地方,恳请读者批评指正。如果读者有任何宝贵意见,可以加我微信 Loken1。QQ:2338195090。
推荐一个零声学院免费公开课程,个人觉得老师讲得不错,分享给大家:
Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,立即学习