SRS的编译过程分析configure—SRS源码分析

SRS 的 configure 只有 800 行,相对于 FFmpeg 的 8000 行 configure,还是比较简单的,他的主要流程如下:

本文主要提取一些重点来讲解一下。

1,解析参数,创建目录

bash 复制代码
. $SRS_WORKDIR/auto/options.sh
. $SRS_WORKDIR/auto/setup_variables.sh

configure 脚本支持很多参数,例如 xxx,xxx,推荐阅读《SRS的编译参数configure》。而 options.sh 这个脚本就负责解析这些编译参数。

setup_variables.sh 这个脚本主要是检测 gcc 编译器是否安装,输出 SRS 的版本信息,还有创建一堆输出目录,如下:

上面这个 objs 以及很大串的 Platform 文件夹 都是 setup_variables.sh 脚本创建的。

options.shsetup_variables.sh 的前面,有一个 . 点号,这个其实是 source 命令的缩写,如下:

bash 复制代码
. $SRS_WORKDIR/auto/options.sh
等级于
source $SRS_WORKDIR/auto/options.sh

source 的作用是让 shell 脚本能用上当前环境创建的变量,更详细的用法请阅读《Linux下source命令详解》,SRS 的 configure 在很多地方都用了这种 . 点号写法,有兴趣可以关注一下。


2,处理依赖 depends.sh

bash 复制代码
# apply user options.
. $SRS_WORKDIR/auto/depends.sh

# the auto generated variables.
. $SRS_WORKDIR/auto/auto_headers.sh

depends.sh 脚本主要做的是下面三件事情。

  1. 检测 makegccg++pkg-config 等软件是否安装。
  2. 创建 nginx 目录以及相关的 HTML 页面,例如 HLS 页面,WebRTC 的推拉流页面等等。
  3. 编译依赖的第三方库的源代码,例如 StateThreads 协程库 libst.aopenssllibsrtplibopusFFmpeglibsrt 等等。

通常 shell 脚本都是不编译项目代码,只是检测环境是否支持编译,而是在 make 进行编译的。但是 depends.sh 会对第三方的项目代码进行编译。这是不同的地方。他在编译这些第三方库的源代码的时候,是把源代码拷贝到 SRS_PLATFORM 目录再进行编译的。

auto_headers.sh 脚本做的事情相对就比较简单了,就是把 shell 里面的一些变量,转成 C 语言的宏定义,然后写入到 srs_auto_headers.hpp 头文件里面,例如 SRS_SRT_BOOL 这个宏就是控制是否启用 SRT 相关的代码。


3,shell 重点语法

这里来讲解一下 configure 里面用到的一些不太容易看到的 shell 的语法。

第一点: SRS_MODULES=() 定义一维数组,这是定义一位数组的写法。

第二点: catEND 写入输出文件。

这种写法是把中间的内容保存到 ${SRS_OBJS}/Makefile 文件里面,注意他是有两个 END 的,而输出文件在 第一个 END 的后面。

关于 PHONY 的用法,请阅读《Makefile中.PHONY的作用


4,modules.sh 生成相关模块的 makefile

上图中 configure 这些模块化的 代码,都是定义这个模块的 文件,例如 KERNEL 模块的文件是 srs_kernel_errorsrs_kernel_log 等等,

modules.sh 会往 objs/Makefile 写入这些模块的 文件的编译规则, 不过实际上就是把相关的 .c 文件编译成 .o 文件而已,没有生成动态库,静态库,或者可执行文件。


5,apps.sh 生成可执行文件的编译规则

apps.sh 主要就是生成下图这一堆 可执行文件 的 makefile 规则的


configure 里面第 1~473 行代码,都是往 trunk/objs/makefile 写入内容,而从 473 行开始,就是生成 根目录的 makefile 了,也就是 trunk/makefile

trunk/makefile 会去调 trunk/objs/makefile 的代码完成编译的,如下:


关于 configure 脚本支持的参数,请阅读《SRS的编译参数configure


本文是《 SRS原理 》一书中的文章,如需观看更多内容,请购买本书。

相关推荐
音视频牛哥21 小时前
可控、安全、可集成:安防RTSP|RTMP视频播放模块工程实践参考
音视频开发·视频编码·直播
音视频牛哥2 天前
如何打造毫秒级响应的RTSP播放器:架构拆解与实战优化指南
人工智能·机器人·音视频开发
音视频牛哥4 天前
构建跨平台远程医疗系统中的视频通路技术方案探究
音视频开发·视频编码·直播
音视频牛哥4 天前
协同办公场景中的技术实践:跨平台音视频推流播放与信创环境适配方案
音视频开发·视频编码·直播
音视频牛哥4 天前
用毫秒级视频回传打造稳定操控闭环之远程平衡控制系统技术实践
人工智能·机器人·音视频开发
音视频牛哥4 天前
从热点到刚需:SmartMediaKit为何聚焦B端视频系统建设?
音视频开发·视频编码·直播
mortimer4 天前
视频配音自动同步(三):把“能跑”变成“好用”
python·ffmpeg·音视频开发
音视频牛哥5 天前
面向轨道交通安检的高帧率视频传输方案 :基于RTMP推流与RTMP播放技术的应用探索
音视频开发·视频编码·直播