美文网首页iOS视频开发IOSIOS面试裤
WebRTC之AppRTC与信令服务器构建

WebRTC之AppRTC与信令服务器构建

作者: 戴维营教育 | 来源:发表于2016-03-18 20:16 被阅读5172次

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

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

$ 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视频通话了.

相关文章

  • WebRTC之AppRTC与信令服务器构建

    此教程于2016年3月18日更新版本更多原理介绍请参考戴维营教育2015年2月的旧教程:http://io.div...

  • WebRTC 服务器要干些什么

    概述 WebRTC 的服务器大体分为信令服务器和媒体服务器 WebRTC 信令服务器是主要功能是为 WebRTC ...

  • Webrtc服务器搭建

    Webrtc服务器包括:房间服务器(Room Server)、信令服务器(Signaling Server)、防火...

  • WebRTC信令交互流程

    WebRTC信令交互流程: 上述序列中,WebRTC并不提供Stun服务器和Signal服务器,服务器端需要自己实...

  • WebRTC学习(二)

    信令服务器 没有信令服务器,各个WebRTC之间是没办法通信的。传递媒体数据有两个信息,必须经过信令服务器进行交换...

  • WebRTC的apprtc和collider源码分析

    apprtc和collider是WebRTC的官方例子, 源码在https://github.com/webrtc...

  • Ubuntu 下搭建 AppRTC 服务

    研究 WebRTC 协议,最好先自己基于官方 Demo 动手搭一套服务环境,其中包括 房间服务器 AppRTC ...

  • 配置 AppRtc 支持多人加入房间

    -- 配置 AppRtc 支持多人加入房间 基于 AppRtc 搭建的 webrtc 音视频通话默认只支持一对一的...

  • AppRTC(WebRTC)服务器搭建

    前言 最近研究了几天 appr.tc 服务器的搭建,主要目的是想在本地搭建一套 webrtc 服务器环境,可以做一...

  • 自建 AppRTC

    AppRTC 是 webrtc 的一个 demo。自建 AppRTC 可以苦其心志劳其筋骨饿其体肤,更重要的是能学...

网友评论

  • 戴维营教育:没具体没看明白你说的问题
    子曰桃风:已经安装成功,在火狐下可正常访问,谷歌下不能,应该是https这块的问题,我目前使用的是不安全的连接,请问使用安全连接怎么弄,在内网条件下,直接用ip地址访问,按照教程配置Nginx 并没有成功。
    6138b18dc76f:
    执行./google_appengine/dev_appserver.py --host 47.90.100.138 --port 9999 ./apprtc/out/app_engine报错:

    INFO 2017-03-22 13:02:52,091 api_server.py:648] Applying all pending transactions and saving the datastore
    INFO 2017-03-22 13:02:52,091 api_server.py:651] Saving search indexes
    Traceback (most recent call last):
    File "./google_appengine/dev_appserver.py", line 84, in <module>
    _run_file(__file__, globals())
    File "./google_appengine/dev_appserver.py", line 80, in _run_file
    execfile(_PATHS.script_file(script_name), globals_)
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/devappserver2.py", line 1040, in <module>
    main()
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/devappserver2.py", line 1033, in main
    dev_server.start(options)
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/devappserver2.py", line 824, in start
    self._dispatcher.start(options.api_host, apis.port, request_data)
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/dispatcher.py", line 194, in start
    _module.start()
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/module.py", line 1177, in start
    self._balanced_module.start()
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/wsgi_server.py", line 315, in start
    self._start_all_fixed_port(host_ports)
    File "/usr/stay/webrtcserver/google_appengine/google/appengine/tools/devappserver2/wsgi_server.py", line 352, in _start_all_fixed_port
    raise BindError('Unable to bind %s:%s' % self.bind_addr)
    google.appengine.tools.devappserver2.wsgi_server.BindError: Unable to bind 47.90.200.139:8080


    可能是什么原因
    ab6af5324d26:@戴维营教育 竟然回复了好激动呀,稍等。
    chrome在版本47后只允许 https,但我用nginx加了https做反向代理,其它地方也相应改成 了https,又报了Failed to start signaling: Failed to execute 'pushState' on 'History': A history state object with URL 'http://192.168.31.214/r/948401670' cannot be created in a document with origin 'https://192.168.31.214' and URL 'https://192.168.31.214/'.
    我出现的正式跟这个人一样的错误,http没问题,https就出现这个问题,您能帮我解答吗
  • ab6af5324d26:老师,您好!
    我遇到了pushState的问题,您能帮忙指点指点吗!
  • 388521ad3389:各种懵懂搞不明白,有搭建成功的没?
    有偿求搭建,或@戴维营教育 给个联系方式学习搭建
  • 戴维营教育:仅仅是把这个东西归类到一个用户下面.好管理一点而已.
  • bdc8c4057bd7:请问为什么要创建一个用户apprtc?
  • 戴维营教育:那估计是你的stun/turn服务器有问题.
    cc9411b8297c:@戴维营教育 就是用你们的地址,不同网段的,无法连上
  • cc9411b8297c:你好老师,我刚刚测了一下,发现在不同网段的,打洞貌似不成功呢?
  • 91b5f45f7db6:你好,https://api.diveinedu.com/apprtc/iceconfig.php?key=%s输出的结果node.js怎么实现的,里面的username,credential两个值怎么生成呢还是固定死?
    戴维营教育:@吴题Etimes 这个可以参看turn rest api的RFC文档:https://tools.ietf.org/html/draft-uberti-behave-turn-rest-00

本文标题:WebRTC之AppRTC与信令服务器构建

本文链接:https://www.haomeiwen.com/subject/hhhhlttx.html