问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

复杂局域网环境下视频电话稳定性的解决方案

创作时间:
作者:
@小白创作中心

复杂局域网环境下视频电话稳定性的解决方案

引用
1
来源
1.
https://learnku.com/articles/89202

在复杂局域网环境下,如何保证视频电话功能的稳定使用?本文提出了一种基于GRPC协议的主从网关架构方案,通过自动发现机制和音视频流调度,有效解决了传统Websocket和MQTT方案在长时间运行时的连接稳定性问题。

原方案采用webrtc + websocket + mqtt的nodejs架构,但在不稳定的网络环境下,websocket和mqtt等长链接协议在程序超长时间运行后会出现无法重连、甚至在连接情况下也无法通信的情况。往往需要人为处理才能恢复视频电话的正常使用,例如调整防火墙规则或处理网络故障等。

一主多从 网关架构方案

  1. 采用GRPC协议实现设备间通信:在局域网内所有设备的IP信息都是固定的情况下,采用双向通信的GRPC协议可以有效避免websocket等长链接协议在超长时间运行时的糟糕表现。虽然websocket是实现聊天室的常用方案,但在需要主动双向通信的场景下,GRPC是更好的选择。开发方面采用gomoble开发和生成安卓SDK的方式,虽然性能上会有部分损失,但golang的跨平台特性可以更好地开发其他平台工具来负责监控、测试和后期的运维。同时,简单的语法可以更方便地完成更高的单元测试覆盖,保证后续程序可以稳定的快速更新迭代。

  2. 主节点功能实现:主节点需要实现自动发现、网关信息储存、webrtc音视频流调度等功能。自动发现可以避免每次新增、更换节点时都需要人工设置网关节点信息。

  3. 通话流程管理

  • 当某一网关节点发起通话申请到主节点时,主节点收到申请将会通知所有需要通话的节点打开APP接听界面,建立webrtc连接并发生音视频流到主节点。
  • 另一端的网关节点接听发送接听申请到主节点,主节点收到申请将会把通话双方的音视频流分别发送给对方,网关节点收到对方的音视频流之后就可以打开通话界面开始通话了。
  • 挂断通话按接听情况可以分为未接挂断、接听挂断,未接挂断按挂断方式又可以分为手动挂断、自动挂断,如果是多人同时通话又有单次挂断、全部挂断。



gomoble技术选型

gomoble是一个用于生成跨平台SDK的工具,可以帮助开发者快速生成适用于不同平台的SDK,从而实现一次开发、多平台部署的目标。在本方案中,使用gomoble可以方便地生成安卓SDK,同时也可以为后续的监控、测试和运维开发其他平台的工具。

本作品采用《CC 协议》,转载必须注明作者和本文链接。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号