Apprtc服务搭建

转载地址:https://www.cnblogs.com/kakawater/p/7112914.html

Apprtc是一个使用WebRTC技术实现的一个在线聊天室,可以支持两个人进行视频通话,是一个不错的WebRTC 项目。

运行AppRTC需要使用Google App Engine SDK for Python,因为这个项目的Web服务器是使用Google App Engine框架编写的,因此必须要安装。

同时还需要使用Grunt构建工具。

下面介绍如何在Centos 6上来搭建这个Apprtc项目。

Google Engine SDK

官网地址:https://cloud.google.com/appengine/downloads#Google_App_Engine_SDK_for_Python

Google Engine SDK for Python 使用的是Python 2.7。因此在安装Google Engine SDK for Python之前,我们必须安装Python 2.7

安装Python 2.7

官网地址:https://www.python.org/downloads/release/python-2712/

下载Python 2.7源代码:

$wgethttps://www.python.org/ftp/python/2.7.12/Python-2.7.12.tgz

解压

$tar -xf Python-2.7.12.tgz

编译安装

生成Makefile

$./configure

编译

$make

安装

$make install

配置Python 2.7

建立软连接,使系统默认的 python指向 python2.7

$mv/usr/bin/python /usr/bin/python2.6.6

$ln-s/usr/local/bin/python2.7 /usr/bin/python

解决系统 Python 软链接指向 Python2.7 版本后,因为yum是不兼容 Python 2.7的,所以yum不能正常工作,我们需要指定 yum 的Python版本

vi /usr/bin/yum

将文件头部的#!/usr/bin/python改成#!/usr/bin/python2.6.6

下载Google App Engine SDK for Python源码:

$wgethttps://storage.googleapis.com/appengine-sdks/featured/google_appengine_1.9.40.zip

解压

$unzip google_appengine_1.9.40.zip

配置环境变量以使用Google App Engine

export PATH=$PATH:/google_appengine_1.9.40/

配置成功之后我们就可以在命令行中使用dev_appserver.py了

Grunt

Grunt是一个Web项目的构建工具,可以方便我们将一个开发中的Web项目打包成发布版本或测试版本。

Grunt是一个在NodeJS环境下运行的构建工具,因此我们必须先安装NodeJS

安装NodeJS

NodeJS官网:https://nodejs.org/en/

安装

Centos上安装NodeJS文章:https://nodejs.org/en/download/package-manager/

$curl --silent --locationhttps://rpm.nodesource.com/setup_6.x | bash -

$yum install -ynodejs

CNPM

在中国大陆的话,因为众所周知的原因,我们可能需要使用cnpm

npminstall-gcnpm--registry=https://registry.npm.taobao.org

安装Grunt

$npm -g install grunt-cli

如果在中国大陆,不能正常安装的话,尝试使用cnpm.即``

Open-JDK

Apprtc这个项目还需要JAVA环境,因此我们还需要配置一下Java环境。这里我使用的是Open-JDK

官网:http://openjdk.java.net/

安装

$yuminstalljava-1.8.0-openjdk

配置环境变量

Redhat公司提供的OpenJDK环境变量配置参考文章:https://access.redhat.com/documentation/en-US/JBoss_Enterprise_Application_Platform/6/html/Installation_Guide/Install_OpenJDK_on_Red_Hat_Enterprise_Linux.html

$export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.111-0.b15.el6_8.x86_64/jre

Apprtc

下载Apprtc项目源码

$gitclonehttps://github.com/webrtc/apprtc.git

安装项目依赖

$npm install

同样,如果在中国大陆不行的话,可以使用cnpm,即cnpm install

安装JDK(前面安装了就不用安装了)

yuminstalljava-1.8.0-openjdkexportJAVA_HOME=/usr/lib/jvm/java-1.8.0

如果不安装的话,可能会出现如下错误

Warning:Error: Unabletoaccess jarfile undefined Use --forcetocontinue.Aborted duetowarnings.

构建Apprtc项目

$grunt build

常见错误

requests模块不存在

ImportError: No module named requestsWarning: Command failed: python ./build/build_app_engine_package.py src out/app_engineTraceback (most recentcalllast):File"./build/build_app_engine_package.py", line12,inimportrequestsImportError:Nomodulenamed requestsUse--force to continue.Aborted duetowarnings.

解决方法是通过python的包管理工具pip来安装requests

安装pip

下载setup-python工具

$wgethttps://pypi.python.org/packages/2.7/s/setuptools/setuptools-0.6c11-py2.7.egg  --no-check-certificate

赋予setuptools-0.6c11-py2.7.egg执行权限

$chmod +xsetuptools-0.6c11-py2.7.egg

./setuptools-0.6c11-py2.7.egg

下载pip

$wgethttps://pypi.python.org/packages/source/p/pip/pip-1.5.4.tar.gz

解压

$tar -xf pip-1.5.4.tar.gz

安装pip

$python setup.py install

安装requests模块

$pip install requests

运行Apprtc

$ dev_appserver.py apprtc/out/app_engine/

collider信令服务器

collider是Apprtc这个项目配套的一个信令服务器。在我们的Apprtc项目中就已经携带了它的源码。

安装Golang

colider是一个使用Golang语言编写的项目,因此在安装collider之前,我们必须先安装Golang

下载Golang源码

$wgethttps://storage.googleapis.com/golang/go1.6.3.linux-amd64.tar.gz

解压

$tar -xf go1.6.3.linux-amd64.tar.gz

配置Golang环境变量

Go 二进制版本,假设它们会被安装在/usr/local/go(Windows,c:\Go)中,如果没有安装在该位置,我们需要配置一下环境变量

exportGOROOT=exportPATH=$PATH:$GOROOT/bin

GOPATH

GOPATH环境变量用来指定你的工作目录。当我们在开发Golang项目的时候需要指定

The GOPATH environment variable specifies the location of your workspace. It is likely the only environment variable you'll need to set when developing Go code.

GOPATH环境变量用来指定除GOROOT之外包含的Go项目源代码和二进制文件的目录。go install和go工具都会用到GOPATH,作为编译后二进制文件的存放目的地和import包时的搜索路径。

GOPATH是一个路径列表,也就是可以同时指定多个目录。多个目录在Mac和Linux下通过”:”分割;Windows下通过”;”分割。注意,大部分情况下会是第一个路径优先,比如:查找包

Kakawater-2:~kakawater$ mkdir GOWorkPlaceKakawater-2:~kakawater$ cd GOWorkPlace/Kakawater-2:GOWorkPlacekakawater$ export GOPATH=`pwd`

$GOPATH 目录约定有三个子目录:

src 存放源代码(比如:.go .c .h .s等)

pkg 编译后生成的文件(比如:.a)

bin 编译后生成的可执行文件(为了方便,可以把此目录加入到 $PATH 变量中,如果有多个gopath,那么使用${GOPATH//://bin:}/bin添加所有的bin目录)

安装colider

第一步将apprtc/src/colider目录下的collider、collidermain、collidertest拷贝到GOPATH/src/下

修改$GOPATH/src/collidermain/main.go 设置我们的房间服务器,防止第三方使用我们的信令服务器

// var roomSrv = flag.String("room-server", "https://appr.tc", "The origin of the room server")varroomSrv = flag.String("room-server","https://apprtc.kakawater.top","The origin of the room server")

设置信令服务器需要使用的HTTPS证书

编辑$GOPATH/src/collider/collider.go

// e = server.ListenAndServeTLS("/cert/cert.pem", "/cert/key.pem")e = server.ListenAndServeTLS("/Users/kakawater/Documents/nginx/apprtcKakawaterTopSizeSSL/1_apprtc.kakawater.top_bundle.crt","/Users/kakawater/Documents/nginx/apprtcKakawaterTopSizeSSL/2_apprtc.kakawater.top.key")

安装collidermain项目依赖

$gogetcollidermain

安装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/

这样collidermain的项目依赖就安装完了

我们安装collidermain命令服务器程序:

$ goinstallcollidermain

$collidermain --helpUsageofcollidermain:  -port int        The TCP port that the server listenson(default443)  -room-serverstringThe originofthe room server (default"https://apprtc.kakawater.top")  -tls        whether TLSisused (defaulttrue)

启动colider

$collidermain-port=8089 -tls=true

常见错误

因为跨域访问,造成在HTTPS中无法使用信令服务器

Failedto start signaling:Failedto execute'pushState' on'History':Ahistory stateobjectwithURL'http://192.168.20.135/r/769453476' cannot be created in a document with origin 'https://192.168.20.135'.

解决方案

编辑apprtc/out/app_engine/js/apprtc.debug.js

AppController.prototype.pushCallNavigation_=function(roomId, roomLink){if(!isChromeApp()){//window.history.pushState({"roomId":roomId, "roomLink":roomLink}, roomId, roomLink);}};

至此,Apprtc项目搭建完毕。

你可能感兴趣的:(Apprtc服务搭建)