网络损伤仿真,为5G应用保驾护航

2024-03-04 02:50

本文主要是介绍网络损伤仿真,为5G应用保驾护航,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

5G,绝对是今年最热门的话题!2019年6月6日,工信部正式向中国电信、中国移动、中国联通、中国广电发放5G商用牌照,中国正式进入5G商用元年。5G不仅仅是一次通信技术的升级,更是开启了一个新的时代。5G的超高带宽、海量连接、低时延超可靠性等性能,将成为构建数字化社会的强大基础。在这里插入图片描述
更高的网络传输速率可以使已经面世许久但因网速受限的AR/VR/超高清视频业务等技术被广泛推广和使用。
在这里插入图片描述
而5G技术海量连接的特点,是将网络业务无所不包,广泛存在。万物联网,万物皆可连接到网络,智能家居、智能路灯、智能机场等等,生活中所接触的任何事物皆可联网,实现智慧城市。
在这里插入图片描述
低延时也是5G技术的一个关键点,这使得5G可以完美的与TSN(时间敏感网络)相结合。TSN的主要目标是通过IEEE802(以太网)有线网络提供确定性服务,这意味低时延、低丢包率、有保证的数据包传输,而TSN标准可以广泛应用于许多垂直领域,例如工业物联网(IIoT)和工业4.0(包括像运动控制、移动机器人、AGV远程控制、甚至传统的工业过程自动化领域),及汽车以太网(汽车控制及自动驾驶)。
在这里插入图片描述
国家层面不断向运营商提倡的提速降费,加上快速推进的5G商用,其最终目的是为了提供一个高速率、低延时及高可靠性的网络基础设施,为基于工业以太网,工业物联网、汽车以太网、广域网、数据中心等网络基础之上的应用提供尽可能完美的网络服务质量,给用户提供一个完美的联网体验。

然而,世界是不可能完美无瑕的,互联网也不例外。全球互联互通的任意两个信息端点之间的通信,可能需要经过很多不同的物理环境、传输链路、传输设备和网络设备,总会有自然或意外的随机事件发生,从而导致破坏网络上传输的数据包。所以会给互联网上的各种应用带来非常不好的用户体验,尤其是是对网络质量要求非常高的音视频业务(VR/超高清视频/VOIP/视频会议/汽车360度全景导航等)及TSN(时间敏感网络)相关的上层应用业务。相信大家都有过手机观看高清视频出现卡顿的现象,尤其是实时直播高清视频。
在这里插入图片描述
据NIST(美国)国家标准与技术局研究统计,应用系统发布上线后, 80%的总成本仅用于寻找和发现问题中;另外根据知名咨询机构 Gartner 的研究,全球超过70%的应用部署都是失败的。

究其根本原因在于几乎所有网络设备测试及应用的开发测试都是在相对完美的实验室网络环境下完成的。被测设备及网络并非由复杂的物理环境、大量的传输链路、传输设备及网络设备组成,在该实验网络中具有比较好的时延、抖动、带宽及可靠性,上层应用的测试结果也会比较好(仅能代表测试网络环境中的结果)。

但是真实的互联网环境中,存在大量的导致网络质量损伤的因素,如下我们常见的损伤类型及原因:
丢包:网络设备软、硬件问题;线路传输质量差引起丢包;网络设备配置不合理导致丢包 网络设计不合理导致丢包;网络冲突、广播泛滥造成的丢包;
时延:光纤长距离传输;网络设备转发处理需要时间;应用服务器处理时间;网络拥塞;
抖动:网络拥塞;负载均衡设备的部署;路由翻转;
乱序:网络拥塞;端口捆绑;路由翻转;
重复帧:网络环路;协议栈异常;
物理层损伤:色散或功率衰减、串扰及不确定的系统噪声、环境干扰等;

以上损伤类型作为专业术语,听起来可能有点费劲,阿信举一个快递运输的例子给大家解释下。快递是大家日常生活中经常接触的事情,一套完整的快递运输包含很多流程,如下图。
在这里插入图片描述
假设双十二期间你网购了10样东西,但是快递运输过程中丢了一件(简称“丢包”),明白我意思吧?然后运输过程中又遇到堵塞(此时就产生了运输“时延”,你收到货的时间会延后。由于时延的存在,那么你每次收到货的时间不一样,这种现象我们便称之为“抖动”),你以为倒霉的事这就完了?nonono,后来你发现你先下单的锅居然在后下单的调料到了之后才送达(也就是出现了“乱序”,此时你只能望着调料干捉急了),可能唯一值得庆幸的是,发货的店家给你重复发了两样物品(就是所谓的“重复帧”操作),但是打开包装才发现原来其中一件是坏的(可能是运输过程中出现碰撞,发生了“物理层损伤”)。是不是超级无语!!!

以上只是为了举例形象些,阿信胡编乱造的剧情哈,请不要太过脑补画面…哈哈哈。

而互联网中的大部分应用对网络质量的损伤是非常敏感的,如音视频流的传输:
◆VOIP网络质量最低要求:丢包率小于8%,延时小于200ms,抖动正负不大于40ms;
◆4K高清视频对承载网端到端网络质量最低要求:带宽要大于50Mbps,往返时延(RTT)要小于20ms,丢包率PLR要小于10-5;
◆而VR业务起步阶段,需要80Mbps以上的带宽,网络延迟控制在20毫秒以内;舒适体验阶段需要260Mbps以上的带宽,网络延迟控制在15毫秒以内;理想体验阶段需要1.5Gbps以上带宽,网络延迟控制在2毫秒以内。
现在的问题是,既然现实互联网中的网络质量损伤无法避免,我们能否在测试网络环境中去模拟真实的网络环境?模拟在特定网络质量模型下,来验证对上层应用的影响如何?

答案是使用网络损伤仿真器,也称网络损伤仪。它可以在实验室网络中精确地仿真真实的网络损伤状况,用于在部署之前测试和验证网络中的产品、应用和服务。网络损伤仪对于描述和验证真实环境的性能及终端用户质量体验是必不可少的。它可以为实现高质量的网络应用、灾难恢复、数据中心迁移和多媒体业务的测试提供有力保证。

这篇关于网络损伤仿真,为5G应用保驾护航的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771783

相关文章

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

Nginx内置变量应用场景分析

《Nginx内置变量应用场景分析》Nginx内置变量速查表,涵盖请求URI、客户端信息、服务器信息、文件路径、响应与性能等类别,这篇文章给大家介绍Nginx内置变量应用场景分析,感兴趣的朋友跟随小编一... 目录1. Nginx 内置变量速查表2. 核心变量详解与应用场景3. 实际应用举例4. 注意事项Ng

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Python实现简单封装网络请求的示例详解

《Python实现简单封装网络请求的示例详解》这篇文章主要为大家详细介绍了Python实现简单封装网络请求的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装依赖核心功能说明1. 类与方法概览2.NetHelper类初始化参数3.ApiResponse类属性与方法使用实

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired