webrtc学习(一): webrtc开始

时间:2021-02-10 17:35:55

一. 编译webrtc

1. 预先准备

1)  vpn. 用于同步代码. 这里给一个大概的估计吧. windows端包含vs2013 win8sdk wdk chromium源码等等, 总共需要至少8G. android端还需要android ndk sdk以及大量的依赖库, 大致也是10G往上. 所以需要网速不好的话, 同步一天也是很正常.

2. 同步代码及编译

http://www.webrtc.org/reference/getting-started

参考这个链接, 很详细, 需要认真看.

windows端的配置, 可以参考chromium的windows编译指导, http://dev.chromium.org/developers/how-tos/build-instructions-windows#TOC-Prerequisite-software

工具要求:
    tortoisesvn(可选)
    msysgit和Tortoisegit(可选)
    python(可选)
google的depot_tools会把所有需要的工具全部拉下来并配置好. 所以这些工具都是可选的.

 

配置depot tools:

svn co http://src.chromium.org/svn/trunk/tools/depot_tools
set path=D:\Libraries\depot_tools;%path% 或 export PATH=/root/depot_tools:$PATH

然后同步webrtc源码: (webrtc_root_dir 是你自己的目录)

 

cd webrtc_root_dir
gclient config --name src http://webrtc.googlecode.com/svn/trunk
gclient sync --force
gclient runhooks –force

depot_tools 会把vs2013, win8sdk, wdk都下载下来并配置. 在depot_tools/win_toolchain下.

webrtc依赖chromium(源码大小5G左右)

所以总共需要在线下载8G左右.

以后同步代码的时候需要去掉 --force参数. 否则会进行强制重新更新(意味着超长时间-_-!)

 

生成的工程是webrtcroot/src/all.sln, 编译依赖windows8.1sdk和wdk 可以单独安装, 也可以直接使用depot_tools中的配置.

depot_tools\win_toolchain\vs2013_files\win8sdk 复制到 C:\Program Files (x86)\Windows Kits\8.1

设置环境变量WDK_DIR=depot_tools\win_toolchain\vs2013_files\wdk

 

遇到的一些问题:

> 打包webrtc工程:

webrtc 与chromium公用很多三方库, 所以目录下会生成很多symlink. 所以不能直接7z或winrar打包, 可以先复制到新目录, 这样symlink会变成空目录.  或者 python src/setup_links.py –c 清除symlink, 然后压缩, 在解压后执行python src/setup_links.py --force 重新生成symlink也可以.

 

> 强制重新生成vs工程:

set GYP_GENERATORS=msvs

call python src/webrtc/build/gyp_webrtc -G msvs_version=2013

> 如果修改了depot tools的位置:

需要修改\webrtc\trunk\build\win_toolchain.json .

产生systemroot变量未定义错误时. 需要修改F:\depot_tools\win_toolchain\data.json  

 

> gclient sync时, 会报utf8 code error

> 编译时, call python isolate.py 错误.

系统显示语言必须是英文. 从来没见过像google这么傻逼的.

>svn too old

    把更新depot_tools时用的svn(或者高版本svn)替换depot_tools/svn_bin.

> error LNK2019: unresolved external symbol _intel_aes_encrypt_init_128 referenced in function _aes_InitContext

在trunk\third_party\nss\nss.gyp目录中注释掉USE_HW_AES和INTEL_GCM, 需要在重新生成工程文件.

或者直接删除nss_*.vcprojx中USE_HW_AES和INTEL_GCM的define.

 
>warning treated as error  no object file generated

    原因是该文件的代码页为英文,而我们系统中的代码页为中文

    解决方法: 1. region->administrative->language for non-unicode programs的语言改成english.

    2. 在编译开关里拿掉   /WX   开关, 即warning level. 可能会涉及很多工程.

        vcxproj中是<TreatWarningAsError>true</TreatWarningAsError>

>bash:../../third_party/libvpx/copy_obj.sh: /bin/bash: bad interpreter: No such file or directory

可以使用源代码下的E:\chromium\src\third_party\cygwin\setup_mount.bat,解决 ,双击此文件即可。执行完后,清理工程,再次编译,如果出现如下问题: >copy_obj.sh: line 6: $'\r': command not found

可以使用UltraEdit ->“文件”->“转换”->“Dos转Unix” (编辑copy_obj.sh文件),“保存”,再次清理工程,然后编译,(其实上面的问题都是因为不同操作系统下,文件的中回车/换行标示方法引起的,找个工具转换下就ok了)

>atls.lib(atlbase.obj) : error LNK2005: "class ATL::CAtlWinModule ATL::_AtlWinModule" (?_AtlWinModule@ATL@@3VCAtlWinModule@1@A) already defined in libjingle_media.lib(win32devicemanager.obj)

add "/FORCE:MULTIPLE" in Linker-->CommandLine.

另一种解决办法是, 把\depot_tools\win_toolchain\vs2013_files\wdk\lib\Atl\i386下的atls.lib删掉或重命名. 这样就会链接到C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\atlmfc\lib\atls.lib, 重定义就解决了. 这个因为是因为vs2013 update的原因.

 

linux 及android端:

google 默认的android 编译环境是ubuntu 64位. 其他环境需要自己测试.

本人使用ubuntu 14.01lts 64bit.

与windows类似, 需要depot tools. 然后配置环境变量 export PATH=/home/ldh/depot_tools:$PATH

配置JDK:

使用的是oracle jdk 1.7. 低于1.7会导致编译错误.

export JAVA_HOME=/home/ldh/jdk1.6.0_45

export PATH=$JAVA_HOME/bin:$PATH

 

linux:

./build/install-build-deps.sh    #linux需要依赖

gclient sync

 

linux下默认使用ninja, 如果需要使用make的话, 指定 export GYP_GENERATORS=make

android只支持ninja编译

 

android同步代码

./build/install-build-deps-android.sh   #android需要的依赖
$ echo "target_os = ['android', 'unix']" >> .gclient
$ gclient sync
$ cd src
$ source ./build/android/envsetup.sh
$ export GYP_DEFINES="$GYP_DEFINES OS=android"

 

编译:

$ cd src

Debug:

$ ninja -C out/Debug

Release:

$ ninja -C out/Release

 

错误

util.build_utils.CalledProcessError: Command failed: ( cd /home/ldh/webrtc/src/chromium/src/build/android; javac -g -source 1.7 -target 1.7

javac: invalid source release: 1.7

jdk版本错误, 需要jdk1.7

 

gclient同步时出现git fatal error  out of memory 时

git gc --aggressive --prune=now

git repack -a -d --depth=250 --window=250

这两条命令也可以用户减少.git文件夹的大小.

 

 

二. webrtc demo 简介

windows 下. peerconnection_client 和 peerconnection_server 可以直接测试. server可以部署在公网上.

android下. talk/examples/android 是apprtc的工程(最新名字是ConnectActivity.apk). 使用apprtc.appspot.com作为signal服务器. 可以测试android app, 也可以测试chrome网页.