qos的_QoS 概述

2b55dc53dfcbb516d55b4f205278cff4.png

QoS 是一个很大的领域,涉及到网络中的多个层次和环节。本文仅简要的谈谈 Endpoint 侧的 QoS 概念,将这些纷繁的概念名词串起来,便于理解。

QoS 技术背景

下图说明了 QoS workflow 中,各项技术的位置和关系

216d62060f39d04265468d62572862e5.png
摘自 < 端到端QoS网络设计 >

当流量进入设备后,它依次经过 mark(标记)→ meter(计量) → police(管制) → class/dscp(重分类) → queue(队列) → sharper(整形) → queue priority (优先级调度). meter + police 完成 rate-limit 功能。 而 queue + sharping + priority 完成 congestion manager 功能。sharping 功能属于可选项。

细解释其中的专业术语和实现特点

  • Classification and marking
  • Metering
  • Policing
  • Shaping
  • Scheduling
  • Congestion management
  • 分类:将数据分为不同的类别,称为分类(classification),分类并不修改原来的数据包。
  • 标记:将数据设置为不同的优先级称为标记(marking),而标记会修改原来的数据包。
  • 流量计量:流量计量可以通过漏桶算法(常用于ATM网络)或令牌桶算法(常用于IP网络)实现。计量后的数据包会根据不同的整形类别分别保存在缓冲区中,待满足对应的流量资料后再进行发送。
  • 流量管制:丢弃超出带宽,称为管制(Policing)。
  • 流量整形:将超出的带宽缓存在内存中,等到下一秒再传递,这种行为称为Shaping。典型作用是限制流出某一网络的某一连接的流量与突发,使这类报文以比较均匀的速度向外发送,以符合种给定的“流量资料”(traffic profile)。
  • 队列调度机制:在QoS技术体系中属于拥塞管理的范畴。
  • 拥塞管理:当网络发生拥塞后,数据还是要被传递的,正因为接收到的数据远多于自身的传输能力,所以数据被传输时就出现了先后顺序,而依照什么样的方式来传数据,就需要队列的指导,QOS中的队列定义了数据包被传输的先后顺序。如果处理方式为管制,那么数据包就会被丢弃,通常情况下,网络设备默认丢弃后到的数据包而传输先到的数据包,这样的丢弃方式称为尾丢弃。

流量整形(traffic shaping)常与流量监管(traffic policing)混淆。它们的主要区别在于,流量整形是一种主动调整流量输出速率的措施。流量整形对流量监管中需要丢弃的报文进行缓存——通常是将它们放入缓冲区或队列内,再根据特定算法均匀的向外发送这些被缓存的报文。但这不代表流量整形不会丢弃报文。shaping可能会增加延迟,而policing几乎不引入额外的延迟。

通常的实现方式

  • Marking: fwmark, ToS/IPP/DSCP
  • Metering: token bucket, trTCM, mark ToS/IPP/DSCP
  • Policing per interface (egress)
  • Shaping per interface (egress)
  • Scheduling: Priority Queuing
  • Congestion management: Taildrop

标记方式

实现 QoS 的一个最基本的方法就是分类和标记。

ToS/IPP/DSCP 是 IP头部的一个名为 ToS 字段。用于标记服务类型。这个字段随着发展,被不断的赋予了新的定义。见下表:

a79d057a338342bfe52ed73ef5abe829.png

ToS/IPP:根据RFC791定义,IP报文头ToS(Type of Service)域由8个比特组成,其中3个比特的 Precedence 字段标识了 IP 报文的优先级

DSCP:差分服务代码点(Differentiated Services Code Point)RFC2474 重新定义了 IP 报文中的 ToS 域,增加了C比特,表示传输开销(Monetary Cost)。

下图是RFC1349 定义的每个位的意义:

c5e38988d7e5ade87c4083e270020bfc.png

上图示例了一些协议应该如何设置(4~1)位:

到了 RFC2474 , IPP的的意义就发生了变化。而 DTR位意义不变。IPP 与 DSCP 相应存在一个转换关系。DSCP 可以看成定义了一系列队列类别,下表列出一部分:

6809da8ab77db3ead15bf85f84d9a229.png

在路由器中,一般都是把 CS6 和CS7 中的数据用 PQ 做绝对优先处理,无论下面是否有数据也是要优先来传递这两个队列中的数据。而其他EF到AF1的队列中是用 WFQ 来做的,保证所有队列都可以得到带宽来传输。

PQ(Priority Queueing,优先队列):PQ会先服务高优先级的子队列,若高优先级子队列里没有数据后,再服务中等优先级子队列,依次类推。如果PQ正在服务中等优先级子队列,但是高优先级里又来了数据包,则PQ会中断中等优先级子队列的服务,转而服务高优先级子队列。

WFQ(Weighted Fair Queueing,加权公平队列):可以保证相同优先级业务间公平,不同优先级业务间加权。

计量算法

令牌桶算法(Token Bucket)
有时人们将漏桶算法与令牌桶算法错误地混淆在一起。而实际上,这两种算法具有截然不同的特性并且为截然不同的目的而使用。它们之间最主要的差别在于:漏桶算法能够强行限制数据的传输速率,而令牌桶算法能够在限制数据的平均传输速率的同时还允许某种程度的突发传输。

双速率三色标记器(trTCM)

基于令牌桶算法做计量器

管制支持

Ingress policing per interface provided by the Fast Path QoS module. QoS basic 支持对 入口流量做管制。 QoS advance 仅支持对 出口流量做管制。管制也即丢弃。

队列调度算法

Priority Queuing

在报文到达接口后,首先对报文进行分类,然后按照报文所属类别让报文进入所属队列尾部,在报文发送时,按照优先级,总是在所有优先级较高队列中报文发送完毕后,再发送低优先级队列中报文,这样,在每次发送报文时,总是将优先级高的报文先发出去,保证了属于较高优先级队列报文有较低时延,所以PQ的优缺点是很明显的:优点是可以保证高优先级队列的报文可以得到较大带宽、较低的时延、较小的抖动;缺点是低优先级队列的报文不能得到及时的调度,甚至得不到调度,即会出现“饿死”现象。
PQ具有如下特征:
(1) 报文丢弃策略采用 Tail Drop 机制;
(2) 每个队列内部使用FIFO逻辑;
(3) 当从队列调度报文时,先从高优先级的队列调度报文
从上面可以看出,PQ一般的应用场合是保证某类流量尽可能得到最好的服务,而不管其它流量的“死活”。

拥塞管理算法

与调度算法相匹配,使用简单的尾部丢弃算法(tail drop)

上述的这些实现方式,按照文章中的第一个 workflow 图,被串起来,对流量进行控制。各种 Endpoint QoS 实现,都无出本文之右。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/534926.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么python 为什么没有接口_python做接口测试的必要性

什么是接口测试 接口测试主要用于检测外部系统与内部系统之间,以及系统内部各 个子系统之间的交互点。其测试的重点是,检查数据的交换、传递和控 制管理过程,以及系统间的逻辑依赖关系等。 为什么要做接口测试 1.传统的测试方法成本急剧增加&…

路由器mysql密码重置密码_【验证】mysql root密码恢复

1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库。因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的状态下,其他的用户也可以任意地登录和修改MySQL的信息。可以采用将MySQL对外的…

centos daemonize_手把手教你在centos上配置Django项目(超详细步骤)

前言关于Django的部署,本人也踩了很多坑,这篇文章一步一步教你怎么进行部署,只需要你按照我的步骤来就OK了!这里我们使用的服务器是一个全新的服务器,没有安装任何东西。基础环境搭建步骤★ 注意:下面的步骤…

mysql8.0.17压缩包安装教程_mysql 8.0.16 压缩包安装配置方法图文教程

本文为大家分享了mysql 8.0.16 压缩包安装配置方法,供大家参考,具体内容如下运行环境:windows 10 x641、下载zip安装包:mysql8.0 for windows zip包:,进入页面后可以不用登录。后点击底部“no thanks, just…

python收集数据程序_基于Python语言的互联网数据收集软件的设计

软件建立所需的工具及其版本 编写环境与 IDE Python3.5.2 Windows10 PyCharm 2016.3 Sublime Text3 第三方库与版本号 Requests 2.12.1 BeautifulSoup 4.5.1 PYQT5 5.8.1 Pyinstaller 库的作用 用于爬虫编写 用于爬虫编写 用于软件 GUI 设计 用于封装 python 程序 1.1 百度地图…

Mysql保存是事件驱动吗_【CHRIS RICHARDSON 微服务系列】事件驱动的数据管理-5

编者的话 |本文来自 Nginx 官方博客,是「Chris Richardson 微服务」系列的第五篇文章。第一篇文章介绍了微服务架构模式,并且讨论了使用微服务的优缺点;第二和第三篇描述了微服务架构模块间通讯的不同方面;第四篇研究了服务发现中…

chrome postman插件_收集了一些Chrome插件神器,助你快速成为老司机

刚开始开发项目的时候,我一直都在用火狐,因为它有一个fireBug插件,特别好用(目前已不支持),也不知道什么时候,就一直用起来Chrome浏览器了,可能是因为它有强大的插件作为后盾吧。开发了这么多年&#xff0c…

phpmyadmin 导出mysql,在phpmyadmin中导入/导出非常大的mysql数据库

i have a db in phpmyadmin having 3000000 records. i want to export this to another pc. now when i export this only 200000 entries exported into .sql file and that is also not imported on the other pc.解决方案Answering this for anyone else who lands here. I…

python字符串是否包含某元素_Python实现判断一个字符串是否包含子串的方法总结...

本文实例总结了Python实现判断一个字符串是否包含子串的方法。分享给大家供大家参考,具体如下: 1.使用成员操作符 in >>> snihao,shijie >>> tnihao >>> result t in s >>> print result True 2.使用string模块的f…

python怎么全选_有没有一种方法可以在Python网页上模拟“全选复制粘贴”?

我对Python相当陌生,我不知道selenium是什么,但是如果您能够找到某种模式,您应该能够执行您描述的内容。关键是找到一个模式。下面是几个示例脚本,它们可能会让您了解如何开始。在import urllib2from bs4 import BeautifulSoupf …

python当前时间怎么弄_python获取当前时间

我有的时候写程序要用到当前时间,我就想用python去取当前的时间,虽然不是很难,但是老是忘记,用一次丢一次, 为了能够更好的记住,我今天特意写下这篇文章,如果你觉的对你有用的话,可以…

window.open不重复打开同一个名称的窗口_干货满满|Ctrl键的正确打开方式

“ctrl”是键盘中一个常用的键,全名为"control",中文意为"控制",在计算机基础中称为“控制键”。那么你知道“ctrl”都能控制什么吗?难道只知道 “ctrl”C 复制、“ctrl”V 粘贴 这些?&#xff1f…

java 按位_Java中的按位运算

一、位运算符简介:1.按位与&。如果两个整形数据 a、b 对应位都是1,则结果位才为1,否则为0,(int 最大值0x7fffffff ):1 int a 0x7fffffff;2 int b 12;3 int c 0;4 int aAndB a&b; //aAndB is 125 int aAndC a&c; …

jmeter安装包_分布式执行jmeter脚本步骤(非GUI)

备注:【Linux查看服务器是32位还是64位命令】uname -mgetconf LONG_BIT1.Linux环境安装jmeter可参考https://www.cnblogs.com/surewing/p/9271886.html如需要用到3台客户机,分别在三台机器中安装,以下安装之前需安装jdk环境1)将jm…