1、环境准备
Windows10 操作系统
node v10.19.0(官网要求 >= v8.6.0)
npm-v6.13.4
git-v2.1.10
python-v2.7.17(不可以是 python3)
visual studio v2017及以上(官网要求 2015 以上,笔者最开始尝试 VS2015 ,遇见 constexpr 关键字不支持,此关键字在 VS2015 中开始支持,但是如果版本较低,则不会支持此关键字,因此请至少应使用 VS2017),我使用了 VS2019。
设置 npm 下载镜像站点为淘宝镜像
npm config set registry https://registry.npm.taobao.org
注意:请不要使用 cnpm
将 VS2017 的 MSBuild.exe 加入到 Path 中。
我的路径为D:\Develop\Microsoft Visual Studio\2019\Enterprise\MSBuild\Current\Bin
新建环境变量 GYP_MSVS_VERSION ,值为 2019。如果你使用的是 VS2017 就写 2017。对应的 MSBuild.exe 需要使用 VS2017 的路径。否则也会出错。
github 比较难以访问,可以使用 gitee 中已经同步过的项目,项目地址为: https://gitee.com/xunxinyuan/mediasoup-demo.git
$ git clone https://github.com/versatica/mediasoup-demo.git
$ cd mediasoup-demo
$ git checkout v3
目前此项目应该不再更新,因此不需要切换到 v3,默认就是 v3 版本。
进入 server 文件夹,打开 package.json 文件。修改第 22 行,为 “mediasoup”: “^3.6.16”,
如果不修改此行,则会从 github 中下载 mediasoup-v3 版本的依赖,否则会超级慢。修改后会直接从 npm 的镜像源中下载,加快速度。
运行 npm install
在运行过程中会出现下图中的错误,不用理会,mediasoup的依赖 clang-tools-tutorial ,主要是在 Linux 和 MacOS 中使用,Windows 中不涉及。
- 复制 config.example.js,修改为 config.js
- 在 server 文件夹下新增 certs 文件夹,将自己的公钥证书和私钥证书放进去。修改 config.js 的配置。cert 为公有证书,key 为私有证书。
可以参考这个链接生成证书。也可以使用 openssl 生成。
https://blog.csdn.net/xiejiashu/article/details/86714141
3. 修改所有的 ip 和 announcedIp 为本机 IP。如果内网公网不一致,则 announcedIP 设置为公网 IP。
进入 mediasoup-demo/app 文件夹,运行以下命令
修改 .eslintrc.js 文件,原先为 unix,修改为 windows
运行以下命令:
-
npm install -g gulp-cli
-
npm install
进入 server 文件夹,运行命令行设置临时环境变量
set DEBUG=${DEBUG:='*mediasoup* *INFO* *WARN* *ERROR*'} INTERACTIVE=${INTERACTIVE:='true'}
运行服务端:node server.js
也可以不设置环境变量,直接运行 node server.js
进入 app 文件夹,运行命令行窗口
gulp live
错误一:npm install 错误
Error: Unknown platform: win32 at Object.<anonymous> (E:\code\mediasoup-demo\server\node_modules\clang-tools-prebuilt\install.js:24:33) at Module._compile (internal/modules/cjs/loader.js:1158:30) at Object.Module._extensions..js (internal/modules/cjs/loader.js:1178:10) at Module.load (internal/modules/cjs/loader.js:1002:32) at Function.Module._load (internal/modules/cjs/loader.js:901:14) at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:74:12) at internal/main/run_main_module.js:18:47 npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@1.2.12 (node_modules\fsevents): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.12: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"}) npm WARN optional SKIPPING OPTIONAL DEPENDENCY: clang-tools-prebuilt@0.1.4 (node_modules\clang-tools-prebuilt): npm WARN optional SKIPPING OPTIONAL DEPENDENCY: clang-tools-prebuilt@0.1.4 postinstall: `node install.js` npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1
这个google海外找也没找到解决方法,最后用 npm install --ignore-scripts 通过, 不知道有没有影响
错误二: npm start 错误提示:'DEBUG' 不是内部或外部命令,也不是可运行的程序
解决办法,改为如下方式启动:
set DEBUG=${DEBUG:='*mediasoup* *INFO* *WARN* *ERROR*'} INTERACTIVE=${INTERACTIVE:='true'}
node server.js
错误三:启动WEB APP错误:error Expected linebreaks to be 'LF' but found 'CRLF' linebreak-style
解决:修改.eslintrc.js 文件 'linebreak-style': [ 2, 'windows' ],
其他对新学者可能有用的信息:
1. mediasoup使用ortc接口,用的不是目前webrtc那套sdp交换机制,虽然ortc说是webrtc的下一代接口,好几年前google就号称要支持ortc,但是目前也查不到chrome支持ortc的记录,倒是微软的edge曾经支持过ortc接口,所以用mediasoup的话,无论是web还是win,ios,android都要用mediasoup封装的客户端库