• 主流Webrtc流媒体服务器之Kurento Media Server


    一、 什么是Kurento Media Server

    Kurento Media Server(KMS)是一个多媒体服务器软件包,可用于为WebRTC平台开发高级视频应用程序。Kurento是一个底层平台,可创建WebRTC应用程序,而且负责管理STUN / TURN服务器,网络,可伸缩性等。

    1.1. Kurento Media Server的特点

    1.1.1. 模块化管道

     

     

    Kurento提供了WebRTC和RTP发送器和接收器、音视频混合器、媒体录制等构建模块。这些媒体元素是具有特定媒体功能的独立对象。通过在任何时间点插入,激活或停用它们,它们非常容易组成,即使介质已经在流动。

    扩展Kurento并编写自己的元素也很容易,然后可以将其与现有元素集成在一起!

    应用程序开发人员使用Kurento用所需的媒体元素控制所谓的媒体管道,从而有效地形成完全定制的体系结构,以适应他们的需求。提供了一些内置模块,用于组通信,媒体格式的代码转换以及视听流的路由。

    Kurento可以同时实现SFU和MCU应用架构。

     

    1.1.2. 内建模块

    Kurento提供丰富的开箱即用的媒体元素工具集API

      

    1.1.3. JSON-RPC协议

    KMS通过JSON-RPC协议公开其所有API功能,可以通过WebSocket连接直接访问。以下为三种使用情况:

      

    1.2. 为什么使用Kurento Media Server

    Kurento Media Server(KMS)提供媒体传输、处理、录制 和回放。KMS建立在出色的GStreamer多媒体库之上,并提供以下功能:

    a. 网络流协议,包括HTTP,RTP和WebRTC。

    b. 支持MCU和SFU媒体混合和媒体路由与调度。

    c. 对实现计算机视觉和增强现实算法的过滤器的通用支持。

    d. 媒体存储支持WebM和MP4的写入操作以及GStreamer支持的所有格式的播放。

    e. GStreamer支持的任何编解码器之间的自动媒体转码,包括VP8,H.264,H.263,AMR,OPUS,Speex,G.711等。

     

     

    二、 什么是OpenVidu

    OpenVidu是一个基于Kurento的框架,并封装了其大部分功能,以便简化WebRTC的一些最典型的使用案例,例如会议室。

    使用OpenVidu的开发人员无需担心构成典型WebRTC通信的所有低级技术和协议。该项目的主要目标是提供一个更简单的API:仅包含OpenVidu客户端库,并使用OpenVidu Server处理媒体流,您将拥有一个功能全面的WebRTC功能的应用程序。

    2.1. OpenVidu的特点

    2.1.1. WebRTC视频会议

    支持一对一、一对多、多对多视频会议

    2.1.2. 开源

    OpenVidu是根据Apache License v2许可的OpenSource的开源项目

    2.1.3. 多平台

    兼容Chrome,Firefox,Safari,Opera,Edge,Android,iOS,桌面应用程序

    2.1.4. 使用简单

    OpenVidu提供了即用型组件,您只需将其粘贴到代码中即可快速启动和运行视频通话。

    2.1.5. 部署容易

    OpenVidu提供Docker部署方案,只需简单几步,就可以成功部署OpenVidu

    2.1.6. 提供教程/演示

    OpenVidu提供许多教程和示例,对开发人员是非常友好

    2.1.7. 保持视频会议的私密性

    提供WebRTC加密,可确保您的所有通话都完全私密

    2.1.8. 兼容许多前端技术

    支持JavaScript,TypeScript,Angular,React,Vue.js,Ionic ...您只需选择喜欢的语言和框架

    2.1.9. 与任何后端技术兼容

    OpenVidu提供了开箱即用的Java和Node客户端,用于控制视频通话,但它还公开了REST API以允许使用任何后端技术。

    2.1.10. 使用预定义角色限制客户端功能

    确定允许哪个用户订阅,发布或主持具有预定义角色的视频流以保护您的视频通话

    2.1.11. 信息广播

    您可以使用OpenVidu在几行代码中实现聊天。您的应用程序可能需要任何用户到用户的基于文本的通信,都可以轻松实现

    2.1.12. 录制

    完全自由地录制视频通话:OpenVidu提供了预定义的布局,您也可以使用自己的自定义布局来完成任何类型的结果

    2.1.13. 屏幕共享

    OpenVidu允许您的客户端共享他们的屏幕

    2.1.14. 音频和视频过滤器

    OpenVidu是唯一允许您应用实时音频和视频过滤器的WebRTC技术。检测条形码,设置色度键背景或放大客户端的声音只是使用OpenVidu过滤器可以实现的几个示例。

    2.1.15. 网络摄像机

    您可以使用OpenVidu接收IP摄像机进行实时监视

     

    三、 部署OpenVidu

    # 安装DOCKER
    
    $ sudo apt remove -y docker docker-engine docker.io containerd runc
    
    $ sudo apt install -y apt-transport-https ca-certificates curl gnupg-agent software-properties-common
    
    $ sudo curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
    
    $ sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
    
    $ sudo apt update
    
    $ sudo apt install -y docker-ce docker-ce-cli containerd.io
    
    
    
    
    # 安装DOCKER-COMPOSE
    
    $ sudo curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o $ /usr/local/bin/docker-compose
    
    $ sudo chmod +x /usr/local/bin/docker-compose
    
    
    
    
    # 安装OPENVIDU
    
    $ sudo curl https://s3-eu-west-1.amazonaws.com/aws.openvidu.io/install_openvidu_latest.sh | bash
    
     

     

    四、 运行示例 Hello-world

    # 安装NODE
    
    $ sudo apt install -y nodejs npm
    
    $ sudo npm config set registry https://registry.npm.taobao.org
    
    $ sudo npm install n -g
    
    $ sudo n stable
    
    
    
    
    # 安装GIT
    
    $ sudo apt install -y git
    
    
    
    
    # 下载与运行Hello-world示例
    
    $ git clone https://github.com/OpenVidu/openvidu-tutorials.git
    
    $ npm install -g http-server
    
    $ http-server openvidu-tutorials/openvidu-hello-world/web
    
     

     

    五、 结语

    到此为止,大家对Kurento Media Server的原理和使用有一个大概的认识了吧,Kurento Media Server是一个很不错的框架,它功能强大而且容易入手,本人所在公司也有产品在使用。

    接下来我会讲解其它一些主流的Webrtc流媒体服务器,敬请关注。

  • 相关阅读:
    window7环境下VMWare自定义安装Linux虚拟机完全教程
    Extjs的GridPanel分页前后台完整代码实例
    python数据持久存储:pickle模块的基本使用
    一个 11 行 Python 代码实现的神经网络
    Hadoop入门实例——WordCount统计单词
    Linux环境搭建Hadoop伪分布模式
    函数
    循环
    docker环境下gitlab配置ci
    docker部署mysql配置过程记录
  • 原文地址:https://www.cnblogs.com/eflypro/p/14742142.html
Copyright © 2020-2023  润新知