SP,SRR, WRR,DWRR, WDRR, SDWRR调度算法的区别

2023-10-13 01:50

本文主要是介绍SP,SRR, WRR,DWRR, WDRR, SDWRR调度算法的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



在QoS队列调度中有如下算法,分别如下: 

1、SP

    SP:Strict Priority(严格优先级), SP调度严格按照优先级从高到低的次序优先发送较高优先级队列中的分组,当较高优先级队列为空时,再发送较低优先级队列中的分组。队列7优先级最高,队列0优先级最低.

    报文P1~P11~P…按照分类后进入不同的优先级队列,分类指根据报文本地优先级映射到端口队列。报文如果按照图中方式进入各队列,SP调度先调度高优先级队列7的报文,队列7报文调度完之后在进入下一队列6,报文出来后的顺序就为 p1,p2,p3,p4,p5…p11

 

2、RR(Round Robin)-循环调度

    基于报文的公平调度(Round Robin)RR, 基于报文的公平调度,每个队列调度出对一个报文,就转下一个队列

    报文P1~P11~P…按照分类后进入不同的优先级队列,分类指根据报文本地优先级映射到端口队列。报文如果按照图中方式进入各队列,RR调度,队列7调度一个报文进入下一队列6调度一个报文,依此到队列0调度1个报文后再进入队列7调度一个报文,如果队列中没有报文直接进入下一个队列。上述报文出队的顺序为p1,p4,p7,p10,p2,p5,p8,p11,p3,p6,p9。

2、SRR:

3、DRR(deficit round robin)-差额循环队列

    DRR算法是RR算法的扩展。DRR算法为每个队列分配一个常量QN(以权重为比例的时间片)和一个变量DN(差额)。QN反应了该队列可以发送的长期平均字节数。DN的初始值为零且当队列为空时复位为0。当DRR算法服务一个新队列时,调度器复位计数器Bsent(表示该循环已经从队列中发送的字节数)。当下面两个条件满足时,DRR算法从队列中发送分组:

l 队列中有分组等待发送;

l (QN+DN)大于等于(Bsent+队列中下一个分组的长度)。

否则,该队列的差额DN+1被置为QN+DN-Bsent,调度器按顺序移到下一个队列。QN+DN表示在服务时间间隔内队列能够发送的最大字节数,在一定程度上DN可以平滑数据流的突发。队列通过QN可以获得长期的相对带宽分配。如果激活队列的数目小于N,则激活队列可以根据QN值共享未用的输出链路带宽。

 

4、WRR(Weighted Round Robin)-加权循环调度算法

    基于报文的加权调度WRR, 可以配置每个队列调度出多少个报文,就转下一个队列。如配置队列0-队列7的调度权重依次为1,1,2,4,5,5,2,3。调度方式如下图

   

    报文P1~P11~P…按照分类后进入不同的优先级队列,分类指根据报文本地优先级映射到端口队列。报文如果按照图中方式进入各队列,WRR调度,队列7权重为3调度3个报文p1,p2,p3后进入队列6,队列权重为2调度2个报文p4,p5后进入下一级队列,如果下一级队列没有报文直接进入下一级队列,在一次轮询完成后再进入队列7,队列7没有报文直接进入队列6。上图中报文出来的顺序为p1,p2,p3,p4,p5,p7,p8,p10,p6,p9,p11。

 

5、WDRR(Weighted Deficit Round Robin)-加权差额循环调度

    基于报文字节的加权调度,该算法基于两个变量:配额(quantum)和余额(credit counter),配额代表权重,以字节为单位,是可配置的参数,余额用来表示配额的积累和消耗情况,是状态参数,不可配置。初始状态下,每个队列的余额等于其配额,当队列每发送一个报文的时候,余额就减去这个报文的字节数,当余额低于0的时候就停止这个队列的调度。当所有队列都停止调度的时候就为所有队列补充配额。权重N的范围为0~127,权重为N表示配额是(N*MTU_QUANTA)字节,这个(MTU_QUANTA为2K),N为0表示严格优先级。

                                               WDRR调度图

报文P1~P11~P…按照分类后进入不同的优先级队列,分类指根据报文本地优先级映射到端口队列。报文如果按照图中方式进入各队列,WDRR调度,报文p1~p11大小如果为1200字节,队列7权重为3,即每次调度3*2K= 6K字节的报文,先从队列7调度6K字节,如果队列中没有报文直接进入下一队列,队列6每次调度1*2K=2K字节,即会调度两个报文p4,p5,余额为-400字节,再进入下一队列调度,队列1权重为1,调度2K字节调度每个报文p10,p11,余额为-400字节,完成一次轮询后再进入高优先级队列,队列6再分配到2K配额,由于上次欠了-400字节,因此该次调度只能调度1600字节。上图中最终的报文顺序为p1,p2,p3,p4,p5,p8,p9,p10,p11,p6,p7,p12

 

6、DWRR:

    Dynamic Weighted Round-Robin  --  动态加权循环法。

7、SDWRR:

这篇关于SP,SRR, WRR,DWRR, WDRR, SDWRR调度算法的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

分辨率三兄弟LPI、DPI 和 PPI有什么区别? 搞清分辨率的那些事儿

《分辨率三兄弟LPI、DPI和PPI有什么区别?搞清分辨率的那些事儿》分辨率这个东西,真的是让人又爱又恨,为了搞清楚它,我可是翻阅了不少资料,最后发现“小7的背包”的解释最让我茅塞顿开,于是,我... 在谈到分辨率时,我们经常会遇到三个相似的缩写:PPI、DPI 和 LPI。虽然它们看起来差不多,但实际应用

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy