加权轮询算法
加权轮询( Weighted round robin )是网络中用于调度数据流的算法,也可用于调度进程。
加权轮询[1]是轮询调度的一般化。加权轮询在队列或一系列任务上循环,每个轮次中各数据包或进程按权重获得运行机会。
加权轮询[2]有若干种类,比如经典加权轮询和交替加权轮询。
算法
[编辑]下面以网络调度程序为例介绍加权轮询。
假设有个输入队列。每个队列的权重是一个正整数。使用加权轮询时,队列运行过程有周期性。在每个周期中,队列有次发送机会。
不同的加权轮询算法的区别是在一个周期中如何分配机会。
经典加权轮询
[编辑]采用经典加权轮询算法时[2][3],调度程序会在队列间循环。轮到队列时,调度程序开始发送数据包,直到发出个数据包或遇到队尾为止。
常量和变量: const N // 队列数 N const weight[1..N] // 每个队列的权重 queues[1..N] // 队列 i // 队列序号 c // 数据包计数器 指令: while true do for i in 1 .. N do c:= 0 while (not queue[i].empty) and (c<weight[i]) do send( queue[i].head() ) queue[i].dequeue() c:= c+1 |
交替加权轮询
[编辑]令为所有队列中的最大权重。在交替加权轮询算法中[1][4],每个周期分为轮。第轮中,如果,队列i可以发送一个数据包。
常量和变量: const N // 队列数 N const weight[1..N] // 每个队列的权重 const w_max queues[1..N] // 队列 i // 队列序号 r // 轮次计数器 指令: while true do for r in 1 .. w_max do for i in 1 .. N do if (not queue[i].empty) and (weight[1..N] >= r)then send( queue[i].head() ) queue[i].dequeue() |
示例
[编辑]假设一个系统有三个队列, 其各自的权重。第一个队列中有7个数据包A,B,C,D,E,F,G,第二队列中为3个数据包U,V,W,第三个队列中有两个数据包X,Y。且不会有新数据包到达。
如果使用经典加权轮询算法,在第一个周期中,调度程序首先选择并传送位于队列头部的A,B,C,D,E(因为),然后选择第二个队列 ,传送队列开头的U,V(因为),最后选择第三个队列,该队列的权重等于3,然而该队列一共只有两个数据包,因此传输X,Y 。在Y的传输完毕后,第二个周期开始,先是发送中的F,G,然后是中的W。
如果使用交替加权轮询算法,第一个周期分为5轮。第一轮(r = 1),每个队列发送一个数据包(A,U,X),第二轮(r = 2),每个队列再发送一个数据包(B,V,Y),第三轮(r = 3),仅排队被允许发送数据包(, 和 ),但由于为空,只有来自的C被发送,在第四和第五轮,只有D,E从被发送。然后开始第二个周期,依次发送F,W,G。
任务调度
[编辑]与数据包调度类似,加权轮询完成任务或进程调度时:个现行任务以循环方式安排,每个任务得到份的处理器时间[5][6] 。
性质
[编辑]调度数据包时,如果所有数据包都具有相同的大小,则WRR是通用处理器共享算法的近似[7]:长期来看,队列将占据的带宽(假设所有队列均处于现行状态)。
如果数据包长度可变,则每个队列接收的带宽部分不仅取决于权重,还取决于数据包大小。
如果队列的平均数据包大小是,则每个队列将获得的长期带宽份额等于 。如果目标是给每个队列分配链接容量的( ),则可以设置权重。
参考文献
[编辑]- ^ 1.0 1.1 Katevenis, M.; Sidgiropoulos, S.; Courcoubetis, C. Weighted round-robin cell multiplexing in a general-purpose ATM switch chip. IEEE Journal on Selected Areas in Communications. 1991, 9 (8): 1265–1279. ISSN 0733-8716. doi:10.1109/49.105173.
- ^ 2.0 2.1 Chaskar, H.M.; Madhow, U. Fair scheduling with tunable latency: A round-robin approach. IEEE/ACM Transactions on Networking. 2003, 11 (4): 592–601. ISSN 1063-6692. doi:10.1109/TNET.2003.815290.
- ^ Brahimi, B.; Aubrun, C.; Rondeau, E. Modelling and Simulation of Scheduling Policies Implemented in Ethernet Switch by Using Coloured Petri Nets: 667–674. 2006. doi:10.1109/ETFA.2006.355373.
- ^ Semeria, Chuck. Supporting Differentiated Service Classes: Queue Scheduling Disciplines (PDF) (报告): 15–18. [4 May 2020]. (原始内容存档 (PDF)于2017-08-29).
- ^ Beaulieu, Alain. Real Time Operating Systems -- Scheduling & Schedulers (PDF). Winter 2017 [4 May 2020].[失效链接]
- ^ 20190266019
- ^ Fall, Kevin. EECS 122, "Introduction to Communication Networks", Lecture 27, "Scheduling Best-Effort and Guaranteed Connections". 29 April 1999 [4 May 2020]. (原始内容存档于2012-07-22).