一文学会快速搭建Janus服务端

1、概述

想要了解Janus,首先需要知道WebRTC以及Janus和WebRTC之间的关系,本文将会对这些内容做简单的介绍,同时也会介绍一下Janus的架构,Janus可以实现的功能,并展示如何快速搭建一套Janus的后台服务器,最后利用官方的前端demo,实现sip通话。

2、JANUS简介

什么是WebRTC,它有哪些功能?WebRTC (Web Real-Time Communications) 是一个开源项目是一项实时通讯的技术,旨在使得浏览器能为实时通信提供简单的JavaScript接口,让浏览器通过JS实现即时通信接口。这个接口是通过一系列的信令,建立一个浏览器与浏览器之间(peer-to-peer)的信道,这个信道可以发送任何数据,而不需要经过服务器。并且WebRTC通过实现MediaStream,通过浏览器调用设备的摄像头、话筒,使得浏览器之间可以传递音频和视频。

那么什么是Janus呢?janus是一个WebRTC网关,由Meeteco设计和开发,是为Linux系统量身定制的,也可以在MacOS编译和安装。Windows不受支持,但如果需要的话,Janus可以在Windows 10中的“Windows Subsystem for Linux”上工作。

3、JANUS的架构及各文件作用

3.1、janus架构图

image 28
image 28

3.2、janus部分目录及文件的作用

image 29
image 29

4、JANUS服务端的简单搭建

好了说了这么多废话,下面就开始Janus服务端的搭建,搭建环境为centos7。

4.1、安装依赖包

首先需要安装janus的相关依赖包,以保证Janus服务能正常运行。其中有些依赖包是在github上的,下载的时候可能出现速度比较慢,或者出现会卡顿无法下载等情况,wget多试几次,多等待一会即可。

image 37
image 37
image 38
image 38

4.2、安装Janus

安装完Janus相关的依赖包以后,便要进入到我们主程序的安装,Janus的安装如下。

image 34
image 34

到此,janus的服务器的安装已经完成了。janus安装完成以后,是安装在/opt/janus目录的, 进入目录后可以看到组成结构,其中,Janus的执行文件在bin文件夹中,配置在etc/janus文件夹中。

image 27
image 27
image 31
image 31

由于本文旨在快速搭建,并实现sip通话,就不对配置做一一介绍,直接使用默认的配置启动,配置文件默认https是关闭,如需开启,需要进入janus.transport.http.jcfg文件中,将https = false改为true,并且需要将cert_pem和cert_key配置为有效的https证书路径再启动。

image 35
image 35
image 33
image 33

4.3、启动Janus

image 36
image 36
image 39
image 39
image 42
image 42

查看进程:ps -ef|grep janus

查看相关端口:netstat -apn|grep janus

停止进程:直接kill即可:kill -9 xxx

到此,可以看到http端口和ws端口已经提示启动成功了,这也表示Janus的后端服务已经启动成功了。个人认为对于Janus的服务端,不一定非要通过janus的配置开启https,可以通过nginx做一层转发即可。

4.4、前端项目

上面图中能看到Janus的目录中有一个share目录,/opt/janus/share/janus/demos这个目录下,即使demo环境了。将demos目录拷贝本地nginx的www目录中,www目录为nginx的安装目录,然后访问即可。由于本文主要是搭建简单的sip,所以只需要关注janus.js, settings.js,siptest.html,siptest.js,在启动窗口可以看到后端为http请求的服务端口为8088,将settings.js中的server改为本机的8088端口即可,如果需要集成到自己的项目中,也只需要对这几个文件进行修改。部署完成以后,浏览器访问http://localhost:8088/demos即可访问。页面如下,点击demos,选择Sip Gateway, 点击start,填入真实的sip话机信息,即可实现从浏览器打电话。

image 40
image 40
image 43
image 43

4.5、项目部署遇到的坑

4.5.1、版本问题

前端代码的版本和服务端使用同一版本,在开发过程中,如果使用老版本的前端的js文件修改后调用高版本的服务端,由于一下协议的不同,可能会导致电话打通后秒挂,所以要注意使用同一版本的前后端。

4.5.2、nice_address_ip_version

检查一下依赖环境,参考4.1安装依赖包有关于libnice这段安装。

4.5.3、提示找不到libsrtp

image 32
image 32

4.5.4、提示找不到 libnice

image 30
image 30

4.5.5、要使用libsrtp1.5.4

在configure janus 时加上 –disable-libsrtp2。

4.5.6、libwebsockets.so.12报错

  错误提示:libwebsockets.so.12: cannot open shared object file: No such file or directory。

image 41
image 41