用于限定流量控制信号的方法和装置制造方法

文档序号:7800876阅读:217来源:国知局
用于限定流量控制信号的方法和装置制造方法
【专利摘要】用于限定流量控制信号的方法和装置。在一个实施例中,处理器可读的介质可以存储代表指令的代码,当处理器执行指令的时候,使得处理器去接收代表接收队列的拥塞程度的值和代表传送队列的状态的值。可以由寻址到接收队列的多个分组限定至少一部分传送队列。可以基于代表接收队列的拥塞程度的值和表示传送队列的状态的值来限定传送队列的速率值。处理器可读的介质可以存储代表指令的代码,当处理器执行指令的时候,使得处理器基于代表接收队列的拥塞程度的值和代表传送队列的状态的值限定传送队列的中止时间值。
【专利说明】用于限定流量控制信号的方法和装置
[0001]本申请是2009年9月11日申请的、专利申请号为200910246889.0的专利申请的分案申请。
[0002]相关申请
[0003]本申请要求于2008年9月11日提交的名为“Methods and Apparatus Relatedto Flow Control within a Data Center” 的美国临时专利申请 N0.61 / 096,209 的优先权和权益,通过引用其整体结合在此处。
[0004]本申请是于2008 年 9 月 30 日提交的名为 “Methods and Apparatus for FlowControl Associated with Mult1-Staged Queues” 的共同未决的美国专利申请 N0.12 /242,224的部分继续申请,其要求于2008年9月11日提交的名为“Methods and ApparatusRelated to Flow Control within a Data Center”的美国临时专利申请N0.61 / 096,209的优先权和权益;并且本申请是于2008年9月30日提交的名为“Methods and Apparatusfor Flow Controllable Mult1-Staged Queues” 的共同未决的美国专利申请 N0.12 /242,230的部分继续申请,其要求于2008年9月11日提交的名为“Methods and ApparatusRelated to Flow Control within a Data Center”的美国临时专利申请N0.61 / 096,209的优先权和权益;通过引用所有这些整体结合在此处。
【背景技术】
[0005]在此处描述的实施例通常涉及流量控制,尤其是涉及与多级队列有关的流量控制。
[0006]例如,经由物理链路(例如,以太网链路)从发射机到接收机的数据传输可能由于拥塞而在配置为接收数据的队列处被中断。在有些情况下,由于缓冲溢出,该中断可能导致线头(HOL)阻塞和/或导致至少一部分数据的丢失。已知的流量控制协议,诸如以太网暂停(电气与电子工程师协会(IEEE)802.3x)和优先级暂停(IEEE802.1qbb)在某些应用中基本上可用于防止缓冲溢出,并且量化后的拥塞通知(QCN) (IEEE802.1qau)可以用于在具有相对稳定的数据流的多跳网络内管理数据拥塞。但是,这些已知的流量控制协议不能充分地解决与多级队列相关的拥塞问题,和/或不能充分地处理例如由数据的突发所引起的在逐跳(hop by hop)网络链路内发生的拥塞。
[0007]因此,对与逐跳网络链路有关的多级队列之间的数据流控制的方法和装置存在需求。

【发明内容】

[0008]在一个实施例中,处理器可读的介质可以存储代表指令的代码,当由处理器执行该指令的时候,使得处理器去接收代表接收队列的拥塞程度的值和代表传送队列的状态的值。至少一部分传送队列可以由寻址到接收队列的分组限定。传送队列的速率值可以基于代表接收队列的拥塞程度的值和表示传送队列的状态的值来定义。处理器可读的介质可以存储代表指令的代码,当由处理器执行该指令的时候,使得处理器基于代表接收队列的拥塞程度的值和代表传送队列的状态的值限定传送队列的中止时间值。
[0009]根据本发明的一个方面,提供了一种装置,包括:
[0010]第一队列模块,被配置为基于与第一流量控制环路有关的数据流来限定第一流量控制信号,第一流量控制环路包括链路、第一级队列和安排在链路和第一级队列之间的传输路径内的第二级队列,第一流量控制信号包括与第一流量控制环路有关的传送队列的速率值,和与第一流量控制环路有关的传送队列的中止时间值;和
[0011]第二队列模块,被配置为基于第二流量控制环路内的数据流来限定第二流量控制信号,第二流量控制环路包括第二级队列和链路,第二流量控制环路不包括第一级队列。
[0012]在一个实施例中,与第一流量控制环路有关的数据流来自于传送队列,队列模块被配置为基于与第一流量控制环路有关的数据流来限定代表传送队列的状态的值,队列模块被配置为基于代表传送队列的状态的值限定速率值和中止时间值。
[0013]在一个实施例中,部分第一级队列或者部分第二级队列中的至少一个包括在与多级转换结构有关的边缘设备中。
[0014]在一个实施例中,第二流量控制环路是基于优先级的流量控制环路。
[0015]在一个实施例中,所述装置进一步包括:
[0016]第三队列模块,被配置为基于与包括链路的第三流量控制环路有关的数据流来限定第三流量控制信号,第三流量控制环路不包括第一级队列和第二级队列。
[0017]在一个实施例中,第一级队列逻辑地嵌套在第二级队列的外面,第二级队列逻辑地嵌套在链路的外面。
[0018]根据本发明的另一个方面,提供了一种方法,包括:
[0019]在物理链路的接收侧上,接收请求,该请求请求中止来自第一级队列的发送侧内的队列的数据传输并中止经包括物理链路、一部分第一级队列和一部分第二级队列的路径的传输;和
[0020]响应于该请求,将流量控制信号发送给流量控制模块,流量控制模块被配置为调度来自第一级队列的发送侧内的队列的数据传输,流量控制信号与包括该路径的第一控制环路有关,并且与不包括第一级队列的第二控制环路不同。
[0021]在一个实施例中,第二流量控制环路是基于优先级的流量控制环路。
[0022]在一个实施例中,物理链路包括在不同于第一流量控制环路并且不同于第二流量控制环路的第三流量控制环路中。
[0023]在一个实施例中,数据在第一级队列的发送侧内的队列处排队,中止传输的请求包括与第一级队列的发送侧内的队列相关联的标识符。
[0024]在一个实施例中,第一级队列的发送侧内的队列包括在多个传送队列中,所述多个传送队列包括在第一级队列中,部分第二级队列包括传送队列,包括在第一级队列中的多个传送队列扇入包括在第二级队列中的传送队列。
[0025]在一个实施例中,所述请求是第一请求,所述数据是第一数据,该方法进一步包括:
[0026]在发送之前,经由该路径接收中止第二数据传输的第二请求,该发送响应于第一请求和第二请求。
[0027]在一个实施例中,所述数据是在第一级队列的发送侧内的队列上排队的第一数据,该方法进一步包括:
[0028]接收第二请求以中止在第一级队列的发送侧内的队列处排队的至少一部分第二数据的传输;和
[0029]基于第一请求和基于第二请求来限定中止时间值,中止时间值代表用于中止来自第一级队列的发送侧内的队列的第一数据传输和第二数据传输的时间段,流量控制信号包括中止时间值。
[0030]在一个实施例中,所述数据在第一级队列的发送侧内的队列处排队,所述请求包括基于第一级队列的接收侧内的队列的可用性而限定的中止时间值,流量控制信号是基于中止时间值限定的。
[0031 ] 在一个实施例中,在第一级队列的发送侧内的队列是虚拟的队列,流量控制信号包括与虚拟的队列有关的标识符。
【专利附图】

【附图说明】
[0032]图1是按照一个实施例表明多级流量可控队列的示意方框图。
[0033]图2是按照另一个实施例表明多级流量可控队列的示意方框图。
[0034]图3是按照一个实施例表明配置为限定与多个接收队列有关的流量控制信号的目的地控制模块的示意方框图。
[0035]图4是按照一个实施例表明流量控制分组的示意图。
[0036]图5是按照一个实施例表明用于限定流量控制分组的方法的流程图。
[0037]图6是按照一个实施例表明数据中心的示意方框图。
[0038]图7是按照一个实施例表明用于将流量控制信号发送给两个不同级的队列的方法的流程图。
[0039]图8是按照一个实施例表明配置为处理与多级队列系统有关的流量控制信号的控制模块的示意图。
[0040]图9A是按照一个实施例表明接收队列状态数据库的示意图。
[0041]图9B是按照一个实施例表明传送队列状态数据库的示意图。
[0042]图9C是按照一个实施例表明系统状态数据库的示意图。
[0043]图10是按照一个实施例表明队列优选数据库的示意图。
[0044]图1lA是按照一个实施例表明配置为从传送队列接收数据的接收队列的可用容量的示意图。
[0045]图1lB是按照一个实施例表明配置为从传送队列接收数据的另一个接收队列的
可用容量的示意图。
[0046]图1lC是按照一个实施例表明与传送队列有关的反馈路径的可用容量的示意图。
[0047]图1lD是按照一个实施例表明用于传输寻址到传送队列的流量控制信号的定时的示意图。
[0048]图12是按照一个实施例表明用于限定流量控制信号的方法的流程图。
【具体实施方式】
[0049]经由链路在信源实体处的多级队列和在目的地实体处的多级队列之间传输的数据流(例如,数据分组,诸如网际协议(IP)分组)可以基于与多个流量控制环路有关的流量控制信号来控制。例如,如果由于目的地实体相对于正在发送的数据量来说具有有限的缓存能力,目的地实体(或者其一部分)不能处理来自信源实体的数据流,目的地实体可以将与至少一个流量控制环路有关的流量控制信号发送给信源实体。该流量控制信号可以被配置为触发信源实体以中止传输数据流给目的地实体。在一些实施例中,在信源实体和目的地实体之间的链路可以是物理链路,并且可以与单个网络跳跃(network hop)有关(例如,不能从地形上限定的网络步骤,或者与一个媒体访问控制(MAC)设备和另一个MAC设备之间的链路有关的网络步骤)。在一些实施例中,该信源实体可以称为发射机,并且目的地实体可以称为接收机。
[0050] 与链路有关的流量控制环路可以被限定为使得与流量控制环路有关的流量控制信号可以影响跨越该链路的多级队列的不同部分。例如,与第一流量控制环路有关的流量控制信号可触发中止来自第一级队列的数据传输和来自所有扇入(fan)第一级队列的第二级队列的数据传输。与不同的流量控制环路有关的流量控制信号可以触发中止来自少于所有扇入第一级队列的第二级队列的数据传输。在一些实施例中,在一个或多个第二级队列上接收并扇入第一级队列的数据可以来自于不同的(例如,单独的)网络设备。总之,与第二流量控制环路有关的流量控制信号可以触发与第一流量控制环路有关的流量控制信号所触发的不同的(例如,更加粒状的)数据流控制。
[0051 ] 在一些实施例中,与一级或多级队列有关的流量控制模块可以被配置为限定与流量控制环路有关的流量控制信号,和/或可以被配置为基于与流量控制信号有关的一个或多个参数值来执行流量相关动作(例如,中止数据传输)。在一些实施例中,与流量控制信号有关的一个或多个参数值可以存储在目的地实体和/或信源实体上。该存储的参数值可用于限定另一个流量控制信号,和/或可用于修改和/或调度从信源实体到目的地实体的数据传输。在一些实施例中,包括与多级队列内的几个队列相关的参数值的流量控制分组可以经由流量控制信号将其从目的地实体传送给信源实体。在一些实施例中,流量控制信号可以被配置为表示至少一部分目的地实体可以用来接收数据。
[0052]图1是按照一个实施例表明多级流量可控队列的示意方框图。如图1所示,第一级队列110的发送侧和第二级队列120的发送侧包括在物理链路100的发送侧上的信源实体130中。第一级队列110的接收侧和第二级队列120的接收侧包括在物理链路100的接收侧上的目的地实体140中。该信源实体130和/或目的地实体140可以是任何类型的计算设备(例如,服务器、个人计算机、路由器、多级开关),其可以被配置为经由物理链路100接收和/或传送数据。在一些实施例中,信源实体130和/或目的地实体140可以与数据中心有关。结合图6,论述了在数据中心内与流量可控队列相关的更多的细节。
[0053]如图1所示,第一级队列110包括在物理链路100的发送侧上传送队列A1至A4 (称为第一级传送队列134),和在物理链路100的接收侧上接收队列D1至D4 (称为第一级接收队列144)。第二级队列120包括在物理链路100的发送侧上传送队列B1和B2(称为第二级传送132),和在物理链路100的接收端上接收队列C1和C2 (称为第二级接收队列142)。经由物理链路100的数据流可以基于与信源实体130和目的地实体140之间的流量控制环路有关的流量控制信号来控制(例如,修改、中止)。例如,从物理链路100的发送侧上的信源实体130传送的数据可以在物理链路100的接收侧上的目的地实体140上接收。当目的地实体140不可用于经由物理链路100从信源实体130接收数据的时候,流量控制信号可以在目的地实体140上被限定和/或从目的地实体140发送到信源实体130。该流量控制信号可以被配置去触发信源实体130以修改从信源实体130到目的地实体140的数据流。
[0054]例如,如果接收队列D2不可用于处理从传送队列A1传送的数据,则目的地实体140可以被配置为将与流量控制环路有关的流量控制信号发送给信源实体130 ;该流量控制信号可以被配置去触发中止经由传输路径从传送队列A1到接收队列D2的数据传输,该传输路径包括至少一部分第二级队列120和物理链路100。在一些实施例中,接收队列D2可能是不可用的,例如,当接收队列D2太满以至于不能接收数据的时候。在一些实施例中,该接收队列D2可以响应于预先地从传送队列A1接收的数据,从可用的状态变化为不可用的状态(例如,拥塞状态)。在一些实施例中,传送队列A1可以称为流量控制信号的目标。可以基于与传送队列A1有关的队列标识符在流量控制信号内识别该传送队列4。在一些实施例中,该流量控制信号可以称为反馈信号。
[0055]在这个实施例中,流量控制环路与物理链路100 (称为物理链路控制环路)有关,流量控制环路与第一级队列110(称为第一级控制环路)有关,并且流量控制环路与第二级队列120 (称为第二级控制环路)有关。特别地,该物理链路控制环路与包括物理链路100,并且排除第一级队列Iio以及第二级队列120的传输路径有关。经由物理链路100的数据流可以基于与物理链路控制环路有关的流量控制信号开启和关闭。
[0056]第一级控制环路可以基于来自第二级队列110内的至少一个传送队列134的数据传输和流量控制信号,基于第一级队列110内的至少一个接收队列144的可用性(例如,可用性的指示符)限定该流量控制信号。因此,第一级控制环路可以被认为是与第一级队列110有关。第一级控制环路可以与传输路径有关,该传输路径包括物理链路100、至少一部分第二级队列120和至少一部分第一级队列110。与第一级控制环路有关的流量控制信令可以触发控制来自与第一级队列110有关的传送队列134的数据流。
[0057]第二级控制环路可以与包括物理链路100,并且包括至少一部分第二级队列120,但是排除第一级队列Iio的传输路径有关。第二级控制环路可以基于来自第二级队列120内的至少一个传送队列132的数据传输和流量控制信号,基于第二级队列120内的至少一个接收队列142的的可用性(例如,可用性指示符)限定该流量控制信号。因此,第二级控制环路可以被认为是与第二级队列120有关。与第二级控制环路有关的流量控制信号可以触发控制来自与第二级队列120有关的传送队列132的数据流。
[0058]在这个实施例中,与队列120的第二级有关的该流量控制环路是基于优先级的流量控制环路。特别地,来自第二级传送队列132的每个传送队列与来自第二级接收队列142的接收队列成对;并且每个队列对与服务水平(也可以称为服务等级或者服务质量)有关。在这个实施例中,第二级传送队列B1和第二级传送队列C1限定队列对,并且与服务水平X有关。第二级传送队列B2和第二级传送队列C2限定队列对,并且与服务水平Y有关。在一些实施例中,不同类型的网络业务量可以与不同的服务水平(并且因此不同的优先级)有关。例如,存储业务量(例如,读和写业务量)、处理器间的通信、媒体信令、对话层信号等等,每个可以与至少一个服务水平有关。在一些实施例中,第二级控制环路可以基于例如电气与电子工程师协会(IEEE)802.1qbb协议,其限定基于优先级的流量控制策略。
[0059]在图1中示出的经由传输路径14传输的数据流可以使用至少一个控制环路控制。传输路径14包括第一级传送队列A2、第二级传送队列B1、物理链路100、第二级接收队列C1和第一级接收队列D3。但是,在传输路径14的一级中,基于与该级有关的流量控制环路,经由队列的数据流中的变化可以影响通过传输路径14的另一级的数据流。在一级上的流量控制可以影响在另一级上的数据流,因为在信源实体130内的队列(例如,传送队列132、传送队列134)和在目的地实体140内的队列(例如,接收队列142、接收队列144)被分级。换句话说,基于一个流量控制环路的流量控制可以对经由与不同的流量控制环路有关的单元的数据流有影响。
[0060]例如,经由传输路径14从第一级传送队列A1传输到第一级接收队列D3的数据流可以基于一个或多个控制环路,即第一级控制环路、第二级控制环路和/或物理链路控制环路被修改。可以触发中止数据流向第一级接收队列D3,因为第一级接收队列D3可能已经从可用的状态改变为不可用的状态(例如,拥塞状态)。
[0061]如果流向第一级接收队列D3的数据与服务水平X有关,则基于与第二级控制环路(其基于优先级的控制环路)有关的流量控制信令,可以中止经由第二级传送队列B1和第二级接收队列C1 (其限定与服务水平X有关的队列对)的数据流。但是,中止经由与服务水平X有关的队列对的数据传输可导致中止扇入第二级传送队列B1的来自传送队列的数据传输。特别地,中止经由与服务水平X有关的队列对的数据传输不仅可以导致中止来自第一级传送队列A2的数据传输,而且还可以导致中止来自第一级传送队列A1的数据传输。换句话说,来自第一级传送队列八1的数据流间接地或对比地受到影响。在一些实施例中,在传送队列A1上接收的数据和在传送队列A2上接收的数据可以与相同的服务水平X有关,但是,在传送队列A1上接收的数据和在传送队列A2上接收的数据可以例如来自与不同的服务水平有关的不同的(例如,独立的)网络设备(未示出)。
[0062]流向第一级接收队列D3的数据还可以基于与第一级控制环路有关的流量控制信令通过具体地中止从第一级传送队列A2传输数据来中止。通过直接中止从第一级传送队列A2传输数据,可以不必中断来自第一级传送队列A1的数据传输。换句话说,可以无需中止来自诸如第一级传送队列A1的其它第一级传送队列的数据传输,就能基于与第一级控制环路有关的流量控制信号直接控制第一级传送队列A2的流量控制。
[0063]流向第一级接收队列D3的数据还可以基于与物理链路控制环路有关的流量控制信令通过中止经由物理链路10的数据传输来控制。但是,中止经由物理链路100的数据传输可能导致中止经由物理链路100的所有数据传输。
[0064]在物理链路100的发送侧上的队列可以称为传送队列136,并且在物理链路的接收侧上的队列可以称为接收队列146。在一些实施例中,该传送队列136还可以称为信源队列,并且该接收队列146可以称为目的地队列。虽然未示出,但是在一些实施例中,一个或多个传送队列136可以包括在与信源实体130有关的一个或多个接口卡中,并且一个或多个接收队列146可以包括在与目的地实体140有关的一个或多个接口卡中。
[0065]当信源实体130经由物理链路100传送数据的时候,信源实体130可以称为安置在物理链路100的发送侧上的发射机。目的地实体140可以被配置去接收数据,并且可以称为安置在物理链路100的接收侧上的接收机。虽然未示出,但是在一些实施例中,该信源实体130 (和相关的单元(例如,传送队列136))可以被配置为起目的地实体(例如,接收机)的作用并且该目的地实体140 (和相关的单元(例如,接收队列146))可以被配置为起信源实体(例如,发射机)的作用。另外,该物理链路100可以起双向链路的作用。
[0066]在一些实施例中,该物理链路100可以是有形的链路,诸如光链路(例如,光纤缆、塑料光纤缆)、电缆链路(例如,基于铜的线路)、双绞线链路(例如,5类电缆)等等。在一些实施例中,该物理链路100可以是无线链路。经由物理链路100的数据传输可以基于诸如以太网协议、无线协议等等的协议来限定。
[0067]在一些实施例中,第二级控制环路可以被认为是嵌套(例如,逻辑地嵌套)在第一级控制环路内,因为与第二级控制环路有关的第二级队列120被安置在第一级队列110(其与第一级控制环路有关)的内侧。类似地,该物理链路控制环路可以被认为是嵌套(例如,逻辑地嵌套)在第二级控制环路内。在一些实施例中,第二级控制环路可以称为内部控制环路,并且第一级控制环路可以称为外部控制环路。
[0068]图2是按照一个实施例表明多级流量可控队列的示意方框图。如图2所示,第一级队列210的发送侧和第二级队列220的发送侧包括在物理链路200的发送侧上所安排的信源实体230中。第一级队列210的接收侧和第二级队列220的接收侧包括在物理链路200的接收侧上所安排的目的地实体240中。在物理链路200的发送侧上的队列可以集体地称为传送队列236,并且在物理链路的接收侧上的队列可以集体地称为接收队列246。虽然未示出,但是在一些实施例中,该信源实体230可以被配置为起目的地实体的作用,并且目的地实体240可以被配置为起信源实体(例如,发射机)的作用。另外,该物理链路200可以起双向链路的作用。
[0069]如图2所示,信源实体230经由物理链路200与目的地实体240通信。信源实体230具有队列QP1,该队列配置为在经由物理链路200在传送数据之前缓存数据(必要时),并且目的地实体240具有队列QP2,该队列配置为在目的地实体240上分配数据之前缓存经由物理链路200接收的数据(必要时)。在一些实施例中,无需缓存队列QPl和队列QP2就能处理经由物理链路200的数据流。
[0070]包括在第一级队列210中的传送队列QA1至QAn可以都称为第一级传送队列,并且可以集体地称为传送队列234 (或者称为队列234)。包括在第二级队列220中的传送队列QB1至QBm可以都称为第二级传送队列,并且可以集体地称为传送队列232(或者称为队列232)。包括在第一级队列210中的接收队列QD1至QDk可以都称为第一级接收队列,并且可以集体地称为接收队列244 (或者称为队列244)。包括在第二级队列220中的接收队列QC1至QCm可以都称为第二级接收队列,并且可以集体地称为接收队列242 (或者称为队列 242)。
[0071]如图2所示,第二级队列220中的每个队列被安排在物理链路200和第一级队列210中的至少一个队列之间的传输路径内。例如,一部分传输路径可以由第一级接收队列QD4、第二级接收队列QC1和物理链路200限定。第二级接收队列QC1被安排在第一级接收队列QD4和物理链路200之间的传输路径内。
[0072]在这个实施例中,物理链路控制环路与物理链路200有关,第一级控制环路与第一级队列210有关,并且第二级控制环路与第二级队列220有关。在一些实施例中,第二级控制环路可以是基于优先级的控制环路。在一些实施例中,该物理链路控制环路可以包括物理链路200、队列QPl和队列QP2。
[0073]在信源实体230上的信源控制模块270和在目的地实体240上的目的地控制模块280之间可以限定和/或传送流量控制信号。在一些实施例中,该信源控制模块270可以称为信源流量控制模块,并且该目的地控制模块280可以称为目的地流量控制模块。例如,当在目的地实体240上的一个或多个接收队列246 (例如,接收队列QD2)不可用于接收数据的时候,目的地控制模块280可以被配置去将流量控制信号发送给信源控制模块。该流量控制信号可以被配置为触发信源控制模块270,从而例如中止数据从一个或多个接收队列236流动到一个或多个接收队列246。
[0074]信源控制模块270可以在该数据被传送之前将队列标识符与传送队列236中的传送队列上排队的数据相关联。该队列标识符可以代表和/或可用于识别正在排队该数据的传送队列。例如,当数据分组在第一级传送队列QA4上排队的时候,唯一地识别第一级传送队列QA4的队列标识符可以附加在该数据分组中,或者包括在该数据分组内的字段(例如,头部部分、尾部部分、有效载荷部分)中。在一些实施例中,该队列标识符可以与信源控制模块270上的数据有关,或者由信源控制模块270触发。在一些实施例中,该队列标识符可以仅仅在数据被传送之前、或者与在已经从一个传送队列236传送该数据之后与数据有关。
[0075]该队列标识符可以与从物理链路200的发送侧传送到物理链路200的接收侧的数据有关,使得可以识别数据的来源(例如,该信源队列)。因此,流量控制信号可以被限定以基于该队列标识符中止一个或多个传送队列236的传输。例如,与第一级传送队列QAn有关的队列标识符可以包括在从第一级传送队列QAn传送到第一级接收队列QD3的数据分组中。在接收到该数据分组之后,如果第一级接收队列QD3不能从第一级传送队列QAn接收另一个数据分组,则基于与第一级传送队列QAn有关的队列标识符限定流量控制信号,该流量控制信号请求第一级传送队列QAn中止传输附加的数据分组到第一级接收队列QD3。该队列标识符可以由目的地控制模块280从数据分组中解析,并且由目的地控制模块280使用以限定该流量控制信号。
[0076]在一些实施例中,响应于第一级接收队列QDk从可用的状态改变到不可用的状态,可以中止数据从多个传送队列236 (例如,第一级传送队列234)到第一级接收队列QDk的数据传输。每个传送队列236可以基于其相应的队列标识符在流量控制信号内得以识别。
[0077]在一些实施例中,一个或多个传送队列236和/或一个或多个接收队列246可以是虚拟的队列(例如,逻辑地限定的队列组)。因此,队列标识符可以与虚拟的队列有关(例如,可以代表)。在一些实施例中,队列标识符可以与限定虚拟队列的一组队列中的队列有关。在一些实施例中,与物理链路200有关的一组队列标识符中的每个队列标识符可以是唯一的。例如,每个传送队列236与物理链路200 (例如,与中继段有关)有关,其可以与唯一的队列标识符有关。
[0078]在一些实施例中,该信源控制模块270可以被配置为将队列标识符仅仅与传送队列236的指定子集和/或仅仅与在一个传送队列236上排队的数据子集相关。例如,如果无需队列标识符就将数据从第一级传送队列QA2传送到第一级接收队列QD1,则可能不能定义配置为请求中止来自第一级传送队列QA2的数据传输的流量控制信号,因为可能不知道数据的来源。因此,当从传送队列传送该数据的时候,可以通过将(例如,省略)队列标识符不与数据相关来从流量控制除去传送队列236中的传送队列。
[0079]在一些实施例中,可以基于满足的条件限定在目的地实体240上的一个或多个接收队列246的不可用性。该条件可以与队列的存储限制、队列访问速率、数据进队列的流速等等有关。例如,响应于一个或多个接收队列246的状态可以在目的地控制模块280上限定流量控制信号,例如该接收队列是基于超出的阈值存储限制从可用的状态改变到不可用的状态(例如,拥塞状态)的第二级接收队列QC2。当处于不可用的状态之中的时候,第二级接收队列QC2不可用于接收数据,因为例如第二级接收队列QC2被认为太满(如由超出的阈值存储限制表示的)。在一些实施例中,当禁止的时候,一个或多个接收队列246可以处于不可用的状态之中。在一些实施例中,当该接收队列不可用于接收数据的时候,可以基于中止从接收队列246到接收队列数据传输的请求限定该流量控制信号。在一些实施例中,响应于接收队列246的特定子集(例如,在指定级内的接收队列)处于拥塞状态之中,一个或多个接收队列246的状态可以(由目的地控制模块280)从可用的状态改变到拥塞状态。
[0080]在一些实施例中,可以在目的地控制模块280上限定流量控制信号,以表示接收队列246中的一个已经从不可用的状态改变到可用的状态。例如,最初,目的地控制模块280可以被配置为响应于第一级接收队列QD3从可用的状态改变到不可用的状态,限定和发送第一流量控制信号给信源控制模块270。第一级接收队列QD3可以响应于从第一级传送队列QA2发送的数据而从可用的状态改变到不可用的状态。因此,第一流量控制信号的目标可以是第一级传送队列QA2 (如基于队列标识符表示的)。当第一级接收队列QD3从不可用的状态改变回到可用的状态的时候,目的地控制模块280可以被配置为限定和发送表示从不可用的状态改变回到可用的状态的第二流量控制信号给信源控制模块270。在一些实施例中,该信源控制模块270可以被配置为响应于第二流量控制信号,触发从一个或多个传送队列236到第一级接收队列QD3的数据传输。
[0081 ] 在一些实施例中,流量控制信号可以具有一个或多个参数值,其可以由信源控制模块270使用,以修改来自传送队列236中的一个(在流量控制信号内由队列标识符识别)的传输。例如,流量控制信号可以包括一个参数值,其可以触发信源控制模块270在指定的一段时间(例如,10毫秒(ms))中止来自传送队列236中的一个的传输。换句话说,该流量控制信号可以包括中止时间段参数值。在一些实施例中,该中止时间段可以是不确定的。在一些实施例中,该流量控制信号可以限定请求,从而以指定的速率(例如,每秒指定的帧数、每秒指定的字节数)从传送队列236中的一个或多个传送数据。
[0082]在一些实施例中,可以基于流量控制算法限定流量控制信号(例如,在流量控制信号内的中止时间段)。可以基于接收队列246 (例如,第一级接收队列QD4)中的接收队列不可用的时间段来限定该中止时间段。在一些实施例中,可以基于第一级接收队列244中的多个不可用来限定该中止时间段。例如,在一些实施例中,当多于或者少于指定数目的第一级接收队列244处于拥塞状态之中的时候,可以增加该中止时间段。在一些实施例中,可以在目的地控制模块280上进行这种类型的确定。该接收队列不可用的时间段可以是目的地控制模块280基于例如来自接收队列的数据流速(例如,历史流量速率、早先的流速)计算的预计(例如,预测的)时间段。
[0083]在一些实施例中,该信源控制模块270可以拒绝或者改变请求以修改来自传送队列236中的一个或多个的数据流。例如,在一些实施例中,该信源控制模块270可以被配置为减少或者增加中止时间段。在一些实施例中,不是响应于流量控制信号中止数据传输,而是该信源控制模块270可以被配置为修改与传输队列236之一有关的传输路径。例如,如果第一级传送队列QA2已经接收到基于第一级接收队列QD2的状态中的变化中止传输的请求的话,则该信源控制模块270可以被配置为触发从第一级传送队列QA2到例如第一级接收队列QD3的数据传输,而不是遵循中止传输的请求。
[0084]如图2所示,在第二级队列220内的队列扇入或者扇出物理链路200。例如,在物理链路200的发送侧上的传送队列232 (即,队列QB1至QBm)扇入物理链路200的发送侧上的队列QP1。因此,在任何一个传送队列232上排队的数据可以传送给物理链路200的队列QPl0在物理链路200的接收侧上,从物理链路200经由队列QP2传送的数据可以广播给接收队列242 (即,队列QC1至QCm)。
[0085]此外,如图2所示,在第一级队列210内的传送队列234扇入第二级队列220内的传送队列232。例如,在第一级传送队列QAp (^4和QAn_2中的任一个上排队的数据可以传送给第二级传送队列QB2。在物理链路200的接收侧上,例如从第二级接收队列QCm传送的数据可以广播给第一级接收队列QDim和QDK。[0086]因为许多流量控制环路(例如,第一控制环路)与不同的扇入和扇出体系结构有关,所以该流量控制环路可以对经由物理链路200的数据流量具有各种各样的影响。例如,当基于第二级控制环路中止来自第二级传送队列QB1的数据传输的时候,也中止从第一级传送队列QVQA2、QA3和QAim经由第二级传送队列QBl到接收队列246中的一个或多个的数据传输。在这种情况下,当中止来自下游队列(例如,第二级传送队列QB1)的传输时,中止来自一个或多个上游队列(例如,第一级传送队列QA1)的数据传输。相比之下,如果基于第一级控制环路中止从第一级传送队列QA1沿着包括至少下游第二级传送队列QB1的传输路径传输数据,则无需完全地中止来自第二级传送队列QB1的数据传输,就能降低来自第二级传送队列QB1的数据流的速率;例如,第一级传送队列QA1仍然能够经由第二级传送队列QB1传送数据。
[0087]在一些实施例中,扇入和扇出体系结构可以不同于在图2中示出的那些。例如,在一些实施例中,在第一级队列210内的一些队列可以被配置去扇入该物理链路200,绕过第二级队列220。
[0088]与传送队列236有关的流量控制信令是由信源控制模块270处理的,并且与接收队列246有关的流量控制信令是由目的地控制模块280处理的。虽然未示出,但在一些实施例中,流量控制信令可以由一个或多个控制模块(或者控制子模块)(其可以单独的和/或集成为单个控制模块)处理。例如,与第一级接收队列244有关的流量控制信令可以由控制模块处理,该控制模块与配置为处理与第二级接收队列242有关的流量控制信令的控制模块分离。同样地,与第一级传送队列234有关的流量控制信令可以由与配置为处理与第二级传送队列232有关的流量控制信令的控制模块分离的控制模块处理。在一些实施例中,该信源控制模块270和/或目的地控制模块280的一个或多个部分可以是基于硬件的模块(例如,数字信号处理器(DSP)、现场可编程门阵列(FPGA)),和/或基于软件的模块(例如,计算机代码的模块、一组处理器可读的命令,其可以在处理器上执行)。
[0089]图3是按照一个实施例表明配置为限定与多个接收队列有关的流量控制信号28的目的地控制模块350的示意方框图。多级队列包括第一级队列310和第二级队列320。如图3所示,信源控制模块360与第一级队列310的发送侧有关,并且目的地控制模块350与第一级队列310的接收侧有关。在物理链路300的发送侧上的队列可以集体地称为传送队列370。在物理链路300的接收侧上的队列可以集体地称为接收队列380。
[0090]该目的地控制模块350被配置为响应于第一级队列310内的一个或多个接收队列不可用于接收来自第一级队列310上的单个信源队列的数据,而将流量控制信号28发送给信源控制模块360。该信源控制模块360可以被配置为基于该流量控制信号28,中止从第一级队列310上的信源队列到第一级队列310上的多个接收队列的数据传输。
[0091]可以由目的地控制模块280基于与第一级队列310内的每个不可用的接收队列有关的信息限定该流量控制信号28。该目的地控制模块350可以被配置去采集与不可用的接收队列有关的信息,并且可以被配置去限定流量控制信号28,使得不发送潜在地冲突的流量控制信号(未示出)给第一级队列310上的单个信源队列。在一些实施例中,基于信息采集而限定的流量控制信号28可以称为聚集的流量控制信号。
[0092]具体地,在这个例子中,该目的地控制模块350被配置为响应于第一级队列310的接收侧上的两个接收队列,即接收342和接收队列346,不可用于从第一级队列310的发送侧上的传送队列312接收数据来限定流量控制信号28。在这个实施例中,响应于分别经由传输路径22和传输路径24从传送队列312发送的数据分组,接收队列342和接收队列346被从可用的状态改变到不可用的状态。如图3所示,传输路径22包括传送队列312,在第二级队列320内的传送队列322,物理链路300,在第二级队列320内的接收队列332和接收队列342。传输路径24包括传送队列312、传送队列322、物理链路300、接收队列332和接收队列346。
[0093]在一些实施例中,流量控制算法可用于基于与接收队列342的不可用性相关的信息,和/或与接收队列346的不可用性相关的信息限定流量控制信号28。例如,如果目的地控制模块350确定接收队列342和接收队列346对于不同的时间段将是不可用的,则目的地控制模块350可以被配置为基于不同的时间段限定流量控制信号28。例如,目的地控制模块350可以经由流量控制信号28请求在一段时间内中止来自传送队列312的数据传输,这段时间是基于不同的时间段(例如,时间段等于不同的时间段的平均值,时间段等于不同的时间段中的较大值)来计算。在一些实施例中,可以基于来自第一级队列310的接收侧的专用中止请求(例如,与接收队列342有关的中止请求和与接收队列346有关中止请求)限定该流量控制信号28。
[0094]在一些实施例中,可以基于最大或者最小的可容许时间段限定该流量控制信号
28。在一些实施例中,可以基于例如来自传送队列312的数据的聚集流速计算该流量控制信号28。例如,可以基于来自传送队列312的数据的聚集流速依比例决定该中止时间段。在一些实施例中,例如,如果来自传送队列312的数据的流速大于一个阈值,该中止时间段可以提高,并且如果来自传送队列312的数据的流速低于一个阈值,该中止时间段可以降低。
[0095]在一些实施例中,该流控制算法可以被配置为在限定和/或发送流量控制信号28之前等待指定的一段时间。该等待时间段可以被限定,使得与传送队列312相关的多个中止请求可用于限定该流量控制信号28,可以在等待时间段内的不同的时期接收该多个中止请求。在一些实施例中,可以响应于与接收的传送队列312相关的至少一个中止请求触发该等待时间段。
[0096]在一些实施例中,可以由流量控制算法基于与第一级队列310内的每个接收队列有关的优先值限定该流量控制信号28。例如,如果接收队列342具有高于与接收队列346有关的优先值的优先值,则目的地控制模块350可以被配置去基于与接收队列342有关而与不是接收队列346有关的信息限定流量控制信号28。例如,可以基于与接收队列342有关的中止时间段,而不是与接收队列346有关的中止时间段限定该流量控制信号28,因为接收队列342可以具有比与接收队列346有关的优先值更高的优先值。
[0097]在一些实施例中,可以由流量控制算法基于与第一级队列310内的每个接收队列有关的属性限定该流量控制信号28。例如,可以基于指定类型的队列(例如,后进先出(LIFO)队列,先进先出(FIFO)队列)的接收队列342和/或接收队列346限定该流量控制信号28。在一些实施例中,可以基于配置为接收指定类型的数据(例如,控制数据/信号队列、介质数据/信号队列)的接收队列342和/或接收队列346限定该流量控制信号28。
[0098]虽然未示出,但与某级队列(例如,第一级队列310)有关的一个或多个控制模块可以配置为发送信息给不同的控制模块,在这里该信息可用于限定流量控制信号。该不同的控制模块可以与不同级的队列有关。例如,可以在目的地控制模块350上限定与接收队列342有关的中止请求和与接收队列346有关的中止请求。该中止请求可以发送给与第二级队列320的接收侧有关的目的地控制模块(未示出)。可以在与第二级队列320的接收侧有关的目的地控制模块上基于中止请求和基于流量控制算法限定流量控制信号(未示出)。
[0099]可以基于与第一级队列310有关的流量控制环路(例如,第一级控制环路)限定该流量控制信号28。可以基于与第二级队列320有关的流量控制环路和/或与物理链路300有关的流量控制环路限定一个或多个流量控制信号(未示出)还。
[0100]与第一级队列310 (除传送队列312以外)内的传送队列有关的数据传输大体上不受流量控制信号28限制,因为到接收队列342和346的数据流是基于第一级流量控制环路而得以控制的。例如,即使中止来自传送队列312的数据传输,但传送队列314可以继续经由传送队列322发送数据。例如,传送队列314可以被配置为即使已经中止经由传送队列322来自传送队列312的数据传输,但仍经由包括传送队列322的传输路径26发送数据到接收队列348。在一些实施例中,传送队列322可以被配置为即使基于流量控制信号28已经中止经由传输路径22来自队列312的数据传输,但仍继续从例如传送队列316发送数据给接收队列342。
[0101]如果取而代之通过基于与第二级控制环路有关的流量控制信号(未示出)控制经由传送队列322的数据流,从而中止去往接收队列342和346的数据传输,则经由传送队列322来自传送队列314和传送队列316的数据传输也将被限制(除了来自传送队列312的数据传输之外)。可以中止来自传送队列322的数据传输,因为其与指定的服务水平有关,并且例如在接收队列342和346上造成拥塞的数据可以与指定的服务水平有关。
[0102]在流量控制信号28内限定的一个或多个参数值可以存储在目的地控制模块350的存储器352上。在一些实施例中,在参数值已经被限定之后,和/或当该流量控制信号28被发送给信源控制模块360的时候,该参数值可以存储在目的地控制模块350的存储器352上。在流量控制信号28内限定的参数值可用于跟踪例如传送队列312的状态。例如,在存储器352内的条目可以表示该传送队列312是处于中止状态(例如,非传送状态)之中。可以基于在流量控制信号28内限定的中止时间段参数值限定该项目。当该中止时间段已经期满的时候,更新该项目以表示传送队列312的状态已经转变为例如激活状态(例如,传送状态)。虽然未示出,但在一些实施例中,该参数值可以存储在目的地控制模块350外面的存储器(例如,远程存储器)上。
[0103]在一些实施例中,存储在目的地控制模块350的存储器352上的参数值(例如,基于参数值限定的状态信息)可以由目的地控制模块350使用,以确定是否应限定附加流量控制信号(未示出)。在一些实施例中,该参数值可以由目的地控制模块350使用以限定一个或多个附加流量控制信号。
[0104]例如,如果响应于从传送队列312接收的第一数据分组,接收队列342从可用的状态改变为不可用的状态(例如,拥塞状态),则可以经由流量控制信号28发送中止来自传送队列312数据传输的请求。基于队列标识符,该流量控制信号28可以表示传送队列312是请求的目标,并且可以指定中止时间段。当发送该流量控制信号28给信源控制模块360的时候,与传送队列312有关的该中止时间段和队列标识符可以存储在目的地控制模块350的存储器352中。在发送流量控制信号28之后,响应于从传送队列312 (传输路径没有在图3中示出)接收的第二数据分组,接收队列344从可用的状态改变为拥塞状态。在基于流量控制信号28中止来自传送队列312的数据传输之前,可以从传送队列312发送第二数据分组。该目的地控制模块350可以访问存储在存储器352中的信息,并且可以响应于与接收队列344有关的状态中的变化,确定不应当限定以传送队列312为目标的附加流量控制信号,并且发送给信源控制模块360,因为流量控制信号28已经被发送。
[0105]在一些实施例中,该信源控制模块360可以被配置为基于最近的流量控制信号参数值中止来自传送队列312的传输。例如,在已经将目标是传送队列312的流量控制信号28发送给信源控制模块360之后,可以在信源控制模块360上接收到目标是传送队列312的稍后的流量控制信号(未示出)。该信源控制模块360可以被配置为实现与稍后的流量控制信号有关的一个或多个参数值,而不是与流量控制信号28有关的参数值。在一些实施例中,稍后的流量控制信号可以触发该传送队列312在比流量控制信号28中表示的时间更长或者更短的一段时间内保持中止状态。
[0106]在一些实施例中,当与该参数值有关的优先值高于(或者低于)与一个或多个与流量控制信号28有关的参数值有关的优先值的时候,该信源控制模块360可以可选地执行与稍后的流量控制信号有关的一个或多个参数值。在一些实施例中,可以在目的地控制模块350上限定每个优先值,并且可以基于与接收队列380中的一个或多个有关的优先值来限定每个优先值。
[0107]在一些实施例中,可以响应于来自不可用的接收队列380的同一个接收队列限定流量控制信号28和稍后的流量控制信号(这两个都是以传送队列312为目标)。例如,稍后的流量控制信号可以包括更新的参数值,目的地控制模块350基于在比之前计算的时间更久的时间段内保持不可用的状态的接收队列342限定该参数值。在一些实施例中,可以响应于改变状态(例如,从可用的状态改变到不可用的状态)的接收队列380中的一个来限定目标是传送队列312的流量控制信号28,并且可以响应于改变状态(例如,从可用的状态改变到不可用的状态)的接收队列380中的另一个来限定目标是传送队列312的稍后的流量控制信号。
[0108]在一些实施例中,可以在目的地控制模块350限定多个流量控制信号,以中止从来自第一级队列310中的多个传送队列的传输。在一些实施例中,多个传送队列可以传输数据给单个接收队列,诸如接收队列344。在一些实施例中,来自第一级队列310中的多个传送队列的流量控制信号的历史记录可以存储在目的地控制模块350的存储器352中。在一些实施例中,可以基于流量控制信号的历史记录计算与单个接收队列有关的稍后的流量控制信号。
[0109]在一些实施例中,与多个传送队列有关的中止时间段可以被分组和包括在流量控制分组中。例如,与传送队列312有关的中止时间段和与传送队列314有关的中止时间段可以包括在流量控制分组(也可以称为流量控制分组)中。结合图4描述了与流量控制分组相关的更多的细节。
[0110]图4是按照一个实施例表明流量控制分组的示意图。该流量控制分组包括包头410、包尾420和有效载荷430,有效载荷430包括用于由队列标识符(ID)(在列414中示出)代表的几个传送队列的中止时间段参数值(在列412中示出)。如图4所示,由队列IDl至V( S卩,Queue ID1至Queue IDv)代表的传送队列分别是与中止时间段参数值I至V(即,中止时间Period1至中止时间Periodv)有关。该中止时间段参数值414表示应中止(例如,禁止)由队列ID412代表的传送队列传输数据的时间段。
[0111]在一些实施例中,例如,可以在诸如在图3中示出的目的地控制模块350这样的目的地控制模块上限定该流量控制分组。在一些实施例中,该目的地控制模块可以被配置为以常规的时间间隔限定流量控制分组。例如,该目的地控制模块可以被配置为每隔10毫秒限定流量控制分组。在一些实施例中,该目的地控制模块可以被配置为当已经计算出中止时间段参数值的时候,和/或当已经计算出指定数目的中止时间段参数值的时候,随机地限定流量控制分组。在一些实施例中,例如,基于一个或多个参数值和/或由目的地控制模块访问的状态信息,该目的地控制模块可以确定不应限定和/或发送至少一部分流量控制分组。
[0112]虽然未示出,但在一些实施例中,多个队列ID可以与单个中止时间段参数值有关。在一些实施例中,至少一个队列ID可以与除中止时间段参数值以外的参数值有关。例如,队列ID可以与流速参数值有关。该流速参数值可以表示传送队列(由队列ID代表的)将要发送数据的流速(例如最大流速)。在一些实施例中,该流量控制分组可以具有配置为表示特定的接收队列是否可以用于接收数据的一个或多个字段。
[0113]可以经由流量控制信号(诸如,在图3中示出的流量控制信号28)从目的地控制模块传送该流量控制分组到信源控制模块(诸如,在图3中示出的信源控制模块360)。在一些实施例中,可以基于第2层(例如,开放系统互连(OSI)模型的第2层)协议限定该流量控制分组。换句话说,可以在网络系统的第2层内限定和使用该流量控制分组。在一些实施例中,可以在与第2层(例如,MAC设备)有关的设备之间传送该流量控制分组。
[0114]回来参考图3,与该流量控制信号28有关的一个或多个参数值(例如,基于参数值限定的状态信息)可以存储在信源控制模块360的存储器362中。在一些实施例中,当在信源控制模块360上接收到该流量控制信号28的时候,该参数值可以存储在信源控制模块360的存储器362上。在流量控制信号28内限定的参数值可用于跟踪接收队列380中的一个或多个(例如,接收342)的状态。例如,在存储器362内的条目可以表示接收队列342不可用于接收数据。可以基于在流量控制信号28内限定并且与接收队列342的标识符(例如,队列标识符)有关的中止时间段参数值限定该项目。当该中止时间段已经期满的时候,更新该项目以表示接收队列342的状态已经转变为例如激活状态。虽然未示出,但在一些实施例中,该参数值可以存储在信源控制模块360外面的存储器(例如,远程存储器)上。
[0115]在一些实施例中,存储在信源控制模块360的存储器362上的参数值(和/或状态信息)可以由信源控制模块360使用,以确定是否应当将数据传送给接收队列380中的一个或多个。例如,该信源控制模块360可以被配置为基于与接收队列344和接收队列342相关的状态信息,将数据从传送队列316传送到接收队列344,而不是接收队列342。
[0116]在一些实施例中,该信源控制模块360可以分析数据传输模式,以确定是否应当将数据从一个或多个信源队列370传送到一个或多个接收队列380。例如,该信源控制模块360可以基于存储在信源控制模块360的存储器362上的参数值确定传送队列314正在给接收队列346发送相对较高容量的数据。基于这个确定,该信源控制模块360可以触发队列316而不是接收队列346去发送数据给接收队列348,因为接收队列346正在从传送队列314接收很高数量的数据。通过分析与传送队列370有关的传输模式,大体上可以避免在接收队列380中的一个或多个上拥塞的发生。
[0117]在一些实施例中,该信源控制模块360可以分析存储在信源控制模块360的存储器362上的参数值(和/或状态信息),以确定是否应当将数据传送给接收队列380中的一个或多个。通过分析存储的参数值(和/或状态信息),大体上可以避免在传送队列380中的一个或多个上发生拥塞。例如,基于比较(例如,是更好,是更糟)接收队列342的历史可用性和接收队列340的历史的可用性,信源控制模块360可以触发传送数据给接收队列340,而不是接收队列342。在一些实施例中,例如,基于在数据突发类型方面比较接收队列344的历史表现和接收队列342的历史表现,信源控制模块360可以传送数据给接收队列342,而不是接收队列344。在一些实施例中,与接收队列380中的一个或多个相关的参数值的分析可以基于特定的时间窗、特定类型的网络交易(例如,处理器间通信)、特定的服务水平等等。
[0118]在一些实施例中,该目的地控制模块350可以发送有关接收队列380的状态信息(例如,当前状态信息),该信息可以由信源控制模块360使用,以确定是否应当从信源队列370中的一个或多个传送数据。例如,该信源控制模块360可以触发队列314去发送数据给队列344,而不是队列346,因为正如由目的地控制模块350所表示的那样,队列346具有比队列344更多的可用容量。在一些实施例中,当前状态信息、传输模式分析和历史数据分析的任何组合可用于大体上防止,或者降低接收队列380中的一个或多个发生拥塞的可能性。
[0119]在一些实施例中,可以经由带外传输路径从目的地控制模块350发送流量控制信号28到信源控制模块360。例如,可以经由专用于与流量控制信令相关的通信的链路发送流量控制信号28。在一些实施例中,可以经由与第二级队列320有关的队列,与第一级队列310有关的队列,和/或物理链路300传送该流量控制信号28。
[0120]图5是按照一个实施例表明用于限定流量控制分组的方法的流程图。如图5所示,在500上,在第一级队列内的传送队列上排队的数据与代表传送队列的队列标识符有关。在一些实施例中,该队列标识符可以附加在该数据上,或者包括在与数据有关的一部分字段中。[0121]在510上,在传送队列上排队的数据经由第二级队列和物理链路被发送给第一级队列内的接收队列。换句话说,经由传输路径从传送队列发送该数据到接收队列,该传输路径不仅包括传送队列和接收队列,而且包括第二级队列中的至少一个队列和物理链路。第二级队列可以安排在第一级队列和物理链路之间。第一级队列的发送侧可以与数据中心的交换中心有关,并且第一级队列的接收侧可以与在数据中心边缘上的网络实体有关,反之亦然。第一级队列可以与第一级控制环路有关,并且第二级队列可以与第二级控制环路有关。在一些实施例中,该物理链路可以与物理链路控制环路有关。
[0122]在520上,响应于在接收队列上正在接收的数据而修改该接收队列的状态。在一些实施例中,可以响应于在接收队列上接收的数据将该接收队列的状态从可用的状态改变到拥塞状态。在一些实施例中,响应于正处于拥塞状态的级内的多个接收队列(或者,指定的接收队列的子集),将该接收队列的状态(由目的地控制模块)从可用的状态改变到拥塞状态。
[0123]在530上,基于接收队列的状态和基于该队列标识符,在中止时间段内限定中止来自传送队列的数据传输的请求。中止传输的该请求可以包括队列标识符,使得该传送队列可以被识别为中止请求的目标。在一些实施例中,可以基于转变为不活动状态或者禁止状态的接收队列的状态限定中止传输的请求。在一些实施例中,可以基于来自接收队列的数据流速来限定该中止时间段。
[0124]在540上,在与第二级队列的接收侧有关的目的地控制模块上修改与请求有关的中止时间段。可以基于中止来自传送队列的数据传输的多个请求来修改传送队列的中止时间段。在一些实施例中,基于中止来自传送队列的数据传输的多个请求,在配置为限定传送队列的中止时间段参数值的一部分目的地控制模块上修改该中止时间段。在一些实施例中,该目的地控制模块可以与接收侧的可能不包括第二级队列的不同的部分有关。在一些实施例中,可以拒绝该中止请求。
[0125]在550上,基于请求限定包括代表中止时间段的参数值的流量控制分组。在一些实施例中,该流量控制分组可以包括与多个队列标识符有关的中止周期参数值。
[0126]在560上,将该流量控制分组发送给与传送队列有关的信源控制模块。在一些实施例中,可以在预定时间,或者在与第二级队列的接收侧有关的信源控制模块处指定的时间上发送该流量控制分组。在一些实施例中,可以经由流量控制信号发送和/或经由带外传输路径发送该流量控制分组。
[0127]在560上,基于包括在流量控制分组中的中止时间段参数值中止来自第一级队列内的传送队列的数据传输。在一些实施例中,在信源控制模块上接收到该流量控制分组之后,可以用在信源控制模块上接收的流量控制信号(例如,不同的流量控制分组)减小该中止时间段。
[0128]图6是按照一个实施例表明数据中心600的示意方框图。该数据中心600包括网络实体610、网络实体620和网络实体630 (集体地称为网络实体680),其分别经由物理链路690中的至少一个与交换核心602通信。例如,网络实体630可以被配置为经由物理链路632从交换核心602传送数据和/或接收数据。当网络实体630经由物理链路632传送数据的时候,网络实体630可以被称为安排在物理链路632的发送侧上的发射机。交换核心602可以被配置为接收数据,并且可以被称为安排在物理链路632的接收侧上的接收机。相反地,交换核心602还可以被配置作为发射机传送数据,并且网络实体630可以被配置作为接收机接收该数据。
[0129]经由每个物理链路690 (物理链路612、物理链路622和/或物理链路632)的数据流可以基于一个以上的流量控制环路,诸如与图1到图5结合描述的那些来得以控制。该流量控制环路可以与物理链路690和/或部分数据中心600内的多级队列有关。例如,流量控制环路可以与物理链路622有关,并且至少一个流量控制环路可以与跨越物理链路622的若干级队列中的每一级有关。
[0130]在一些实施例中,每级队列可以在物理链路622的一侧(例如,发送侧)上具有队列的第一部分,和在物理链路622的另一例(例如,接收侧)上具有队列的第二部分。例如,虽然未示出,但在某一级队列内的第一队列可以包括在物理链路612的一侧上的网络实体610中,并且在该级队列内的第二队列可以包括在物理链路612的另一侧上的交换核心602中。流量控制环路可以与在包括在网络实体610中的该级队列内的第一队列有关,和在包括在交换核心602中的该级队列内的第二队列有关。
[0131]例如,如果第一队列(接收队列)不能处理从第二队列(传送队列)传送的数据,那么与第一队列有关的流量控制模块可以将配置为触发中止来自第二队列的数据传输的流量控制信号发送给第一队列。可以基于与第二队列有关的队列标识符在流量控制信号内识别第二队列。
[0132]如图6所示,网络实体610、网络实体620和网络实体630在数据中心600的边缘,并且分别地起到网络614、网络624和网络634网关的作用。网络614、网络624和/或网络634例如可以是虚拟网络、局域网(LAN)和/或广域网(WAN),并且可以包括一个或多个有线和/或无线的环节。
[0133]该数据中心600的交换核心602可以是具有多个级(例如,进入级、输出级、中间级)的转换结构,可以经由这些级路由数据。在一些实施例中,可以基于Clos网络体系结构(例如,不堵塞Clos网络、狭义不堵塞Clos网络、Benes网络)限定该交换核心602。在一些实施例中,网络体系结构,举例来说,诸如Clos网络和/或Benes网络是可重构的(例如,可重新排列的)。在一些实施例中,可以通过一个或多个多级开关(未示出)限定该交换核心602,每个开关包括一个或多个交换结构。在一些实施例中,该开关核心602可以被配置为起单个逻辑实体的作用。
[0134]图7是按照一个实施例表明用于将流量控制信号发送给两个不同的队列级的方法的流程图。如图7所示,在700上,当接收队列处于拥塞状态的时候,将第一流量控制信号发送给第一级传送队列。在一些实施例中,可以响应于接收队列处于拥塞状态的指示符发送第一流量控制信号。在一些实施例中,该指示符可以被称为拥塞指示符。在一些实施例中,响应于从第一级传送队列发送的一部分数据,将该接收队列的状态从可用的状态改变到拥塞状态。在一些实施例中,第一流量控制信号可以与第一流量控制环路有关。
[0135]在710上,当接收队列处于拥塞状态的时候,将第二流量控制信号发送给第二级传送队列。在一些实施例中,可以响应于接收队列处于拥塞状态的指示符发送第二流量控制信号。换句话说,触发第二流量控制信号发送的指示符可以与触发第一流量控制信号发送的指示符相同。在一些实施例中,可以由不同的指示符触发发送第一流量控制信号和发送第二流量控制信号。在一些实施例中,可以响应于从第二级传送队列发送的一部分数据,将该接收队列的状态从可用的状态改变到拥塞状态。在一些实施例中,第二流量控制信号可以与第二流量控制环路有关,第二流量控制环路不同于与第一流量控制信号有关的第一流量控制环路。
[0136]图8是按照一个实施例表明配置为处理与多级队列系统802有关的流量控制信号的控制模块的示意图。具体地,目的地控制模块850与多级队列系统802的接收侧有关,并且信源控制模块840与多级队列系统802的发送侧有关。如图8所示,多级队列系统802包括第一级队列810和第二级队列820。第一级队列810包括物理链路800的发送侧上的传送队列FA1至FAn (称为第一级传送队列834),和物理链路800的接收侧上的接收队列FD1至FDp (称为第一级接收队列844)。第二级队列820包括物理链路800的发送侧上的传送队列FB1和FBm(称为第二级传送队列832),和物理链路800的接收侧上的接收队列FC1和FCJ称为第二级接收队列842)。
[0137]当一个或多个接收队列不可用于处理从传送队列传送的该数据(例如,数据分组、数据流)的时候,该目的地控制模块850可以被配置为限定一个或多个流量控制信号,该一个或多个流量控制信号配置为触发修改来自一个或多个传送队列的数据流。该目的地控制模块850可以被配置为基于存储在状态数据库856中的状态值(例如,状态值的组合)限定流量控制信号。具体地,可以基于存储在状态数据库856中的状态值限定该流量控制信号的参数值(也可以称为命令)。例如,可以基于存储在状态数据库856中的一个或多个状态值在流量控制信号内限定应当修改来自传送队列的数据流量的特定方式。在一些实施例中,可以配置该目的地控制模块850,使得基于存储在状态数据库856中的一个或多个状态值,不发送流量控制信号(例如,没有限定流量控制信号,限定用于流量控制信号的参数值,但是不发送)。
[0138]该目的地控制模块850可以被配置为基于包括在状态数据库856中的状态值限定流量控制信号,使得可以以特定的方式控制来自多级队列系统802内的不同水平的传送队列的数据流量。例如,该目的地控制模块850可以被配置为限定以第一级队列810 (其逻辑地嵌套在第二级队列820的外面)中的特定传送队列为目标的流量控制信号。第一级队列810中的特定传送队列可以与特定的虚拟机或者网络设备有关。可以基于例如与特定的传送队列有关的状态值,和/或与从特定的传送队列接收数据的接收队列有关的状态值限定以特定传送队列为目标的该流量控制信号,使得以特定的方式为特定的传送队列实现流量控制。在上述的例子中,可以在不影响来自第一级队列810中的其它的传送队列并扇入例如第二级队列820中的传送队列的数据流的情况下,流量控制信号可触发中止来自第一级队列810的特定传送队列的数据传输。总之,以第一级队列810中的特定传送队列为目标的该流量控制信号可以触发比当该流量控制信号目标是第二级队列820中的一个或多个传送队列时可以实现的更多粒状数据流量控制。
[0139]如图8所示,该状态数据库856可以存储在目的地控制模块850的存储器854中。在一些实施例中,该状态数据库856 (或者状态数据库856的一部分)可以存储在存储器(未示出)中,该存储器不是目的地控制模块850本地的(例如,远程存储器)。
[0140]在一些实施例中,由目的地控制模块850基于存储在状态数据库856中的状态值限定的流量控制信号可以包括速率值和/或中止时间值(还可以称为中止时间段参数值)。该中止时间值可以限定中止时间段,在此期间传送队列应当中止数据传输。在一些实施例中,该中止时间值可以指定例如几百毫秒的中止时间段。该速率值可以限定传送队列应当从传送队列传送数据的速率(例如,位速率、字节速率、平均位速率)。在一些实施例中,该速率值可以指定例如数百千位/秒的速率。
[0141]例如,如果接收队列FDp不可用于处理在传送队列FA1上排队的数据(例如,数据分组流),并且寻址到接收队列FDP,该目的地控制模块850可以被配置为将与流量控制环路有关的流量控制信号发送给信源控制模块830,该流量控制信号可以被配置为基于包括在流量控制信号中的中止时间值,在中止时间段内触发中止从传送队列FA1到接收队列FDp的数据传输。目的地控制模块850可以基于包括在状态数据库856中的一个或多个状态值限定该中止时间段参数值。在一些实施例中,传送队列FA1可以被称为流量控制信号的目标。换句话说,该流量控制信号可以以(例如,寻址到)传送队列FA1S目标。在一些实施例中,可以基于与传送队列FA1有关的队列标识符在流量控制信号内识别该传送队列FA115
[0142]在一些实施例中,速率值和中止时间值两者可以以单个传送队列为目标(基于队列标识符)。在这个例子中,速率值和中止时间值两者可以包括在单个流量控制帧中,诸如结合图4所描述的那样。在上述的例子中,以传送队列为目标的速率值和/或中止时间值可以包括在一个以上的流量控制帧中。
[0143]在一些实施例中,该目的地控制模块850可以被配置为基于例如一个或多个规则(未示出)限定流量控制信号。可以使用算法(例如,程序)实现该规则。在一些实施例中,可以基于一个或多个阈值条件限定该规则。虽然未示出,但在一些实施例中,规则(例如,实现该规则的算法)可以存储在存储器854中,并且当限定流量控制信号的时候,由目的地控制模块850进行检索。
[0144]由目的地控制模块850用来限定流量控制信号的状态值可以是代表与多级队列系统802有关的各种单元的状态的值。例如,状态值可以代表在物理链路800的接收侧上的队列(例如,第一级队列810中的队列、第二级队列820中的队列)的状态。代表接收队列的状态值可以称为接收队列状态值。结合图9A描述了与可以存储在状态数据库856中的接收队列状态值相关的更多细节。在一些实施例中,状态值可以代表在物理链路800的接收侧上的队列(例如,第一级队列810中的队列、第二级队列820中的队列)的状态。代表传送队列的状态值可以称为传送队列状态值。结合图9B描述了与可以存储在状态数据库856中的传送队列状态值的相关的更多细节。在一些实施例中,除了特定的队列(例如,特定的传送队列、特定的接收队列)以外,状态值可以代表与多级队列系统802相关的单元的状态。这些类型的状态值可以称为系统状态值。例如,系统状态值可以代表反馈路径的状态、物理链路800的状态,和/或多级队列系统802的传输路径(或者传播路径的集合)的状态。图结合9C描述了与可以存储在状态数据库856中的系统状态值相关的更多的细节。
[0145]在一些实施例中,可以基于散列(hash)值检索和/或修改包括在状态数据库856中的状态值。例如,与队列(例如,传送队列、接收队列)有关的状态值可以存储在使用代表该队列的标识符的散列值识别的存储位置中(例如,该状态数据库856的存储位置)。可以基于使用代表该队列的标识符的散列查找在存储位置上稍后更新与该队列有关的状态值。
[0146]在一些实施例中,该目的地控制模块850可以被配置为基于优先级存储状态值。例如,与传送队列有关的优先级可以表示仅仅某些类型的状态值应当存储用于该传送队列。该目的地控制模块850可以被配置为基于这个优先级存储用于该传送队列的状态值。类似地,与接收队列(或者多级队列系统802的另一部分)有关的优选级可以表示仅仅某些类型的状态值应当存储用于该接收队列(或者多级队列系统802的另一部分)。该目的地控制模块850可以被配置为基于这个优先级存储用于该接收队列(或者多级队列系统802的另一部分)的状态值。
[0147]图9A是按照一个实施例表明接收队列状态数据库905的示意图。该接收队列状态数据库905可以限定状态数据库的一部分,诸如在图8中示出的状态数据库856。该接收队列状态数据库905包括与接收队列标识符(在列910中不出)有关的接收队列状态值(在列920中示出),该接收队列标识符代表接收队列(诸如,在图8中示出的接收队列)。例如,该接收队列状态值RV51与由接收队列标识符RQ12 (也可以称为接收队列RQ12)代表的接收队列有关。在一些实施例中,例如,该接收队列状态值RV51可以代表接收队列RQ12处于不拥塞的状态并且可以用来接收数据,可以代表接收队列RQ12处于拥塞的状态并且不可用于接收数据,可以代表经指定的一段时间后接收队列RQ12的平均流失速率,可以代表接收队列RQ12的使用百分比(例如,接收队列RQ12被使用的百分比),和/或其他。虽然未示出,但在一些实施例中,多个接收队列状态值可以与单个接收队列有关,或者多个接收队列可以与单个接收队列状态值有关。
[0148]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为在仅仅与拥塞的接收队列有关的接收队列状态数据库905中存储状态值。例如,该目的地控制模块可以被配置为仅仅存储与例如不可用于从一个或多个传送队列接收数据的接收队列有关的状态值。在一些实施例中,该目的地控制模块可以被配置为仅仅存储与例如具有超过指定阈值的使用百分比的接收队列有关的状态值。
[0149]在一些实施例中,可以由目的地控制模块更新该接收队列状态数据库905。例如,如果接收队列的使用百分比改变,则可以在接收队列状态数据库905内更新代表接收队列的使用百分比的接收队列状态值。在一些实施例中,响应于在接收队列状态数据库905内代表的接收队列上接收的数据,和/或其他,周期性地、随机地更新在接收队列状态数据库905内的条目。
[0150]在一些实施例中,当与接收队列有关的接收队列状态值以特定的方式改变的时候,可以从接收队列状态数据库905中除去与接收队列有关的条目(例如,行)(或者条目的一部分)。例如,当接收队列RQl例如不再拥塞的时候,可以从接收队列状态数据库905中除去与接收队列RQl (在列910中示出)有关的状态值RV2(在列920中示出)。
[0151]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为基于例如存储在接收队列状态数据库905中的一个或多个接收队列状态值,并且基于一个或多个规则(未示出)限定流量控制信号。例如,目的地控制模块可以被配置为限定流量控制信号,该流量控制信号配置为基于接收队列RQl的使用百分比和接收队列RQl的流失速率触发传送队列(其是流量控制信号的目标),以在中止时间段内中止数据传输到接收队列RQl (在列910中示出)。在一些实施例中,可以限定该规则,使得当接收队列RQl的使用百分比超出阈值相对很大的余量和/或接收队列RQl的流失速率相对缓慢的时候,目的地控制模块将限定相对长的中止时间段。还可以限定该规则,使得当接收队列RQl的使用百分比超出阈值相对小的余量和/或接收队列RQl的流失速率相对快速的时候,目的地控制模块将限定相对短的中止时间段。
[0152]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为基于例如存储在接收队列状态数据库905中的接收队列状态值中的变化,限定寻址到单个传送队列的多个流量控制信号。例如,响应于从传送队列接收并促使接收队列从不拥塞的状态改变到拥塞的状态的分组,可以在第一时间将与接收队列有关的接收队列状态值存储在接收队列状态数据库905中。接收队列状态值可以代表接收队列处于拥塞的状态。目的地控制模块可以被配置为基于与接收队列有关的接收队列状态值,限定第一流量控制信号,该第一流量控制信号配置为基于第一中止时间值在中止时间段内触发传送队列中止传输附加的分组到接收队列。在中止时间段结束之前,如果接收队列从拥塞的状态改变到不拥塞的状态,则该目的地控制模块可以发送第二流量控制信号,该第二流量控制信号包括第二中止时间值,第二中止时间值短于中止时间段的剩余时间(并且短于第一中止时间值),使得整个中止时间段比最初由第一中止时间值限定的短。
[0153]在一些实施例中,目的地控制模块可以被配置为解决(或者防止潜在的)与多个接收队列有关的流量控制信令冲突。具体地,目的地控制模块可以被配置为发送流量控制信号给接收队列,使得实现一组接收队列所期望的流量控制。例如,接收队列状态值RV2和接收队列状态值RV51可以分别地代表该接收队列RQl和接收队列RQ12处于拥塞的状态。可以由从单个传送队列发送的分组引起该接收队列RQl和接收队列RQ12的拥塞状态。该目的地控制模块可以限定流量控制信号(或者流量控制信号的集合),其将满足接收队列RQl和接收队列RQ12两者的需要,而不是为例如具有不同的和冲突的中止时间值的每个接收队列RQl和接收队列RQ12限定和发送多个独立的流量控制信号。具体地,该目的地控制模块可以限定和发送流量控制信号,该流量控制信号将触发传送队列在将允许接收队列RQl和接收队列RQ12两者接收来自传送队列的附加分组之前返回到不拥塞的状态的单个中止时间段内中止数据传输给接收队列RQl和接收队列RQ12两者。在这种例子中,除非接收队列RQl和接收队列RQ12两者准备(例如,可用于)从传送队列接收数据,目的地控制模块可以基于随后的流量控制信号来防止中止时间段被减小(响应于例如独立地转变为不拥塞的状态的接收队列RQl或者接收队列RQ12)。
[0154]在一些实施例中,例如,接收队列状态值RV2和接收队列状态值RV51可以分别地代表该接收队列RQl和接收队列RQ12处于拥塞的状态。可以由从单个传送队列发送的分组引起该接收队列RQl和接收队列RQ12的拥塞状态。目的地控制模块可以被配置为基于该接收队列状态值RV2确定在第一中止时间段内应当中止该传送队列,和基于该接收队列状态值RV51确定在第二中止时间段内(不同于第一时间段)应当中止该传送队列。该目的地控制模块可以被配置为基于大于或等于两个中止时间段中较长时间段的一个中止时间段来限定流量控制信号,以保证接收队列RQl和接收队列RQ12两者准备好将在一个中止时间段结束时从传送队列接收数据。
[0155]在一些实施例中,该目的地控制模块可以被配置为发送配置为延长中止时间段的流量控制信号,该中止时间段与传送队列有关。例如,第一接收队列和第二接收队列可以被配置为从传送队列接收数据。目的地控制模块可以被配置为限定配置为触发该传送队列在中止时间段内中止数据传输到第一接收队列的第一流量控制信号。可以限定该中止时间段的持续时间,使得在接收队列准备接收该数据之后,该传送队列将继续发送数据给该接收队列。在已经发送第一流量控制信号之后,该目的地控制模块可以被配置为基于与第二接收队列有关的接收队列状态值(和/或与传送队列有关的传送队列状态值),限定配置为触发延长中止时间段的第二流量控制信号。在这个例子中,可以延长该中止时间段,因为,直至第一接收队列准备好从该传送队列接收数据之后第二接收队列将不会准备从该传送队列接收数据。
[0156]图9B是按照一个实施例表明传送队列状态数据库925的示意图。该传送队列状态数据库925可以限定状态数据库的一部分,诸如在图8中示出的状态数据库856。该传送队列状态数据库925包括与传送队列标识符(在列930中示出)有关的传送队列状态值(在列940中示出),该传送队列标识符代表传送队列(诸如,在图8中示出的传送队列)。例如,该传送队列状态值TVB与由传送队列标识符TQl (也可以称为传送队列TQl)代表的传送队列有关。该传送队列状态值930可以响应于流量控制信号而代表传送队列940的状态。在一些实施例中,例如,传送队列状态值TVB可以代表在指定时间开始的指定时间段内已中止来自传送队列TQl的传输,可以代表自从在流量控制信号中接收到速率值以来,传送队列TQl已经发送了指定数目的字节值,和/或等等。虽然未示出,但在一些实施例中,多个传送队列状态值可以与单个传送队列有关,或者多个传送队列可以与单个传送队列状态值有关。
[0157]可以由目的地控制模块(例如,在物理链路的接收侧上)更新该传送队列状态数据库925。例如,在已经发送流量控制信号给传送队列之后,如果是从传送队列接收分组的,则可以在传送队列状态数据库925内更新代表自从发送流量控制信号以来接收的分组数目的传送队列状态值。在一些实施例中,响应于从传送队列状态数据库925内所代表的传送队列中接收的数据,和/或其他,周期性地、随机地更新在传送队列状态数据库925内的条目。在一些实施例中,在链路(例如,物理链路)的接收侧上的目的地控制模块可以被配置为基于从该链路的发送侧上的信源控制模块接收的信息,更新在传送队列状态数据库925中的条目。
[0158]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为基于例如存储在传送队列状态数据库925中的一个或多个传送队列状态值,和基于一个或多个规则(未示出)来限定流量控制信号。例如,该传送队列状态值TVA可以代表传送队列TQ2已经以特定的速率发送数据。如果该接收队列不能处理当前的传输速率,则目的地控制模块可以被配置为基于规则来限定流量控制信号,该流量控制信号配置为触发传送队列TQ2进一步降低到接收队列的数据传输速率。
[0159]在一些实施例中,目的地控制模块可以被配置为基于包括在传送队列状态数据库925中的状态值解决(或者防止潜在的)流量控制信令冲突。例如,包括在传送队列状态数据库925中的传送队列状态值TVA(不出在列940上)可以代表响应于流量控制信号已经中止传送队列TQ2直到时间Tl。该目的地控制模块可以基于传送队列状态值TVA来阻止发送(或者抑制限定)过早地结束中止传输的(例如,在时间Tl之前结束中止传输)第二流量控制信号。如果基于来自传送队列TQ2的数据流,响应于处于拥塞状态的单个接收队列发送流量控制信号,则目的地控制模块可以阻止发送在时间Tl之前过早地结束中止传输的附加的流量控制信号(除非该附加的流量控制信号与该一个接收队列有关)。如果基于来自传送队列TQ2的数据,响应于多个分别处于拥塞状态的接收队列发送该流量控制信号,则该目的地控制模块可以阻止发送在时间Tl之前过早地结束中止传输的附加的流量控制信号(除非该附加的流量控制信号与该多个接收队列有关)。在一些实施例中,该目的地控制模块可以限定将阻止限定和/或发送流量控制信号的非反馈指示符。
[0160]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为只为已向其发送流量控制信号的传送队列在传送状态数据库925中存储状态值。例如,只有在已经将寻址到传送队列的流量控制信号发送给传送队列的时候,该目的地控制模块可以被配置为为传送队列存储状态值。
[0161]在一些实施例中,当例如与传送队列有关的命令不再有效的时候,可以从传送队列状态数据库925中除去与传送队列有关的条目(例如,一行)(或者条目的一部分)。例如,当该中止时间段已经结束的时候,可以从传送队列状态数据库925中除去代表传送队列的中止时间段的持续时间的传送队列状态值。
[0162]图9C是按照一个实施例表明系统状态数据库955的示意图。该系统状态数据库955可以限定状态数据库的一部分,诸如在图8中示出的状态数据库856。该系统状态数据库955包括与系统标识符(在列950中示出)有关的系统状态值(在列960中示出),除了特定的队列(例如,特定的传送队列、特定的接收队列)以外,该系统标识符代表多级队列系统的一部分。例如,该系统状态值SVT可以与由系统标识符Sl(也可以称为系统SI)代表的一部分多级队列系统有关。多级队列系统的几部分例如可以是反馈路径(例如,与物理链路有关的反馈路径,诸如在图8中示出的物理链路800,带外反馈路径)、物理链路,和/或传输路径(或者传播路径的集合)。在一些实施例中,例如,系统状态值可以代表反馈路径(或者传输路径的百分比)不可用于传送流量控制信号,可以代表一部分多级队列系统的拥塞水平,该多级队列系统包括多个传送队列和多个接收队列,和/或等等。
[0163]可以由目的地控制模块(例如,在物理链路的接收侧上)更新该系统状态数据库955。例如,如果反馈路径从可用的状态改变到不可用的状态(或者反之亦然),则可以在系统状态数据库955内更新代表该改变的系统状态值。在一些实施例中,响应于从一个或多个传送队列接收和/或在一个或多个接收队列上接收的数据,和/或其他,周期性地、随机地更新系统状态数据库955内的项目。
[0164]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为基于例如存储在系统状态数据库955中的一个或多个系统状态值,和基于一个或多个规则(未示出)限定流量控制信号。例如,如果正如由包括在系统状态数据库955中的系统状态值代表的那样,反馈路径不可用,则目的地控制模块不会经由反馈路径发送一组流量控制信号。在一些实施例中,例如,如果在一部分多级队列系统内的总体拥塞超过包括在规则中的阈值条件,则目的地控制模块可以被配置为修改流量控制信号(例如,增加在流量控制信号内的中止时间值)。
[0165]在一些实施例中,目的地控制模块(诸如,在图8中示出的目的地控制模块850)可以被配置为只为多级队列系统的几部分在系统状态数据库955中存储状态值。例如,只有在该反馈路径拥塞的时候,该目的地控制模块可以被配置为为反馈路径存储状态值。
[0166]在一些实施例中,可以从该系统状态数据库955中除去与一部分多级队列系统有关的条目(例如,行)(或者条目的一部分)。例如,当反馈路径例如不再拥塞的时候,可以从系统状态数据库955中除去与反馈路径有关的状态值(或者整个条目)。[0167]回到参考图8,在一些实施例中,该状态数据库856可以包括接收队列状态值、传送队列状态值和/或系统状态值。例如,在一些实施例中,该状态数据库856可以包括接收队列数据库(诸如,在图9A中示出的)和传送队列数据库(诸如,在图9B中示出的),但是可能不包括系统状态数据库(诸如,在图9C中示出的)。在上述的实施例中,基于接收队列状态值和/或传送队列状态值,而不是基于系统状态值,该目的地控制模块850可限定一个或多个流量控制信号,因为系统状态值是不可利用的。
[0168]在一些实施例中,该信源控制模块840可以被配置为处理(例如,解码)从目的地控制模块850发送的一个或多个流量控制信号。例如,该信源控制模块840可以被配置为在流量控制信号中接收一个指令,并且可以被配置为基于该命令修改从传送队列传送的数据。在一些实施例中,该信源控制模块840可以被配置为修改包括在流量控制信号中的指令,并且可以被配置为执行该修改的指令。例如,该信源控制模块840可以接收包括以特定传送队列为目标的1000毫秒的中止时间值的流量控制信号。该信源控制模块840可以被配置为基于物理链路800的发送侧上的处理资源的不可用性,触发在比1000毫秒更长的一段时间内中止来自传送队列的数据传输。
[0169]在一些实施例中,该信源控制模块840可以被配置为基于包括在流量控制信号中的速率值和中止时间值的组合,触发修改来自传送队列的数据传输。例如,该信源控制模块840可以被配置为按脉冲或者在时间分段内从传送队列传送数据。可以基于速率值和中止时间值的组合计算脉冲。
[0170]在一些实施例中,该信源控制模块840可以被配置为基于包括在队列优选数据库846中的流量控制优先级来处理流量控制信号。例如,该信源控制模块840可以被配置为忽略从目的地控制模块850发送的一个或多个流量控制信号(或者一部分流量控制信号)。该信源控制模块840可以被配置为基于包括在队列优先级数据库846中的条目而忽略流量控制信号(或者一部分流量控制信号)。例如,目的地控制模块850可以被配置为基于包括在状态数据库856中的状态值(例如,与传送队列FAn有关的状态值)来限定以传送队列FAn为目标的中止时间值和速率值(在队列810的第一级内)。该信源控制模块840可以被配置为忽略以传送队列FAn为目标的中止时间值,因为传送队列FAn没有被配置为基于中止时间值中止传输。作为代替,该信源控制模块840可以基于该速率值修改来自传送队列FAn的数据流。
[0171]在一些实施例中,信源控制模块840可以被配置为将与传送队列有关的一个或多个流量控制优先级发送给目的地控制模块850。该目的地控制模块850可以使用流量控制优先级去限定一个或多个流量控制信号。例如,该信源控制模块840可以发送一个指示符给目的地控制模块850,该指示符指示传送队列FA1配置为基于速率值修改(来自传送队列FA1)数据的流量,而不是配置为基于中止时间值修改数据的流量。因此,目的地控制模块850可以被配置为限定以仅包括速率值而不包括中止时间值的传送队列FA1为目标的流量控制信号。
[0172]虽然未示出,在但一些实施例中,可以在与多级队列系统802有关的流量控制环路内执行其他类型的流量控制算法。例如,在一些实施例中,除了在此处描述的那些之外,可以执行随机早期丢弃流量控制算法。
[0173]在一些实施例中,可以将传送队列(例如,传送队列FAn)的流量控制优先级从物理链路800的发送侧传送到物理链路800的接收侧。例如,从传送队列传送的数据分组可以包括传送队列的流量控制优先级的指示符(例如,在数据分组的包头中的指示符)。包括在该数据分组中的流量控制优先级可以由目的地控制模块850使用以限定一个或多个流量控制信号。在一些实施例中,该目的地控制模块850可以被配置为在例如存储器854中存储传送队列的流量控制优先级,供稍后使用。结合图10描述了一个队列优先级数据库的例子。
[0174]图10是按照一个实施例表明队列优先级数据库1000的示意图。如图10所示,该队列优选数据库1000包括与传送队列标识符(在列1010中示出)有关的流量控制优先级(在列1020中示出)。例如,与中止流量控制(在列1020中示出)的流量控制优先级有关的传送队列Ql (在列1010中示出)。传送队列Q3(在列1010中示出)与没有反馈控制(在列102Q中示出)的流量控制优先级有关,因为传送队列Q3不是流量可控的传送队列。
[0175]图1lA是按照一个实施例表明配置为从传送队列接收数据的第一接收队列的可用容量的示意图。图1lB是按照一个实施例表明配置为从传送队列接收数据的第二接收队列的可用容量的示意图。图1lC是按照一个实施例表明与传送队列有关的反馈路径的可用容量的示意图。图1lD是按照一个实施例表明用于传输寻址到传送队列的流量控制信号的定时的示意图。可以在目的地控制模块上限定并发送该流量控制信号。如图1lA至图1lD所示,时间向右增加。
[0176]如图1lA所示,第一接收队列的可用容量响应于从传送队列(未示出)接收的数据随后在时间T2上降到阈值YV之下。因此,如图1lD所示,在时间T2上发送流量控制信号给传送队列。该流量控制信号被配置为触发在中止时间段内中止来自传送队列的传输,直至时间T9为止。可以经由反馈路径发送在时间T2上发送的流量控制信号。
[0177]如图1lA所示,第一接收队列的可用容量响应于从第一接收队列传送(例如,从中流失)的数据在时间T4上提高到阈值YV之上。在时间T4上不将流量控制信号发送给传送队列(如由图1lD表明的),因为该反馈路径在时间T4上不可用于流量控制信号的传输(在图1lC中示出)。如果该反馈路径可用于传输,则可以在时间T4上发送流量控制信号以触发减少传送队列的中止时间段。
[0178]如图1lA所示,第一接收队列的可用容量响应于从第一接收队列传送(例如,从中流失)的数据在时间T7上提高到阈值YV之上。在时间T7上(如由图1lD表明的)不将流量控制信号发送给传送队列,因为预定从该传送队列接收数据的第二接收队列不可用于从时间T5(在图1lB中示出)开始接收来自传送队列的数据,因为第二接收队列的可用容量低于该阈值ZV。如图1lD所示,在时间Τ8上发送流量控制信号,以在时间T9之后响应于第二接收队列的不可用性来触发增加传送队列的中止时间段的持续时间。
[0179]图12是按照一个实施例表明用于限定流量控制信号的方法的流程图。如图12所示,在1200上,在限定接收队列的存储器上接收分组。在一些实施例中,接收队列可以与逻辑地嵌套在第二级队列外面的第一级队列有关。第二级队列可以逻辑地嵌套在物理链路的外面。
[0180]在1210上,响应于该分组限定代表接收队列的状态的接收队列状态值。在一些实施例中,接收队列的状态可以存储在状态数据库中。接收队列状态值例如可以代表接收队列的拥塞水平。[0181]在1220上,可以基于包括在分组中的标识符更新代表传送队列状态的传送队列状态值。在一些实施例中,该标识符可以代表该分组是从传送队列接收的。因此,该标识符可用于更新与传送队列有关的传送队列状态值。在一些实施例中,该传送队列状态值可以代表在接收队列上自从响应于从不拥塞状态改变到拥塞状态的接收队列而将流量控制信号发送给该传送队列以来接收的许多字节。
[0182]在1230上,接收代表系统状态的系统状态值。系统状态值可以代表与传送队列和接收队列有关的反馈路径的容量。
[0183]在1240上,寻址到传送队列的流量控制信号可以基于接收队列状态值、传送队列状态值和/或系统状态值限定。在已经限定该流量控制信号之后,可以将该流量控制信号发送给配置为基于该流量控制信号触发修改来自传送队列的数据流的信源控制模块。在一些实施例中,流量控制信号可以包括速率值和中止时间值。可以基于包括在流量控制信号中的速率值和/或中止时间值修改来自传送队列的数据流。
[0184]在此处描述的某些实施例涉及具有计算机可读介质(也可以称为处理器可读介质)的计算机存储产品,在计算机可读介质上具有用于执行各种各样计算机可执行操作的命令或者计算机代码。可以为了特定的目的设计和构造介质和计算机代码(也可以称为代码)。计算机可读介质的例子包括但是不局限于:磁存储介质,诸如硬盘、软盘和磁带;光存储介质,诸如光盘/数字视频光盘(CD / DVD)、光盘只读存储器(CD-ROM)和全息照相设备;磁光盘存储介质,诸如光盘;载波信号处理模块;和特别配置为存储和执行程序代码的硬件设备,诸如专用集成电路(ASIC)、可编程序逻辑设备(PLD)和只读存储器(ROM)和随机存取存储器(RAM)设备。
[0185]计算机代码的例子包括但是不局限于,微代码或者微指令、诸如由编译器产生的机器指令,用于产生网络服务的代码,和包含高级指令的文件,该高级指令是由计算机使用翻译器执行的。例如,可以使用Java、C++或者其它的编程语言(例如,面向对象的程序设计语言)和开发工具执行多个实施例。计算机代码的附加例子包括但是不局限于,控制信号、加密的代码和压缩的代码。
[0186]虽然上文已经描述了各种各样的实施例,但应该明白,它们仅仅通过举例的方式给出,并非限制,并且可以在形式和细节方面进行各种变化。除了互相排斥的组合之外,可以以任何组合方式组合在此处描述的装置和/或方法的任何部分。在此处描述的实施例可以包括所描述的不同实施例的功能、部件和/或特征的各种组合和/或子组合。例如,信源实体和/或目的地实体可以具有跨越物理链路的多于两个流量可控队列级的队列级。
【权利要求】
1.一种被实施在存储器或者处理设备中的至少一个中的装置,所述装置包括: 第一流量控制模块,被配置为基于第一流量控制环路内的数据流来发送第一流量控制信号,所述第一流量控制回路包括(1)扇入第二级传送队列中的第一级传送队列、(2)扇入物理链路的所述第二级传送队列以及(3)所述物理链路;以及 第二流量控制模块,被配置为基于第二流量控制环路内的数据流来限定第二流量控制信号,所述第二流量控制环路包括(1)所述第二级传送队列和(2)所述物理链路,并且所述第二流量控制环路不包括所述第一级传送队列。
2.根据权利要求1所述的装置,还包括: 第三流量控制模块,被配置为基于与第三流量控制环路相关联的数据流来限定第三流量控制信号,所述第三流量控制环路包括所述物理链路并且不包括所述第一级传送链路和所述第二级传送链路。
3.根据权利要求1所述的装置,其中所述第二流量控制环路是基于优先级的流量控制环路。
4.根据权利要求1所述的装置,其中所述第一级传送队列包括在第一接口卡处的传送队列和在第二接口卡处的传送队列,在所述第一接口卡处的传送队列和在所述第二接口卡处的传送队列扇入在所述第二级传送队列中包括的传送队列。
5.根据权利要求1所述的装置,其中所述第一流量控制信号包括第2层流量控制分组,所述第一流量控制模块与第2层设备相关联。
6.根据权利要求1所述的装置,其中: 所述第一流量控制信号包括来自所述第一级传送队列的传送队列的标识符和与所述传送队列的标识符相关联的中止时间值, 所述中止时间值基于第一请求而中止在与所述第一级传送队列相关联的接收队列处的传输,并且基于第二请求而中止在所述接收队列处的传输。
7.根据权利要求1所述的装置,其中: 所述第一流量控制信号包括来自所述第一级传送队列的传送队列的标识符和与所述传送队列的标识符相关联的中止时间值, 所述中止时间值基于第一请求而中止在与所述第一级传输队列相关联的接收队列处的传输,并且基于第二请求而中止在所述接收队列处的传输,并且 所述中止时间是与所述第一请求相关联的时间段和与所述第二请求相关联的时间段的平均值。
8.根据权利要求1所述的装置,其中: 所述第一流量控制信号包括来自所述第一级传送队列的传送队列的标识符和与所述传送队列的标识符相关联的中止时间值, 所述中止时间值基于第一请求而中止在与所述第一级传送队列相关联的接收队列处的传输,并且基于第二请求而中止在所述接收队列处的传输,并且 当与所述第一请求相关联的时间段大于与所述第二请求相关联的时间段时,所述中止时间值是与所述第一请求相关联的时间段。
9.根据权利要求1所述的装置,其中: 所述第一流量控制信号包括来自所述第一级传送队列的传送队列的标识符和与所述传送队列的标识符相关联的中止时间值, 所述中止时间值基于第一请求而中止在与所述第一级传送队列相关联的接收队列处的传输,并且基于第二请求而中止在所述接收队列处的传输,并且 所述第一流量控制模块被配置为将限定所述第一流量控制信号延迟等待时间段,所述第一请求和所述第二请求在所述等待时间段内被接收。
10.根据权利要求1所述的装置,其中所述第二流量控制模块被配置为发送所述第二流量控制信号,使得来自所述第二级传送队列的传送队列响应于所述第二流量控制信号而中止传输。
11.根据权利要求1所述的装置,其中: 所述第一流量控制环路包括(I)扇入第二级接收队列中的第一级接收队列、(2)扇入所述物理链路中的所述第二级接收队列, 所述第二流量控制环路包括所述第二级接收队列并且不包括所述第一级接收队列。
12.—种方法,包括: 基于接收队列在第一时间的拥塞状态,来限定用于第一级传送队列的第一流量控制信号; 当所述接收队列在所述第一时间处于所述拥塞状态时,向所述第一级传送队列发送所述第一流量控制信号; 基于所述接收队列在第二时间的所述拥塞状态,来限定用于与所述第一级传送队列不同的第二级传送队列的第二流量控制信号;以及 当所述接收队列在所述第二时间处于所述拥塞状态时,向所述第二级传送队列发送所述第二流量控制信号,所述第一级传送队列包括被扇入在所述第二级传送队列中包括的队列中的第一多个传送队列。
13.根据权利要求12所述的方法,其中所述第二级传送队列包括被扇入物理链路中的多个传送队列,所述物理链路不同于所述第二级传送队列和所述第一级传送队列。
14.根据权利要求12所述的方法,其中来自所述第一多个传送队列的至少一个传送队列在第一接口卡处,来自所述第一多个传送队列的至少一个传送队列在第二接口卡处。
15.根据权利要求12所述的方法,其中所述第二时间不同于所述第一时间。
16.根据权利要求12所述的方法,其中所述第一时间对应于所述第二时间。
17.根据权利要求12所述的方法,其中响应于所述接收队列在所述第一时间之前从可用的状态改变到所述拥塞状态而触发发送所述第一流量控制信号,响应于所述接收队列在所述第二时间之前从可用的状态改变到所述拥塞状态而触发发送所述第二流量控制信号。
18.一种装置,包括 第一级传送队列,包括在第一接口卡处的传送队列和在第二接口卡处的传送队列; 第二级传送队列,在所述第一接口卡处的所述传送队列和在所述第二接口卡处的所述传送队列被扇入在所述第二级传送队列中包括的传送队列;以及 控制模块,被配置为当接收到第一流量控制信号时修改用于所述第一级传送队列的流量控制,所述第一流量控制信号与第一流量控制环路相关联,所述第一流量控制环路包括所述第一级传送队列和所述第二级传送队列, 所述控制模块被配置为当接收到第二流量控制信号时修改用于所述第二级传送队列的流量控制,所述第二流量控制信号与第二流量控制环路相关联,所述第二流量控制环路包括所述第二级传送队列并且不包括所述第一级传送队列。
19.根据权利要求18所述的装置,其中所述第二级传送队列包括被扇入物理链路中的多个传送队列,所述第一流量控制环路和所述第二流量控制环路分别包括所述物理链路。
20.根据权利要求18所述的装置,其中所述第二级传送队列包括被扇入所述物理链路中的多个传送队列,所述控制模块被配置为当接收到第三流量控制信号时修改用于所述物理链路的流量控制,所述第三流量控制信号与第三流量控制环路相关联,所述第三流量控制环路包括所述物理链路并且不包括所述第一级传送队列和所述第二级传送队列。
21.根据权利要求18所述的装置,其中所述流量控制信号基于第2层协议。
22.—种方法,包括: 限定中止时间值,所述中止时间值代表用于中止第一级队列的发送侧内的队列与所述第一级队列的接收侧内的队列之间的数据传输的时间段;以及 从在物理链路的接收侧上的流量控制模块向在所述物理链路的所述发送侧上的流量控制模块发送流量控制信号,所述流量控制信号被配置为基于所述中止时间值而中止从在所述第一级队列的所述发送侧内的队列的数据传输,所述流量控制信号与第一控制环路相关联并且不与所述第二流量控制环路相关联,所述第一控制环路包括所述第一级队列、第二级队列和所述物理链路,所述第二控制环路包括所述第二级队列和所述物理链路并且不包括所述第一级队列。
23.根据权利要求22所述的方法,其中所述第二流量控制环路是基于优先级的流量控制环路。
24.根据权利要 求22所述的方法,其中所述物理链路被包括在第三流量控制环路中,所述第三流量控制环路不同于所述第一流量控制环路和所述第二流量控制环路。
25.根据权利要求22所述的方法,其中所述数据在所述第一级队列的所述发送侧内的队列处排队,中止传输的所述请求包括与所述第一级队列的所述发送侧内的队列相关联的标识符。
26.根据权利要求22所述的方法,其中在所述第一级队列的所述发送侧内的队列是虚拟的队列,所述流量控制信号包括与所述虚拟的队列相关联的标识符。
27.根据权利要求22所述的方法,其中所述流量控制信号是第一流量控制信号,所述数据是第一数据,所述方法还包括: 存储所述第一流量控制信号的标识符; 在所述流量控制模块处接收请求,以中止在所述第一级队列的所述发送侧内的队列处排队的第二数据的至少一部分的传输;以及 基于所述中止时间值和所述第一流量控制信号的标识符来确定不发送第二流量控制信号。
28.—种处理器可读的非瞬态介质,所述非瞬态介质存储代码,所述代码代表用于使处理器执行处理的指令,所述代码包括用于执行以下步骤的代码: 从物理链路的接收侧接收响应于第一数据分组在接收队列处被接收而限定的第一流量控制信号,所述数据分组包括在所述物理链路的发送侧上设置的传送队列的标识符,所述流量控制信号包括与所述 传送队列相关联的标识符和与所述传送队列的所述标识符相关联的第一中止时间值; 从所述物理链路的所述接收侧接收第二流量控制信号,所述第二流量控制信号包括与所述传送队列的所述标识符相关联的第二中止时间值;以及 基于所述第一中止时间值和所述第二中止时间值而中止在所述传送队列处的第二数据分组的传输持续第二中止时间段。
29.根据权利要求28所述的处理器可读的非瞬态介质,其中设置在所述物理链路的所述发送侧上的所述传送队列是虚拟队列,所述流量控制信号包括与所述虚拟队列相关联的标识符。
30.根据权利要求28所述的处理器可读的非瞬态介质,其中所述传送队列和所述接收队列被包括在第一级队列中,第二级队列与所述第一级队列相互不包括,并且被设置在所述传送队列和所述接收队列之间。
31.根据权利要求28所述的处理器可读的非瞬态介质,其中所述传送队列和所述接收队列被包括在第一级队列中,流量控制优先级被包括在与被包括在第二级队列中的成对的队列相关联的第一多个流量控制优先级中,所述第一级队列与不同于所述第一多个流量控制优先级的第二多个流量控制优先级相关联。
32.根据权利要求28所述的处理器可读的非瞬态介质,其中所述传送队列被包括在被扇入来自多个队列的队列中的多个传送队列中,所述第一流量控制信号和所述第二流量控制信号被配置为触发中止来自少于被包括在所述多个传送队列中的所有传送队列的数据传输。
33.一种方法,包括: 接收第一请求以中止在被包括在第一级队列中的传送队列处排队的第一数据的传送,所述第一请求与基于第一接收队列的可用性而限定的所述第一数据相关联,所述第一接收队列被包括在第一级队列中,所述第一数据被排队以用于经由传输路径的传输,所述传输路径包括被包括在第二级队列中的传送队列,所述第二级队列被设置在被包括在所述第一级队列中的所述传送队列与被包括在所述第一级队列中的所述第一接收队列之间; 接收第二请求以中止在所述第一级队列中的所述传送队列处排队的第二数据的传输,所述第二请求与基于被包括在所述第一级队列中的第二接收队列的可用性而限定的所述第二数据相关联;以及 基于所述第一请求并且基于所述第二请求发送流量控制信号,所述流量控制信号被配置为触发中止所述第一数据和所述第二数据中的至少一个的传输,使得经由被包括在所述第二级中的所述传送队列的数据流被修改。
34.根据权利要求33所述的方法,其中所述限定包括:基于所述第一请求并且基于所述第二请求,来限定用于被包括在所述第一级队列中的所述传送队列的中止时间值。
35.根据权利要求33所述的方法,其中所述限定包括:限定中止时间值,所述中止时间值基于第2层协议被编码在所述流量控制信号中。
36.根据权利要求33所述的方法,其中所述第一请求包括第一中止时间值,所述第二请求包括与所述第一中止时间值 不同的第二中止时间值,所述限定响应于条件被满足而被执行,所述条件与所述第一中止时间值和所述第二中止时间值的比较相关联。
37.根据权利要求33所述的方法,其中所述第二级队列是流量可控级队列,所述物理链路是流量可控的链路。
38.根据权利要求33所述的方法,其中被包括在所述第一级队列中的所述第一传送队列被包括在多个传送队列中,所述多个传送队列被包括在所述第一级队列中,被包括在所述第一级队列中的所述多个传送队列扇入被包括在所述第二级队列中的所述传送队列中。
39.根据权利要求33所述的方法,其中所述流量控制信号包括中止时间值,所述中止时间值是与所述第一请求相关联的时间段和与所述第二请求相关联的时间段的平均值。
40.根据权利要求33所述的方法,所述流量控制信号包括中止时间值,当与所述第一请求相关联的时间段大于与所述第二请求相关联的时间段时,所述中止时间值是与所述第一请求相关联的时间段。
41.根据权利要求33所述的方法,其中所述限定被延迟等待时间段,所述接收所述第一请求和所述接收所述第二请求在所述等待时间段内。
42.—种方法,包括: 接收第一请求以中止在第一级队列处排队的第一数据的传输,所述请求与基于被包括在所述第一级队列中的第一接收队列的可用性而限定的所述第一数据相关联,所述第一数据针对被排队以用于经由传输路径的传输,所述传输路径包括物理链路和被设置在所述物理路径和所述第一级队列之间的所述传输路径内的第二级队列的一部分; 接收第二请求以中止在所述第一级队列处排队的第二数据的传输,所述请求与基于被包括在所述第一级队列中的第二接收队列的可用性而限定的所述第二数据相关联,所述第二数据被排队以用于经由所述传输路径传输;以及 基于所述第一请求并且基 于所述第二请求限定流量控制信号。
43.根据权利要求42所述的方法,其中所述第二级队列的一部分包括传送队列,所述流量控制信号被配置为触发中止所述第一数据和所述第二数据中的至少一个的传输,使得经由被包括在所述第二级中的所述传送队列的数据流被修改.
44.根据权利要求42所述的方法,其中所述第一数据在被包括在所述第一级队列中的传送队列处被排队,所述第二数据在所述传送队列处被排队,所述限定包括:基于所述第一请求并且基于所述第二请求,来限定用于所述传送队列的中止时间值。
45.根据权利要求42所述的方法,其中所述限定包括:限定中止时间值,所述中止时间值基于第2层协议被编码在所述流量控制信号中。
46.根据权利要求42所述的方法,其中所述第一请求包括第一中止时间值,所述第二请求包括与所述第一中止时间值不同的第二中止时间值,所述限定响应于条件被满足而被执行,其中所述条件与所述第一中止时间值和所述第二中止时间值的比较相关联。
47.根据权利要求42所述的方法,其中所述第二级队列是流量可控级队列,所述物理链路是流量可控的链路。
【文档编号】H04L12/863GK103888368SQ201410137084
【公开日】2014年6月25日 申请日期:2009年9月11日 优先权日:2008年9月11日
【发明者】A·戈德博尔, A·巴苏, J-M·弗爱龙, A·S·贾大夫, N·贾因, P·辛德胡 申请人:瞻博网络公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1