编译WebRTC网上已经很多文章,基本每篇文章并不能完全按照作者就一次能成功,年青人总归是要走些弯路的,所以出错是难免的,出错时怀疑过网络、环境、各博主著作时的版本和现在最新WebRTC的差异,一点点解决了,因此也记录一下,总体上大同小异,大胆和耐心去尝试总会遇到对的。
0、网络准备
可以访问外网,这一步如果没有解决,接下来的文章可以忽略了。稳定、快速的外网环境真的能让人少走很多弯路和节省时间,笔者曾用公司的外网和电脑(有安全保护)搞了将近半个月都没搞好,用自己的后从搭环境、下载源码到demo运行起来才花三个多小时。如果不能访问外网,只能转战国内镜像,比如声网的镜像
1、Window环境准备
(尽量是干净的电脑,笔者怀疑过已有的开发环境对前期工具、编译有影响,这一步不需要外网)
100G +的磁盘空间,NTFS格式,因为编译时的临时文件大和一些文件超过4G;
Window SDK安装,安装到C盘,用较新的WebRTC就先安装最新版本的sdk,这里下载,注意安装时一定要勾上“Debugging Tools For Windows”选项;后面编译时如果提示sdk版本出错可以再选择装对应的版本或者修改对应的文件为自己的版本。
VS2019安装,安装到C盘,各作者都不太建议使用最新的,笔者也不想太新的,因为太新的如果出问题都找不到解决方法;这里下载2019版本,社区版/专业版、英文/中文版都可以;下载后打开CMD用以下命令来进行安装,第一项是vs2019安装包的名称,后面是参数。
vs2019_community.exe --add Microsoft.VisualStudio.Workload.NativeDesktop --add Microsoft.VisualStudio.Component.VC.ATLMFC --includeRecommended
2、安装depot_tools
depot_tools是获取源码、编译必须的工具,建议使用git下载;这一步开始需要外网。
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
下载depot_tools之后,将其添加进环境变量中,注意是添加到系统变量中的Path,并且将其上移到第一位;
同样的添加环境变量方法,添加“DEPOT_TOOLS_WIN_TOOLCHAIN” ,并设值置为0,意思是告诉depot_tool工具将使用的是本地visualstudio;
3、更新工具
打开CMD,执行“gclient”,会自动更新webrtc所需要的工具,比如ninja、python等,更新完之后可以执行ninja --help或者python用来测试,如果对应命令有响应则成功了;如果没有响应先排除一些网络环境和再次执行“gclient”就行。
4、获取Webrtc源码
1. mkdir webrtc_code /*创建一个存放源码的文件夹*/
2. cd webrtc_code
3. fetch --nohooks webrtc /*开始获取源码,十多个G*/
4. gclient sync /*补充和更新对应的编译工具等*/
下载完成后,建议选择一个较新和稳定的版本,这里可以查看WebRTC的一些版本分支信息,笔者这里选择4515的分支,也就是m92的版本,因为用较新的版本,VS运行peerconnection Demo会出错,注意每次切换分支之后需要再次执行“gclient sync”或者根据提示“gclient sync -D”
git checkout -b 4515 remotes/branch-heads/4515
gclient sync
5、编译源码
先设置下VS的环境信息
set GYP_MSVS_VERSION=2019
set GYP_MSVS_OVERRIDE_PATH=C:\Program Files (x86)\Microsoft Visual Studio\2019\Community
生成vs工程、设置是release版本和编译,debug版本运行demo时需要注释一个断言,所以直接选择生成release版本,这一步成功后是可以直接用vs打开运行了,不用再做其他的步骤。
gn gen --ide=vs2019 out/release --args="is_debug=false"
ninja -C out/release
如果此步骤出错,根据对应提示解决就行了,如果百度不能解决的,基本就是glcient sync这一步骤异常,没有完整的更新和安装成功。
参考文章: