Kurento应用开发指南(以Kurento 5.0为模板) 之一:简介,安装与卸载

2024-08-21 17:58

本文主要是介绍Kurento应用开发指南(以Kurento 5.0为模板) 之一:简介,安装与卸载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录
1. Kurento是什么               3
2. Kurento简介                       3
2.1 WebRTC媒体服务器               3
2.2 Kurento 媒体服务器               4
2.3 Kurento API, 客户端和协议       5
2.4  使用Kurento创建应用程序       7
3. Kurento Media Server的安装与卸载    8
3.1  Kurento Media Server的安装       8
3.2 kurento Media Server的启动与停止   8
3.3. kurento Media Server的卸载 8
4.  STUN和TURN服务配置 9
4.1.  STUN服务器配置 9
4.2.  TURN服务器配置 10
5. Kurento教程 11
5.1  Node.js 教程1 - Hello world 11
5.1.1 运行示例程序 11
5.1.2 运行时的出错 12
5.1.3 示例程序的分析 14
5.1.4 应用程序服务端逻辑 16
5.1.5  客户端逻辑 19
5.1.6 依赖库 20
5.2  教程3一对多的视频呼叫 21
5.2.1 运行示例程序 21
5.2.2  理解这个示例程序 21
5.2.3 应用程序服务端逻辑 24
5.2.4  客户端 29
5.2.5 依赖库 30
5.3 教程四-一对一的视频呼叫 31
5.3.1 运行示例程序 31
5.3.2 Understanding this example 31
5.3.3 应用程序服务端逻辑 33
5.3.4 客户端 40
5.3.5 依赖库 43
11. Kurento 架构 43
11.1 Kurento API和接口 44
11.2 Kurento 模块 45
11.3 使用Kurento创建应用程序 46
11.4 客户端,服务端和Kurento的通信 47
11.5 使用kurento实现实时WebRTC应用 49
11.6 Kurento 设计原则 51

1. Kurento是什么

Kurento是一个WebRTC媒体服务器,并且包含一个客户端API集合,
用以简化WWW和移动平台上的高级视频应用程序的开发。
Kurento的功能包括组通信,转码,记录,混音,广播和routing of audiovisual flows。
Kurento同样提供高级的媒体处理能力,包括计算机视觉,视频检索,虚拟现实和语音分析。
Kurento模块化的架构使得其集成第三方媒体处理算法(如语音识别,场景分析,人脸识别等)很简单,
而且它可以被应用程序开发者视为透明。
Kurento的核心组成是Kurento媒体服务器,它用来负责媒体传输,处理,加载和记录。
它是基于GStreamer,优化了资源消耗来实现的。它提供的功能如下:
• 网络流协议,包括HTTP(作为客户端和服务端工作),RTP和WebRTC.
• 组通信(MCU和SFU功能),支持媒体混合和媒体路由/分发
• 原生支持计算机视觉和虚拟现实滤镜
• 媒体存储,支持WebM和MP4的写操作,能播放GStreamer支持的所有格式
• 自动的媒体转换,支持GStreamer提供的所有codec,包括VP8, H.264, H.263, , AMR, OPUS, Speex, G.711,等。
它还提供的许多基于Java和Javascript的Kurento客户端库,用来提供给应用程序控制Kurento媒体服务器。
如果你喜欢其它的编程语言,可以使用基于WebSocket和JSON-RPC的Kurento协议来实现。
Kurento是开源的,它基于 LGPL version 2.1许可协议,它的源码位于GitHub。.
如果你想快速上手,最好的方式是安装Kurento媒体服务器并学习官方提供的示例教程。
如果想利用好Kurento,可以看本指南的高级部分。

2. Kurento简介

2.1 WebRTC媒体服务器

WebRTC是一项开源技术,它能够通过JavaScript API实现网页浏览器间的实时通信。
它被认为是一种P2P技术,能实现浏览器间的实时通信,而不用通过任何类型的媒体中继。
这种方式能足以实现一些基本的应用,但是有些功能,如组通信,媒体流录制,
媒体广播或媒体转码是很难实现的。基于这个原因,很多应用还是需要有媒体服务器。
 
Figure 1.1: Peer-to-peer WebRTC approach vs. WebRTC through a media server
在概念上,WebRTC媒体服务器是一种多媒体中继(它位于两个通信端的中间)。
媒体服务器能处理媒体流,并有各种功能,包括组通信(分发一个端生成的媒体流到多个接收端,
如像Multi-Conference Unit, MCU的工作方式),混合(转换多个输入流合成一个组合流),
转码(在不兼容的客户端间选择codec和格式), 录制等
 
Figure 1.2: Typical WebRTC Media Server capabilities


2.2 Kurento 媒体服务器

Kurento架构的核心是媒体服务器,它被命名为Kurento媒体服务器(KMS)。
Kurento媒体服务器的媒体处理能力是插件式的,意思是它的功能都是插件模块,
可以被激活和关闭。而且,开发者可以无缝地创建额外的模块来扩展Kurento媒体服务器并动态插入。
Kurento媒体服务器提供即时可用的组通信,混合,转码,录制和播放。
另外,它还提供一些高级的媒体处理模块,包括有计算机视觉,虚拟现实,透镜等;
 
Figure 2.1: Kurento Media Server capabilities


2.3 Kurento API, 客户端和协议

Kurento媒体服务器的能力是通过Kurento API呈现给应用开发者的。
这些API是通过叫做Kurento Client库实现的。
Kurento提供了两种类型的客户端库: Java和JavaScript。
如果你希望使用其它的语言,可以通过Kurento 协议来直接操作Kurento。
这个协议可以控制Kurento媒体服务器,它是基于标准的网络协议如WebSocket和JSON-RPC。
下图显示了Kurento客户端的三种应用场景:
• 在兼容WebRTC的浏览器上直接使用Kurento JavaScript Client
• 在Java EE Application Server上使用Kurento Java Client 
• 在Node.js 服务器上使用Kurento JavaScript Client
这三种场景在教程中都有完整的示例程序。
 
Figure 3.1: Connection of Kurento Clients (Java and JavaScript) to Kuento Media Server


Kurento Client的API是基于Media Element的概念,每个Media Element都有特定的媒体能力。
例如,WebRtcEndpoint有发送和接收WebRTC媒体流的能力;
RecorderEndpoint 有将接收到的媒体流存储到文件的能力;
FaceOverlayFilter 能检测视频流中的人脸并添加一个特定的图片在人脸之上。
Kurento拥有丰富的媒体元素工具箱来做为它的API的一部分。
 
Figure 3.2: Some Media Elements provided out of the box by Kurento


更好的理解这些概念需要参见本文档中关于Kurento API和Kurento Protocol的章节.
你同样还需要看看Java文档和JS文档:
• kurento-client-java : JavaDoc of Kurento Java Client.
• kurento-client-js : JsDoc of Kurento JavaScript Client.
• kurento-utils-js : JsDoc of an utility JavaScript library aimed to simplify the development of WebRTC applications.


2.4  使用Kurento创建应用程序

从应用程序开发人员的角度来看,媒体元素就像是乐高积木:
你只需选择应用程序想要的元素,然后再它连接到想要的拓扑结构中。
在Kurento的术语中,媒体元素的连接图被称作媒体管道。
因此,当你想创建一个管道时,开发人员需要确定想要使用的媒体元素的能力,
并确定媒体元素间如何连接的拓扑图。这些连接是通过连接原语控制(以Kurento Client APIs方式显现)。
这些原语以拓扑上后续的元素作为参数,激活本元素作为源:
sourceMediaElement.connect(sinkMediaElement)


例如,如果你想创建一个录制WebRTC流到文件的应用程序,
你需要两个媒体元素:WebRtcEndpoint 和 RecorderEndpoint。当一个客户端连接到这个应用程序时,
你需要实例化这两个媒体元素,并使用 WebRtcEndpoint 
(它用来接收WebRTC流)来接收流后输送给RecorderEndpoint (它用来将媒体流录制到文件)。
最后,你需要连接它们,这样就能实现将前一个媒体元素接收到的流输送给后一年媒体元素,
像下面这样:
WebRtcEndpoint.connect(RecorderEndpoint)


为了简化在客户端的WebRTC流的处理,Kurento提供了一个叫WebRtcPeer的实体,
而且,标准的WebRTC API (getUserMedia, RTCPeerConnection,and so on) 
同样能连接到WebRtcEndpoints。更多的信息可以参见示例程序的章节
 
Figure 4.1: Simple Example of a Media Pipeline




3. Kurento Media Server的安装与卸载

3.1  Kurento Media Server的安装

Kurento Media Server必须安装在Ubuntu 14.04 LTS (32 or 64 bits)下。
考虑到在Ubuntu Server 14.04下安装Kurento Media Server时,
工具add-apt-repository默认是没有安装的,可以用下面的命令安装。
# sudo apt-get install software-properties-common


使用下面的命令可以安装 Kurento Media Server的最新版本,依据下面的顺序,一次一个命令。
安装过程中有问答时,回复肯定即可:
# sudo add-apt-repository ppa:kurento/kurento
# sudo apt-get update
# sudo apt-get install kurento-media-server


3.2 kurento Media Server的启动与停止

现在,Kurento Media Server安装并已启动了。可以使用下面的命令启动和停止。
# sudo service kurento-media-server start
# sudo service kurento-media-server stop
Kurento Media Server 的日志文件位于 /var/log/kurento-media-server/media-server.log。


3.3. kurento Media Server的卸载

卸载使用如下命令:
# sudo apt-get remove kurento-media-server
# sudo apt-get purge kurento-media-server
或者彻底卸载:
# sudo apt-get remove kurento*
# sudo apt-get autoremove
# sudo apt-get update
# sudo apt-get dist-upgrade


3.4 Kurento Media Server的手动编译安装

Kurento Media Server
To build Kurento Media Server you need an Ubuntu 14.04 LTS operating system.
First you have to install all needed development tools and dependencies executing the following commands:
# sudo add-apt-repository ppa:kurento/kurento
# sudo apt-get update
# sudo apt-get install git
# sudo apt-get install libthrift-dev thrift-compiler libjsoncpp-dev
# sudo apt-get install gstreamer1.0* libgstreamer1.0-dev
# sudo apt-get install libgstreamer-plugins-base1.0-dev libnice-dev gtk-doc-tools
# sudo apt-get install cmake libglibmm-2.4-dev uuid-dev libevent-dev libboost-dev
# sudo apt-get install libboost-system-dev libboost-filesystem-dev
# sudo apt-get install libboost-test-dev libsctp-dev
# sudo apt-get install libopencv-dev autoconf git libjsoncpp-dev
# sudo apt-get install libtool libsoup2.4-dev tesseract-ocr-dev tesseract-ocr-eng
# sudo apt-get install libgnutls28-dev gnutls-bin libvpx-dev

Plase take care that the list of dependencies changes as dependencies change and new features are added, 
you can check the actual packages that the Ubuntu PPA needs for building from sources in the Build-Depends of the latest release debian/control file.
Second you have to get the source code clonning git repository:
# git clone https://github.com/Kurento/kurento-media-server.git
Then you can compile Kurento Media Server:
# mkdir build
# cd build
# cmake ..
# make
Finally, install it into the system as a service:
# git submodule update --recursive --init
# dpkg-buildpackage -us -uc
# sudo dpkg -i ../kurento_<version>_<arch>.deb
And start and stop it:
# sudo service kurento-media-server start
# sudo service kurento-media-server stop


4.  STUN和TURN服务配置

如果Kurento Media Server位于NAT之后,这时就需要使用 STUN or TURN来实现NAT穿透。
在大多数情况下,STUN服务器可以满足需要,只有在NAT是对称的时,才需要TURN服务器。


4.1.  STUN服务器配置

为了安装STUN服务器,需要取消Kurento Media Server配置文件中的下面两行的注释,
配置文件位于 /etc/kurento/kurento.conf.json  :
"stunServerAddress" : "stun ip address",
"stunServerPort" : 3478


参数 stunServerAddress  应当是一个IP地址,不能是域名。
而且需要注意它的JSON格式,如果 stunServerPort 行是WebRtcEndpoint  区域的最后一行,
那么它不能以逗号(,)结束。
下面是一些可用的公共的STUN服务器,例如:
173.194.66.127:19302
173.194.71.127:19302
74.125.200.127:19302
74.125.204.127:19302
173.194.72.127:19302
74.125.23.127:3478
77.72.174.163:3478
77.72.174.165:3478
77.72.174.167:3478
77.72.174.161:3478
208.97.25.20:3478
62.71.2.168:3478
212.227.67.194:3478
212.227.67.195:3478
107.23.150.92:3478
77.72.169.155:3478
77.72.169.156:3478
77.72.169.164:3478
77.72.169.166:3478
77.72.174.162:3478
77.72.174.164:3478
77.72.174.166:3478
77.72.174.160:3478
54.172.47.69:3478


4.2.  TURN服务器配置

为了安装TURN服务器,需要取消Kurento Media Server配置文件(/etc/kurento/kurento.conf.json)
下面这行的注释:
"turnURL" : "user:password@address:port"
和前面的一样,TURN地址也必须是IP地址(不能是域名)。同样也要注意JSON格式的最后一行的逗号。TURN配置的示例如下:
"turnURL" : "kurento:kurento@193.147.51.36:3478"
或使用免费的numb STUN/TURN服务器如下:
"turnURL" : "user:password@66.228.45.110:3478"
有一个TURN服务器的开源实现:coturn.(https://code.google.com/p/coturn/). 

这篇关于Kurento应用开发指南(以Kurento 5.0为模板) 之一:简介,安装与卸载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1093871

相关文章

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.