欢迎访问我的GitHub

https://github.com/zq2599/blog_demos

内容:所有原创文章分类汇总及配套源码,涉及Java、Docker、Kubernetes、DevOPS等;

关于《kurento实战》系列

《kurento实战》系列是欣宸原创的音视频领域实战专题,旨在通过实战学习主流的实时音视频技术,很荣幸与您一同开启这段精彩的旅程;

关于Kurento

  • Kurento由WebRTC媒体服务器和一系列客户端应用组成,用于简化web和智能设备上的实时音视频开发;
  • 官方架构图如下,顶部的紫色区域是端侧,左下角红色区域是提供音视频服务的Kurento Media Server(KMS),右下角绿色区域是业务服务,通过API与KMS交互,对KMS和端侧的提供信令和控制服务(例如点对点聊天时找到对方,多人聊天是提供房间的业务逻辑):

关于WebRTC(Web Real-Time Communication)

WebRTC是一项在浏览器内部进行实时视频和音频通信的技术,是谷歌于2010年以6820万美元收购VoIP软件开发商 Global IT Solutions 公司而获得,可以在浏览器内部进行实时视频和音频通信,谷歌于2011年6月3日开源该项目,有关WebRTC的知识不在本文展开,但下图是典型的实时通信流程,非常重要:

本篇概览

作为《kurento实战》的开篇,今天咱们一起来尝试部署核心服务Kurento Media Server(KMS),再运行一个demo应用验证KMS可用;

版本信息

  1. 操作系统:Ubuntu 16.04.5 LTS
  2. KMS:6.13.0
  3. JDK:1.8.0_191
  4. SpringBoot:2.3.3.RELEASE
  • 注意:本次实战全程使用root帐号
  • 接下来开始部署KMS;

操作

  1. 关闭防火墙;
  2. 安装gnupg:
apt-get install --no-install-recommends --yes gnupg
  1. 设置环境变量:
DISTRO="xenial"
  1. 从密钥服务器下载密钥到可信任的密钥列表,为后面的安装做准备:
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 5AFA7A83
  1. 添加kurentu源地址:
tee "/etc/apt/sources.list.d/kurento.list" >/dev/null <<EOF
deb [arch=amd64] http://ubuntu.openvidu.io/6.13.0 $DISTRO kms6
EOF
  1. 安装kms:
apt-get update && apt-get install --yes kurento-media-server
  1. 启动kms:
service kurento-media-server start
  1. 查看kms状态,如下,可见服务启动成功(active):
root@docker:~# service kurento-media-server status
● kurento-media-server.service - LSB: Kurento Media Server daemon
Loaded: loaded (/etc/init.d/kurento-media-server; bad; vendor preset: enabled)
Active: active (running) since Fri 2021-01-01 05:39:24 PST; 2s ago
Docs: man:systemd-sysv-generator(8)
Process: 4815 ExecStart=/etc/init.d/kurento-media-server start (code=exited, status=0/SUCCESS)
Tasks: 24
Memory: 17.3M
CPU: 242ms
CGroup: /system.slice/kurento-media-server.service
└─4828 /usr/bin/kurento-media-server Jan 01 05:39:24 docker systemd[1]: Starting LSB: Kurento Media Server daemon...
Jan 01 05:39:24 docker kurento-media-server[4815]: * Start Kurento Media Server
Jan 01 05:39:24 docker kurento-media-server[4815]: * Configure Kernel resource limits for Kurento Media Server
Jan 01 05:39:24 docker kurento-media-server[4815]: ...done.
Jan 01 05:39:24 docker systemd[1]: Started LSB: Kurento Media Server daemon.
  1. 执行以下命令确认响应是否正常:
curl -i -N \
-H "Connection: Upgrade" \
-H "Upgrade: websocket" \
-H "Host: 127.0.0.1:8888" \
-H "Origin: 127.0.0.1" \
http://127.0.0.1:8888/kurento
  1. 如果控制台响应以下内容,证明KMS已经可以正常服务了:
HTTP/1.1 500 Internal Server Error
Server: WebSocket++/0.7.0
  1. 至此,KMS部署和启动已经完成,接下来咱们快速体验KMS的基础能力;

体验KMS

  • 接下来部署一个SpringBoot应用,通过应用的网页服务体验KMS,这个应用部署在另一台电脑上(和KMS部署在一起也没任何问题),整个环境情况如下:

  1. 登录到上图的192.168.133.208电脑,关闭防火墙;
  2. 在192.168.133.208电脑上安装JDK8;
  3. 本文的重点是KMS部署,关于SpringBoot应用无需开发,下载我准备好的jar文件即可,地址是:https://download.csdn.net/download/boling_cavalry/14012545
  4. 将helloworld-0.0.1-SNAPSHOT.jar下载到192.168.133.208,再执行以下命令即可启动应用,注意参数-Dkms.url的IP是KMS电脑的地址:
java -Dkms.url=ws://192.168.133.207:8888/kurento -jar helloworld-0.0.1-SNAPSHOT.jar
  1. 控制台输出以下内容,表示启动成功:
[root@centos7 ~]# java -Dkms.url=ws://192.168.133.207:8888/kurento -jar helloworld-0.0.1-SNAPSHOT.jar

  .   ____          _            __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v2.3.3.RELEASE) 2021-01-03 12:30:56.702 WARN 24669 --- [ main] o.s.boot.StartupInfoLogger : InetAddress.getLocalHost().getHostName() took 10004 milliseconds to respond. Please verify your network configuration.
2021-01-03 12:31:06.719 INFO 24669 --- [ main] c.b.helloworld.HelloWorldApplication : Starting HelloWorldApplication on centos7 with PID 24669 (/root/helloworld-0.0.1-SNAPSHOT.jar started by root in /root)
2021-01-03 12:31:06.719 INFO 24669 --- [ main] c.b.helloworld.HelloWorldApplication : No active profile set, falling back to default profiles: default
2021-01-03 12:31:07.970 INFO 24669 --- [rbeatExec-e1-t0] o.k.j.c.JsonRpcClientNettyWebSocket : [KurentoClient] Connecting native client
2021-01-03 12:31:07.974 INFO 24669 --- [rbeatExec-e1-t0] o.k.j.c.JsonRpcClientNettyWebSocket : [KurentoClient] Creating new NioEventLoopGroup
2021-01-03 12:31:23.159 INFO 24669 --- [ntLoopGroup-2-1] o.k.j.c.JsonRpcClientNettyWebSocket : [KurentoClient] Initiating new Netty channel. Will create new handler too!
2021-01-03 12:31:23.267 WARN 24669 --- [ main] org.kurento.client.KurentoClient : Connected to KMS in 15294 millis (> 5000 millis)
2021-01-03 12:31:24.241 INFO 24669 --- [ main] c.b.helloworld.HelloWorldApplication : Started HelloWorldApplication in 53.092 seconds (JVM running for 53.509)
  1. 在浏览器访问地址:https://192.168.133.208:8443 ,由于使用了自签证书,浏览器会有安全提示,点击下图红框中的按钮:

  1. 点击下图红框中的链接,即可访问SpringBoot应用的首页:

  2. 首页效果如下,这是Kurento官方的hello-world项目,确保您当前电脑上的麦克风摄像头都正常,再点击下图红框中的Start按钮,即可开始WebRTC流程:

  1. 出于安全考虑,浏览器会弹出确认窗口,如下图红框,点击确认后摄像头开始捕捉画面:

  1. 如下图,WebRTC已经开始正常工作:

  1. 聪明的您应该发现了,这个应用的功能是将本地摄像头的数据给到KMS,再从KMS取视频到本地展示,官方给出的流程图如下:

  1. 如果您使用的浏览器是Chrome,再打开一个标签,输入地址:chrome://webrtc-internals/ ,可以查看WebRTC的详情,如下图,可以看到PeerConnection的详细信息:

  1. 如下图红框所示,本地输出到KMS的视频流,编码格式为VP8:

  1. 您可以继续尝试,登录KMS机器执行以下命令停止KMS服务,再回到网页时,发现左侧的预览窗口依旧正常工作,但是右侧的远程视频窗口已经静止不动了:
service kurento-media-server stop
  • 至此,KMS从部署到体验的操作都完成了,希望本文能协助您完成最基本的kurento体验,接下来的文章咱们继续写代码做实战,一边动手一边学习kurento;

你不孤单,欣宸原创一路相伴

  1. Java系列
  2. Spring系列
  3. Docker系列
  4. kubernetes系列
  5. 数据库+中间件系列
  6. DevOps系列

欢迎关注公众号:程序员欣宸

微信搜索「程序员欣宸」,我是欣宸,期待与您一同畅游Java世界...

https://github.com/zq2599/blog_demos

Kurento实战之一:KMS部署和体验的更多相关文章

  1. Kurento实战之二:快速部署和体验

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. Jenkins流水线(pipeline)实战之:从部署到体验

    关于Jenkins流水线(pipeline) Jenkins 流水线 (pipeline) 是一套插件,让Jenkins可以实现持续交付管道的落地和实施. 关于blueocean Blue Ocean ...

  3. Kurento实战之四:应用开发指南

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  4. Ubuntu部署和体验Nexus3

    关于Nexus 如下图,在局域网部署了Nexus之后,可以缓存中央仓库的jar,开发者开发的二方库发布到Nexus上,局域网内的其他人也可以从Nexus下载这些二方库使用: 环境信息 本次实战是在Li ...

  5. 超简单的CDH6部署和体验(单机版)

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  6. OpenFaaS实战之一:部署

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  7. Kurento实战之三:知识点小导游

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  8. kubebuilder实战之二:初次体验kubebuilder

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. 第一篇 UEditor入门部署和体验

    UEditor 是由百度「FEX前端研发团队」开发的所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码. UEditor富文本编辑器,轻量, ...

随机推荐

  1. Prometheus(一):Web服务环境监控

    写在前面 现每个后端的同学的日常都在跟服务(接口)打交道,维护老的比较大单体应用.按业务拆得相对比较细的新服务.无论企业内部用的,面向用户的前端的服务.流量大的有流量小的,有重要的有不那么重要的. 但 ...

  2. 浅谈C++11中的多线程(一)

    摘要 本篇文章围绕以下几个问题展开: 进程和线程的区别 何为并发?C++中如何解决并发问题?C++中多线程的基本操作 同步互斥原理以及多进程和多线程中实现同步互斥的两种方法 Qt中的多线程应用 c++ ...

  3. Mysql学生课程表SQL面试集合

    现有如下2个表,根据要求写出SQL语句. student表:编号(sid),姓名(sname),性别(sex) course表:编号(sid),科目(subject),成绩(score)  问题1:查 ...

  4. PYTHON PIP 快速安装

    清华:https://pypi.tuna.tsinghua.edu.cn/simple 阿里云:http://mirrors.aliyun.com/pypi/simple/ 中国科技大学 https: ...

  5. C语言:渔夫打鱼晒网问题

    //如果一个渔夫从 2011 年 1 月 1 日开始三天打渔,两天晒网,编程实现当输入 2011 1 月 1 日以后的任意一天,输出该渔夫是在打渔还是在晒网. #include <stdio.h ...

  6. [008] - JavaSE面试题(八):集合

    第一期:Java面试 - 100题,梳理各大网站优秀面试题.大家可以跟着我一起来刷刷Java理论知识 [008] - JavaSE面试题(八):集合 第1问:说一下集合的体系? 单列集合: 双列集合: ...

  7. 2018年一名合格的web前端程序员应该会哪些技术

    有朋友让小编说一说web前端在未来几年的发展趋向,对于这个问题,恕小编无能为力,web前端技术日新月异,更新非常快,谁也不能预料未来会发生些什么 小编也只能说在2018年,react native和j ...

  8. Java集合中的可变参数

    可变参数: 1.在JDK1.5之后,如果我们定义一个方法需要接收多个参数,并且多个参数类型一致,我们可以对其简化成如下格式: 修饰符 返回值类型 方法名(参数类型... 形参名){} 其实这个书写完全 ...

  9. 如何热更新长缓存的 HTTP 资源

    前言 HTTP 缓存时间一直让开发者头疼.时间太短,性能不够好:时间太长,更新不及时.当遇到严重问题需紧急修复时,尽管后端文件可快速替换,但前端文件仍从本地缓存加载,导致更新长时间无法生效. 对于这个 ...

  10. HDFS学习总结之API交互

    第一种.shell交互 官方文档:http://archive.cloudera.com/cdh5/cdh/5/hadoop-2.6.0-cdh5.7.0/hadoop-project-dist/ha ...