0.前言动机
早在去年初(2015年2月)的时候,戴维营教育由于课程需要讲WebRTC实时音视频聊天技术,就写过一个教程一步一步搭建一个WebRTC的后台服务器AppRTC的教程,但是由于Goggle官方代码有改变,导致大部分网友严格
按步骤来操作不成功.
现在我们戴维营教育仍然要讲WebRTC技术,同时需要更新技术,在这里再一步一步重新搭建最新代码版本的AppRTC服务器,顺便整理出每一步的更新教程.
1.环境准备和代码下载
在Ubuntu Linux 版本服务器上创建新用户apprtc
,设置密码,并安装必要的软件包:
$ sudo useradd -m apprtc
$ sudo passwd apprtc
$ sudo apt-get install openjdk-7-jdk
$ sudo apt-get install python-webtest
然后在用户家目录下从Github克隆出apprtc
代码仓库:
$ apprtc_root
$ cd apprtc_root
$ git checkout fa43376fa2138a45cdcf14007695d2e7523ea48f
目前最新的版本是fa43376fa2138a45cdcf14007695d2e7523ea48f
.
代码下载好了之后,就先留着不要去动, 下面我们去安装必要的依赖.
2.安装NodeJS和grunt
$ cd $HOME;
$ wget https://nodejs.org/dist/v5.9.0/node-v5.9.0-sunos-x64.tar.xz
$ tar xvf node-v5.9.0-sunos-x64.tar.xz
$ export PATH=$PATH:$HOME/node-v5.9.0-linux-x64/bin
$ echo "export PATH=$PATH:$HOME/node-v5.9.0-linux-x64/bin" >> $HOME/.profile
$ sudo npm install -g npm
再安装grunt:
$ npm -g install grunt-cli
3. 安装apprtc代码中的grunt依赖:
切换到apprtc用户下,终端进入apprtc仓库目录下:
执行下面命令:
apprtc@hostname:~/apprtc_root$
npm install
然后再执行下面命令编译出apprtc
这个GAE app.
$ grunt build
编译完成后,输出将放在~/apprtc_root/out
目录下的app_engine
目录
当然到这一步还没完,还需要配置constant.py
服务器参数,
ICE_SERVER_BASE_URL =
ICE_SERVER_URL_TEMPLATE = '%s/apprtc/iceconfig.php?key=%s'
ICE_SERVER_API_KEY = os.environ.get('ICE_SERVER_API_KEY')
然后把下面命令放到一个脚本文件$HOME/start_apprtc.sh
中:
export PATH=$PATH:$HOME/google_appengine
export APPRTC_APP=$HOME/apprtc_root/out/app_engine/
export HOST="--host=0.0.0.0"
export ICE_SERVER_API_KEY="AIzaSyAJdh2HkajseEIltlZ3SIXO02Tze9sO3NY"
dev_appserver.py $HOST $APPRTC_APP
以后都只需要执行该脚本文件就可以启动会话房间服务:
$ $HOME/start_apprtc.sh
最后一步就是配置Nginx反向代理服务器,提供默认HTTPS的访问, 新建Nginx虚拟主机配置文件,反向代理到8080端口.
upstream roomserver {
server localhost:8080;
}
server {
listen 80 ;
server_name
return 301 https://$server_name$request_uri;
}
server {
listen 443 ;
ssl on;
#
ssl_certificate
ssl_certificate_key
server_name
access_log
location / {
proxy_pass http://roomserver$request_uri;
proxy_set_header Host $host;
}
}
信令服务器还没准备好,下面再慢慢的来安装配置信令服务器.
4. 安装GO环境
下载Go安装包:
$ wget
$ tar xvf go1.5.3.linux-amd64.tar.gz
创建本地GO代码目录:
$ mkdir -p $HOME/gopath/src
编辑打开文件$HOME/.profile
,在文件末尾添加两行
$ export GOROOT=$HOME/go
$ export GOPATH=$HOME/gopath
$ export PATH=$PATH:$GOROOT/bin:$GOPATH/bin
退出终端重新打开或者登陆,GO环境就安装配置好了.
5. 安装配置信令服务器
把AppRTC代码仓库内包含的GO语言信令服务器代码链接到$GOROOT/src
下:
$ ln -rs $HOME/apprtc_root/src/collider/collider $GOPATH/src/
$ ln -rs $HOME/apprtc_root/src/collider/collidermain $GOPATH/src/
$ ln -rs $HOME/apprtc_root/src/collider/collidertest $GOPATH/src/
编辑$GOPATH/src/collidermain/main.go
,修改房间服务器为我们前面的房间服务器:
//var roomSrv = flag.String("room-server", "The origin of the room server")
var roomSrv = flag.String("room-server", "The origin of the room server")
编辑$GOPATH/src/collider/collider.go
,设置信令服务器所需要用的HTTPS的证书文件, 找到如下代码,注释后改为这样:
//e = server.ListenAndServeTLS("/cert/cert.pem", "/cert/key.pem")
e =
6. 安装信令服务器collidermain的依赖
$ go get collidermain
安装GO环境的websocket包.
如果上面命令失败,那么则用下面这个麻烦的方法:
$ cd $GOPATH/src
$ wget
$ tar xvf
$ go install golang.org/x/net/websocket/
$ cd -
因为国内网络不好,不能自动下载包安装的话,就手动下载一个,手动安装这个包.
依赖项安装完后,我们安装collidermain
命令服务器程序:
$ go install collidermain
7. 运行信令服务器
$ $GOPATH/bin/collidermain -port=8089 -tls=true
这样,信令服务器也可以通过安全链接方式来访问了.
8. 整体测试
可以用screen
来开启两个终端会话,分别来运行AppRTC
会话房间服务器和Collider
信令服务器.具体方式? 这就不赘述了.