网络延迟是如何产生的?

网络 通信技术
网络延迟是指一个IP包从源主机进程发出开始计时,到达目的地主机进程为止,所经历的时间,以毫秒为单位。

网络延迟

网络延迟是指一个IP包从源主机进程发出开始计时,到达目的地主机进程为止,所经历的时间,以毫秒为单位。

IP包从源主机一路经过多个中继设备,如交换机、路由器,最终到达终点,网络延迟由以下三者组成:

网络延迟 = 传输延迟 + 处理延迟 +缓冲队列延迟

[[275205]]

传输延迟

这个延迟很好理解,指光、电信号在有线介质上的延迟,或无线电信号在空气介质中的延迟,这种传输延迟只和光速有关、或电信号的传输速度有关,用户无法改变该延迟。对于一条选定的端对端路径,此值是恒定的。

[[275206]]

处理延迟

接收IP包,查询转发表,硬件、或软件转发,包括封装、解封装、编码、解码时间,经过设备越多,设备吞吐能力越弱(一秒可以转发多少Gb的数据),延迟越大。但对于一条选定的端对端路径,此值也是恒定的。

缓冲队列延迟

当端到端的路径上,没有任何网络拥塞,缓冲队列的延迟几户为0,网络转发性能达到线速度,好像两端用一根线直连。

[[275207]]

但是网络拥堵经常发生,因为主机对带宽的需求无止境,所以拥堵是常态。当网络拥堵时,路由器将无法及时转发的流量缓冲在出口队列,可能采用加权公平队列WFQ(Weighted FairQueue)、或低延迟队列LLQ (Low Latency Queue),或默认的先进先出队列FIFO(First In FirstOut),这个队列可能会造成几百毫秒或更多的延迟,此值是可变的,可以接近0或几秒不等,依赖网络的拥堵程度。

1. 什么是加权公平队列WFQ?

将不同的种类流量放入不同的队列,预先给不同的队列分配一个权值、或百分比,采用公平轮转的方式来依次发送每个队列的缓冲数据。

2. 什么是低延迟队列LLQ?

依据IP优先级,高优先级的语音流量(Precedence =5),最先发送,可以插队,VIP客户。

3. 什么是先进先出队列FIFO?

先到的先发,后到的后发。

所以过大的网络延迟主要是由缓冲队列延迟过大造成的!

Google最新的TCP BBR算法,就是积极主动测量网络的延迟,运用智能算法,获知网络的最大可利用带宽,使发送速率≤ 最大可利用带宽,最大限度减少路由器的缓冲队列的深度,最大限度减少延迟。

综上可知,网络延迟是由不受人类控制的传输延迟,以及人类可以控制的处理延迟、队列延迟所组成。很显然,如果想减小IP报文的整体延迟,必须从后两者入手,即如何降低处理延迟、队列延迟。

处理延迟是一个衡量一台设备是否牛叉的关键指标。以路由器为例,拥有近百万条路由表的路由器,如何用最快速度匹配到正确的路由条目,包含着满满的黑科技。采用多级查询,只需要查询几百、最多几千次条目,就可以hit到正确的条目。这是产品设计时候需要实现的技术要素。

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2018-05-18 10:35:56

云计算差异技术

2010-11-15 12:12:18

2013-10-23 10:51:48

开发模型软件开发软件产业

2023-12-08 11:22:31

IT首席转型官转型

2023-01-09 08:00:41

JavaScript闭包

2023-02-08 07:04:20

死锁面试官单元

2022-03-07 10:41:09

云计算容器Kubernetes

2022-04-06 07:50:28

线程安全代码

2023-04-18 14:53:48

2023-04-18 15:09:50

2022-08-02 20:17:13

网络UnderlayOverlay

2017-01-04 12:53:51

2023-09-10 07:15:08

网络延迟CDN

2009-04-09 10:11:00

TCPIP通讯

2024-03-27 08:08:29

网络延迟事务

2018-02-26 12:41:27

信息

2019-05-28 10:24:31

V8JavaScript延迟

2020-07-31 07:58:21

MySQL同步延迟

2015-08-11 10:18:09

大数据

2022-04-18 09:07:54

Linux网络延迟
点赞
收藏

51CTO技术栈公众号