写点什么

Slack 是如何使用 WebRTC 的?

  • 2017-09-18
  • 本文字数:1810 字

    阅读完需:约 6 分钟

Slack 是一家线上协作工具,提供聊天群组、工具集成、文件整合等功能,同时,它提供 Web 和桌面、移动客户端,覆盖了主流平台。2016 年,Slack 采用 WebRTC 技术实现了应用内的音视频通话功能。Slack 视频组高级主管工程师 Raj Kumar 将参加 9 月 21 日至 22 日在北京举行的 2017RTC 实时互联网大会,并将做主题演讲。InfoQ 对其进行了采访,了解 WebRTC 在 Slack 的使用。

WebRTC 本身是一组技术的集合,基本上考虑到了音视频通话的方方面面,但是要把它用起来也并不容易。要自建 WebRTC 服务,除了要考虑信令服务器和 NAT 防火墙穿透外,在多人通话中你还需要考虑用选择发送单元(SFU)或多点控制单元(MCU)来控制通话信息路由。Slack 在其工程博客介绍,它采用了 Janus 来作为自建的 SFU,同时进行了大量的性能优化。这只是 WebRTC 应用开发中的其中一例。

受访嘉宾介绍

Raj Kumar, Slack 视频组高级主管工程师。毕业于卡内基梅隆大学电子工程专业,WebRTC 视频编解码专家,全栈工程师,擅长多媒体领域数字信号处理。先后就职于 Apple, Internet Archive, Flurry Live。任职苹果公司工程师期间负责 QuickTime Video 编解码研发工作,获得十项研发专利。

InfoQ:Slack 为什么会选用 WebRTC 技术?

Raj: WebRTC 的一个很大优势是它内置在当今的 Web 浏览器中。在 WebRTC 之上构建您的产品,意味着用户可以在 Web 浏览器中启动应用程序,无需安装任何插件或下载任何其他软件。

内置在 Web 浏览器中的 WebRTC 技术不仅可以提供一流的用户体验,同时也使得不同产品之间的协同变得轻而易举。例如,Slack 用户可以使用 Slack Calls 进行视频通话,也可以使用与 Slack 集成的任何一款第三方的视频会议应用程序。这些应用程序能够与 Slack 无缝地链接在一起。

使用 WebRTC 的另一个优点是,当由 Google 主导的 WebRTC 团队对产品进行改进时,基于 WebRTC 而构建的所有应用程序都可以快速获得相应的改进。例如,当 WebRTC 团队优化回声消除或带宽估计算法时,所有的 WebRTC 应用程序也都可以立即使用这些成果。

实时通信是由采集、编码、前后处理、解码、缓冲、渲染等多种技术组成的集合体,WebRTC 提供了前端实现和编解码,如果开发者要商用,还需要做不少的开发部署工作,来提供可用性。

InfoQ:我们在网上看到了一些评论,说 WebRTC 会占用非常高的 CPU 计算资源,这是怎么回事呢?

Raj: WebRTC 中最消耗计算资源的组件是视频编码器。在大多数平台上,视频编码和解码都是在软件中执行,而不是使用专用的硬件编解码器。好消息是,这种情况正在缓慢地改善。

WebRTC 允许使用 VP8、VP9 或 H.264 视频编解码器。H.264 编解码器的硬件支持适用于大多数的移动平台,现在我们开始看到 WebRTC 应用程序已经在 iOS 和 Android 上通过使用 H.264 来获得更好的性能。在桌面系统支持方面,WebRTC 的 H.264 硬件编码目前还不能像在移动系统上那样获得广泛的支持,还不能在浏览器中启用。

此外,WebRTC 在使用 H.264 时还不支持诸如 Simulcast 或 Scalable Video Coding 之类的技术。需要这些功能的应用程序主要使用 VP8 或 VP9 编解码器,这些编解码器还没有在大多数平台上获得硬件支持。对 WebRTC 编解码器的硬件支持将有助于减少我们今天看到的高 CPU 使用率问题,不过这些问题正在解决之中,预计还需要时间。

InfoQ:当您在 Slack 部署 WebRTC 时,遇到的最大的技术问题是什么?

Raj: Slack 可以为 Mac、Windows 和 Linux 桌面,以及 iOS 和 Android 设备提供客户端。我们面临的一个挑战是使所有客户的 WebRTC 库保持同步,并为每个客户端团队提供本地平台的高级 WebRTC API。

为了应对这些挑战,我们打造了一个构建系统,该系统可以让我们的 Android 团队通过 Java 界面,让我们的 iPhone 团队通过 Objective-C 界面,让我们的桌面团队通过 C ++ 界面,对 WebRTC 进行协同编译。该系统让我们的团队可以专注于建立强大的客户端,而不必担心 WebRTC 代码的接口问题。

InfoQ:关于如何使用 WebRTC,您可以向我们的读者提供一些建议吗?

Raj:通过 WebRTC,任何人都可以轻松地访问强大的应用程序。您只需少量的 Javascript 操作即可将视频会议添加到您的应用程序中,并且由于 WebRTC 可以在浏览器之间进行点对点的连接,因此您无需托管视频服务器就可以部署出应用程序。

WebRTC 仍然是一种新兴的技术,与之相关的质量演进还需要比较长时间,应用场景都有很大空间可以挖掘,所以对开发者来说,现在是构建自己的应用的很好时机!

2017-09-18 04:072914
用户头像

发布了 164 篇内容, 共 109.0 次阅读, 收获喜欢 392 次。

关注

评论

发布
暂无评论
发现更多内容

ITSM | 对话——从业务场景、中国市场策略角度解读Atlassian ITSM解决方案

龙智—DevSecOps解决方案

ITSM ITIL

异常的基本概念和Java中的体系

共饮一杯无

Java 异常 11月月更

代码质量与安全 | 使用Incredibuild加速Klocwork静态代码分析

龙智—DevSecOps解决方案

代码静态分析 SAST工具 SAST 编译器 加速器 编程语言

车间工厂看板还搞不定,数据可视化包教包会

葡萄城技术团队

数据可视化 看板 智能工厂

即时通讯技术文集(第7期):长连接网关、P2P等 [共10篇]

JackJiang

网络编程 IM 即时通讯IM

DHorse系列文章之操作手册

tiandizhiguai

微服务 云原生 k8s管理 微服务治理 Serverless Kubernetes

高管对上新老板的 Twitter

HoneyMoose

单体分层应用架构剖析

京东科技开发者

架构 模块 应用架构 服务层 业务层

华为开发者联盟学堂上线超1800门课程,为开发者提供一站式赋能

最新动态

这可能是最全的SpringBoot3新版本变化了!

艾小仙

Java spring could spring-boot

高效!启科量子线路模拟器 QuSprout 与 Amazon HPC 集成,赋能量子计算

亚马逊云科技 (Amazon Web Services)

量子计算 Hero 专栏

从零开始学习Java系列之Java运行机制与跨平台特性

千锋IT教育

PGL图学习之项目实践(UniMP算法实现论文节点分类、新冠疫苗项目实战,助力疫情)[系列九]

汀丶人工智能

图神经网络 图学习 11月月更 论文节点分类任务 新冠疫苗任务

一次MTU问题导致的RDS访问故障

京东科技开发者

数据库 Linux MTU RDS vpn

【实用工具】解决PCB设计难题,痛击风险漏洞!

华秋PCB

工具 PCB PCB设计

2022中国区Cyber Monday限时优惠来袭,Linux基金会开源软件学园带来优惠

kk-OSC

k8s Linux基金会 CKA CKS

软件测试自动化“领导者”SmartBear举办首场中国线上研讨会:洞悉全球自动化测试走向,探讨降本增效之策

龙智—DevSecOps解决方案

自动化测试 API测试 UI测试 软件测试自动化

技术指南 | 如何集成Perforce版本控制系统Helix Core (P4V) 与敏捷规划工具Hansoft

龙智—DevSecOps解决方案

敏捷 版本管理

Spring6正式发布!重磅更新,是否可以拯救Java

宋小生

深度 | 新兴软件研发范式崛起,云计算全面走向 Serverless 化

Serverless Devs

阿里云 Serverless

《鸿蒙生态应用开发白皮书》正式发布,携手更多开发者迈入鸿蒙世界

最新动态

端云一体开发,助力鸿蒙应用开发效率全面提升

最新动态

《鸿蒙生态应用开发白皮书》正式发布,携手更多开发者迈入鸿蒙世界

最新动态

“鸿蒙开发套件”焕新升级 端到端赋能助力开发运维事半功倍

最新动态

观察者模式在spring中的应用

京东科技开发者

Java spring 编程 观察者模式

东莞理工学院-网安学院举办第二届“火焰杯”软件测试高校就业选拔赛颁奖典礼

测试人

软件测试 自动化测试 测试发开 测试比赛

A/B测试有哪些常见应用场景?——火山引擎DataTester科普

字节跳动数据平台

大数据 AB testing实战

DNS中有哪些值得学习的优秀设计

小小怪下士

Java 程序员 DNS

四项发明专利布局国际市场 申威睿思层级化数据库操作加速系统和方法获肯定

科技热闻

JVM 核心知识体系

钟奕礼

Java java面试 java编程 程序员‘

咱也不知道这份牛P哄哄的【Nginx实战】资料是不是你们想要的

钟奕礼

Java 程序员 java面试 java编程

Slack是如何使用WebRTC的?_DevOps & 平台工程_徐川_InfoQ精选文章