Webrtc之apprtc与信令服务器构建

戴维营教育原创文章,转载请注明出处。我们的梦想是做最好的iOS开发培训!

0.前言动机

早在去年初(2015年2月)的时候,戴维营教育由于课程需要讲WebRTC实时音视频聊天技术,就写过一个教程一步一步搭建一个WebRTC的后台服务器AppRTC的教程,但是由于Goggle官方代码有改变,导致大部分网友严格按步骤来操作不成功.

现在我们戴维营教育仍然要讲WebRTC技术,同时需要更新技术,在这里再一步一步重新搭建最新代码版本的AppRTC服务器,顺便整理出每一步的更新教程.

此教程于2016年3月18日更新版本 更多原理介绍请参考戴维营教育2015年2月的旧教程: http://io.diveinedu.com/2015/02/05/第六章-Webrtc服务器搭建.html

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代码仓库:

$ https://github.com/webrtc/apprtc.git 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 = 'https://api.diveinedu.com'
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

打开浏览器,服务器服务器http://apprtc.diveinedu.com:8080 ,就可以打开了.

最后一步就是配置Nginx反向代理服务器,提供默认HTTPS的访问, 新建Nginx虚拟主机配置文件,反向代理到8080端口.

配置文件位置是: /etc/nginx/sites-enabled/apprtc.diveinedu.com; 配置文件内容是:

#/etc/nginx/sites-enabled/apprtc.diveinedu.com
upstream roomserver {
        server localhost:8080;
}


server {
        listen 80 ;
        server_name apprtc.diveinedu.com;
        return  301 https://$server_name$request_uri;
}

server {
        listen 443 ;
        ssl on;
        # 域名为apprtc.diveinedu.com的SSL证书文件
        ssl_certificate      /etc/nginx/apprtc.diveinedu.com.crt;
        ssl_certificate_key  /etc/nginx/apprtc.diveinedu.com.key;

        server_name apprtc.diveinedu.com;
        access_log  /var/log/nginx/apprtc.diveinedu.com.log;
        location / {
                proxy_pass http://roomserver$request_uri;
                proxy_set_header Host $host;
        }

}

保存退出后, 重启nginx服务器.就可以通过https://apprtc.diveinedu.com安全连接方式访问会话房间服务器了.

关于免费的HTTPS/SSL证书请去沃通官网申请: https://buy.wosign.com/free/

信令服务器还没准备好,下面再慢慢的来安装配置信令服务器.

4. 安装GO环境

下载Go安装包:

    $ wget https://storage.googleapis.com/golang/go1.5.3.linux-amd64.tar.gz
    $ 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", "https://apprtc.appspot.com", "The origin of the room server")
var roomSrv = flag.String("room-server", "https://apprtc.diveinedu.com", "The origin of the room server")    

编辑$GOPATH/src/collider/collider.go,设置信令服务器所需要用的HTTPS的证书文件, 找到如下代码,注释后改为这样:

//e = server.ListenAndServeTLS("/cert/cert.pem", "/cert/key.pem")
e = server.ListenAndServeTLS("/etc/nginx/apprtc.diveinedu.com.crt", "/etc/nginx/apprtc.diveinedu.com.key")

6. 安装信令服务器collidermain的依赖

$ go get collidermain

安装GO环境的websocket包. 如果上面命令失败,那么则用下面这个麻烦的方法:

$ cd $GOPATH/src
$ wget http://www.golangtc.com/static/download/packages/golang.org.x.net.tar.gz
$ tar xvf golang.org.x.net.tar.gz
$ go install golang.org/x/net/websocket/
$ cd -

因为国内网络不好,不能自动下载包安装的话,就手动下载一个,手动安装这个包.

依赖项安装完后,我们安装collidermain命令服务器程序:

$ go install collidermain

7. 运行信令服务器

$  $GOPATH/bin/collidermain -port=8089 -tls=true

这样,信令服务器也可以通过安全链接方式来访问了.

8. 整体测试

可以用screen来开启两个终端会话,分别来运行AppRTC会话房间服务器和Collider信令服务器.具体方式? 这就不赘述了.

到这一步,我们的AppRTC后台就完美搭建成功了,用谷歌火狐浏览器打开 https://apprtc.diveinedu.com/ 就可以随意的建立WebRTC视频通话了.

戴维营学院(高级开发视频): http://v.diveinedu.com

潜心俱乐部(iOS面试必备): http://divein.club