复杂局域网环境下视频电话稳定性的解决方案
创作时间:
作者:
@小白创作中心
复杂局域网环境下视频电话稳定性的解决方案
引用
1
来源
1.
https://learnku.com/articles/89202
在复杂局域网环境下,如何保证视频电话功能的稳定使用?本文提出了一种基于GRPC协议的主从网关架构方案,通过自动发现机制和音视频流调度,有效解决了传统Websocket和MQTT方案在长时间运行时的连接稳定性问题。
原方案采用webrtc + websocket + mqtt的nodejs架构,但在不稳定的网络环境下,websocket和mqtt等长链接协议在程序超长时间运行后会出现无法重连、甚至在连接情况下也无法通信的情况。往往需要人为处理才能恢复视频电话的正常使用,例如调整防火墙规则或处理网络故障等。
一主多从 网关架构方案
采用GRPC协议实现设备间通信:在局域网内所有设备的IP信息都是固定的情况下,采用双向通信的GRPC协议可以有效避免websocket等长链接协议在超长时间运行时的糟糕表现。虽然websocket是实现聊天室的常用方案,但在需要主动双向通信的场景下,GRPC是更好的选择。开发方面采用gomoble开发和生成安卓SDK的方式,虽然性能上会有部分损失,但golang的跨平台特性可以更好地开发其他平台工具来负责监控、测试和后期的运维。同时,简单的语法可以更方便地完成更高的单元测试覆盖,保证后续程序可以稳定的快速更新迭代。
主节点功能实现:主节点需要实现自动发现、网关信息储存、webrtc音视频流调度等功能。自动发现可以避免每次新增、更换节点时都需要人工设置网关节点信息。
通话流程管理:
- 当某一网关节点发起通话申请到主节点时,主节点收到申请将会通知所有需要通话的节点打开APP接听界面,建立webrtc连接并发生音视频流到主节点。
- 另一端的网关节点接听发送接听申请到主节点,主节点收到申请将会把通话双方的音视频流分别发送给对方,网关节点收到对方的音视频流之后就可以打开通话界面开始通话了。
- 挂断通话按接听情况可以分为未接挂断、接听挂断,未接挂断按挂断方式又可以分为手动挂断、自动挂断,如果是多人同时通话又有单次挂断、全部挂断。
gomoble技术选型
gomoble是一个用于生成跨平台SDK的工具,可以帮助开发者快速生成适用于不同平台的SDK,从而实现一次开发、多平台部署的目标。在本方案中,使用gomoble可以方便地生成安卓SDK,同时也可以为后续的监控、测试和运维开发其他平台的工具。
本作品采用《CC 协议》,转载必须注明作者和本文链接。
热门推荐
郁金:现代医学的新宠儿?
秋冬庭院种植指南:苹果树、柠檬树、人参果苗
BeMMO/G体系在有机草莓种植中的应用与实践
科技创新让果农足不出户掌控整个果园
菠萝种植全攻略:从选种到丰收
西黄胶囊被纳入《原发性肝癌中西医结合诊疗专家共识》
抗肝癌的10种中药,分享给您,建议收藏
何健威教你如何成为“僵尸叔叔”
澄迈那雅传统村落活化利用项目开始试运营 “那雅•风土志”正式揭牌
海南十大美丽乡村名单揭晓,你最想去海南的哪个美丽乡村呢?
古村活化新模式!澄迈那雅村一派古韵释新意
成人学英语,这些难点你遇到过吗?
真人外教+牛津学霸:揭秘高效英语学习法
双减政策下,孩子如何轻松学英语?
《僵尸叔叔》:从戏剧角度解析经典角色塑造
《行尸走肉》同款僵尸妆容教程
留学生如何高效完成英语作业?
小红书上的跨文化课堂:老外教你做英语作业
高中生如何用时间管理搞定英语作业?
李菲儿:从《康熙秘史》到综艺女王,37岁生日后的转型之路
从“社恐”到“社牛”:旅行达人的社交突破之路
社交技巧提升助力青少年心理健康
用心理学视角解读:如何维系一段长久的友谊
卡尔·罗杰斯教你高效社交:26招轻松搞定!
李菲新作《神都》开机,粉丝激动不已!
邯郸古迹探秘:那些不为人知的历史故事
秋冬打卡:邯郸京娘湖&太行五指山
滏阳河生态修复:邯郸的绿色奇迹
地震波监测深海温度:一项创新性的地球物理探测技术
中国石油大学揭秘:如何用地震波探秘地球深处?