一种报文处理方法及装置转让专利

申请号 : CN202110345275.9

文献号 : CN113098785B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 吕磊

申请人 : 新华三信息安全技术有限公司

摘要 :

本申请提供一种报文处理方法及装置,该方法应用于框式交换设备中任一接口板中的任一Qos调度芯片,该方法包括:针对本地的任一VOQ,若接收到该VOQ对应的OQ所在的接口板发送的第一流控帧、且第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;按照确定出的发送速率发送该VOQ中缓存的数据报文;其中,该VOQ对应的OQ对应有多个VOQ,且多个VOQ所在的Qos调度芯片不完全相同。本申请可以在一定程度上减少网板侧的流量突发,进而降低了框式交换设备的负载。

权利要求 :

1.一种报文处理方法,其特征在于,所述方法应用于框式交换设备中任一接口板中的任一服务质量Qos调度芯片,所述方法包括:针对本地的任一虚拟出端口队列VOQ,若接收到该VOQ对应的出端口队列OQ所在的接口板发送的第一流控帧、且所述第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;

按照确定出的发送速率发送该VOQ中缓存的数据报文;

其中,该VOQ对应的OQ对应有多个VOQ,且所述多个VOQ所在的Qos调度芯片不完全相同;

在根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率之前,所述方法还包括:判断该Qos调度芯片是否使能了精细调速功能;

在判断结果为否时,执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;

在判断结果为是时,若所述第一流控帧为第1次或者第2次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;

若所述第一流控帧不为前两次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧中的任一流控帧,则获取上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第二流控帧时确定出的发送速率对应的第二发送速率索引值、和上上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第三流控帧时确定出的发送速率对应的第三发送速率索引值,并进一步判断所述第三发送速率索引值是否与所述第一发送速率索引值相同、以及所述第二发送速率索引值和所述第三发送速率索引值是否为相邻的发送速率索引值;

若是,则按照所述第一发送速率索引值对应的发送速率与所述第二发送速率索引值对应的发送之间的中间值发送该VOQ中缓存的数据报文;

否则,执行所述根据所述第一流控帧中携带的第一发送速率索引值,确定待发送该VOQ中缓存的数据报文的发送速率的步骤。

2.根据权利要求1所述的方法,其特征在于,所述方法还包括:

在所述第一流控帧为用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的流控帧时,则停止发送该VOQ中缓存的数据报文。

3.根据权利要求1所述的方法,其特征在于,通过以下方式确定待发送该VOQ中缓存的数据报文的发送速率:在所述第一发送速率索引值为设定的发送速率索引值时,将最大发送速率确定为待发送该VOQ中缓存的数据报文的发送速率;

在所述第一发送速率索引值不为设定的发送速率索引值时,在预设的发送速率索引值与发送速率的第一对应关系中,查找所述第一发送速率索引值对应的发送速率,并将查找到的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率,其中,所述最大发送速率大于所述第一对应关系中的任一发送速率;或者,比较所述第一发送速率索引值、和根据预设的第一数量区间与发送速率的第二对应关系和所述第一对应关系查找到的该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值的大小;

在比较结果为相等时,将比较结果中的任一发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率;

在比较结果为不相等时,将比较结果中的最小的发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率。

4.根据权利要求3所述的方法,其特征在于,通过以下方式查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值:在所述第二对应关系中,查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率;

在所述第一对应关系中,进一步查找查找到的发送速率对应的发送速率索引值。

5.根据权利要求3所述的方法,其特征在于,在接收到所述第一流控帧之前,所述方法还包括:在该Qos调度芯片上电后,将该VOQ的状态设置为初始状态,并监测该VOQ中缓存的数据报文的数量;

在监测到的数量达到第一设定数量且未达到第二设定数量时,将该VOQ的状态由初始状态切换为慢启动状态,并在预设的第二数量区间与发送速率的第三对应关系中,查找监测到的数量所处的第二数量区间对应的发送速率,并按照查找到的发送速率发送该VOQ中缓存的数据报文,其中,所述第三对应关系中不同的第二数量区间对应不同的发送速率;

在监测到的数量达到所述第二设定数量时,将该VOQ的状态由慢启动状态切换为全速发包状态,并按照最大发送速率发送该VOQ中缓存的数据报文,其中,所述最大发送速率大于所述第三对应关系中的任一发送速率;

在按照最大发送速率发送该VOQ中缓存的数据报文后,若接收到所述OQ所在的接口板发送的用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的第四流控帧,则将该VOQ的状态由全速发包状态切换为关闭状态,并停止发送该VOQ中缓存的数据报文;

在接收到所述第一流控帧之后,所述方法还包括:

在所述第一发送速率索引值为设定的发送速率索引值时,将该VOQ的当前状态切换为全速发包状态,其中,该VOQ的当前状态为关闭状态或者调速状态;

在所述第一发送速率索引值不为设定的发送速率索引值时,若该VOQ的当前状态为调速状态,则维持该VOQ的当前状态不变;若该VOQ的当前状态为关闭状态或者全速发包状态,则将该VOQ的当前状态切换为调速状态。

6.一种报文处理装置,其特征在于,所述装置应用于框式交换设备中任一接口板中的任一服务质量Qos调度芯片,所述装置包括:确定模块,用于针对本地的任一虚拟出端口队列VOQ,若接收到该VOQ对应的出端口队列OQ所在的接口板发送的第一流控帧、且所述第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;

发送模块,用于按照确定出的发送速率发送该VOQ中缓存的数据报文;

其中,该VOQ对应的OQ对应有多个VOQ,且所述多个VOQ所在的Qos调度芯片不完全相同;

所述装置还包括:

判断模块,用于在所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤之前,判断该Qos调度芯片是否使能了精细调速功能;

在判断结果为否时,触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;

在判断结果为是时,若所述第一流控帧为第1次或者第2次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;

若所述第一流控帧不为前两次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧中的任一流控帧,则获取上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第二流控帧时确定出的发送速率对应的第二发送速率索引值、和上上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第三流控帧时确定出的发送速率对应的第三发送速率索引值,并进一步判断所述第三发送速率索引值是否与所述第一发送速率索引值相同、以及所述第二发送速率索引值和所述第三发送速率索引值是否为相邻的发送速率索引值;

若是,则按照所述第一发送速率索引值对应的发送速率与所述第二发送速率索引值对应的发送之间的中间值发送该VOQ中缓存的数据报文;

否则,触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值,确定待发送该VOQ中缓存的数据报文的发送速率的步骤。

7.根据权利要求6所述的装置,其特征在于,所述装置还包括:

停止发送模块,用于在所述第一流控帧为用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的流控帧时,则停止发送该VOQ中缓存的数据报文。

8.根据权利要求6所述的装置,其特征在于,所述确定模块,具体用于通过以下方式确定待发送该VOQ中缓存的数据报文的发送速率:在所述第一发送速率索引值为设定的发送速率索引值时,将最大发送速率确定为待发送该VOQ中缓存的数据报文的发送速率;

在所述第一发送速率索引值不为设定的发送速率索引值时,在预设的发送速率索引值与发送速率的第一对应关系中,查找所述第一发送速率索引值对应的发送速率,并将查找到的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率,其中,所述最大发送速率大于所述第一对应关系中的任一发送速率;或者,比较所述第一发送速率索引值、和根据预设的第一数量区间与发送速率的第二对应关系和所述第一对应关系查找到的该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值的大小;

在比较结果为相等时,将比较结果中的任一发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率;

在比较结果为不相等时,将比较结果中的最小的发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率。

9.根据权利要求8所述的装置,其特征在于,所述确定模块,具体用于通过以下方式查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值:在所述第二对应关系中,查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率;

在所述第一对应关系中,进一步查找查找到的发送速率对应的发送速率索引值。

10.根据权利要求8所述的装置,其特征在于,所述装置还包括:

监测模块,用于在所述确定模块接收到所述第一流控帧之前,在该Qos调度芯片上电后,将该VOQ的状态设置为初始状态,并监测该VOQ中缓存的数据报文的数量;

第一切换模块,用于在所述监测模块监测到的数量达到第一设定数量且未达到第二设定数量时,将该VOQ的状态由初始状态切换为慢启动状态,并在预设的第二数量区间与发送速率的第三对应关系中,查找监测到的数量所处的第二数量区间对应的发送速率,并按照查找到的发送速率发送该VOQ中缓存的数据报文,其中,所述第三对应关系中不同的第二数量区间对应不同的发送速率;

第二切换模块,用于在所述监测模块监测到的数量达到所述第二设定数量时,将该VOQ的状态由慢启动状态切换为全速发包状态,并按照最大发送速率发送该VOQ中缓存的数据报文,其中,所述最大发送速率大于所述第三对应关系中的任一发送速率;

第三切换模块,用于在所述第二切换模块按照最大发送速率发送该VOQ中缓存的数据报文后,若接收到所述OQ所在的接口板发送的用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的第四流控帧,则将该VOQ的状态由全速发包状态切换为关闭状态,并停止发送该VOQ中缓存的数据报文;

第四切换模块,用于在所述确定模块接收到所述第一流控帧之后,在所述第一发送速率索引值为设定的发送速率索引值时,将该VOQ的当前状态切换为全速发包状态,其中,该VOQ的当前状态为关闭状态或者调速状态;在所述第一发送速率索引值不为设定的发送速率索引值时,若该VOQ的当前状态为调速状态,则维持该VOQ的当前状态不变;若该VOQ的当前状态为关闭状态或者全速发包状态,则将该VOQ的当前状态切换为调速状态。

说明书 :

一种报文处理方法及装置

技术领域

[0001] 本申请涉及通信技术领域,尤其涉及一种报文处理方法及装置。

背景技术

[0002] 目前,为了提高框式交换设备处理数据报文的服务质量(Quality of Service,Qos),通常在框式交换设备的接口板中的Qos调度芯片(例如,交换网适配(Fabric Adapter,FAP)芯片等)上配置虚拟出端口队列(Virtual Output Queue,VOQ)和出端口队列(Output Queue,OQ)。
[0003] 具体地,如图1所示,假设框式交换设备包括4个接口板,分别为接口板1、接口板2、接口板3和接口板4。假设分别在接口板1和接口板2中的FAP芯片上为某个出端口配置1个VOQ,在接口板3中的FAP芯片上为该出端口配置2个VOQ,在接口板4中的FAP芯片上为该出端口配置一个OQ,事先为该OQ设置两个门限,分别为反压门限(也称为Xoff门限)和解除反压门限(也称为Xon门限)。在这种架构下,对于接口板1至接口板3中的任一接口板中的FAP芯片而言,在接收到该接口板中的网络处理芯片(例如,包处理芯片等)转发的出端口为该出端口的数据报文时,会将该数据报文缓存到对应的VOQ中;在根据预设的调度策略决策出需要转发该数据报文时,该接口板中的FAP芯片会将该数据报文通过根据网板选择策略从该框式交换设备中的多个网板中选择出的一个网板转发给接口板4中的FAP芯片。
[0004] 这样一来,对于接口板4中的FAP芯片而言,会在该出端口对应的OQ中缓存接口板1至接口板3中的FAP芯片转发过来的数据报文,一旦发现缓存的报文数量达到Xoff门限,接口板4中的FAP芯片会向接口板1至接口板3中的FAP芯片广播用于指示停止发送对应的VOQ中缓存的数据报文的流控帧。
[0005] 接口板1至接口板3中的FAP芯片在接收到此流控帧时,会停止发送该出端口对应的VOQ中缓存的数据报文的流控帧。
[0006] 后续随着接口板4上该出端口对应的OQ中的报文缓存数量逐渐减少,待报文缓存数量不高于Xon门限时,接口板4中的FAP芯片会再次向接口板1至接口板3中的FAP芯片广播用于指示继续发送对应的VOQ中缓存的数据报文的流控帧。
[0007] 接口板1至接口板3中的FAP芯片在接收到此次的流控帧时,会根据该调度策略,按照最大发送速率发送该出端口对应的VOQ中缓存的数据报文。
[0008] 可见,在框式交换设备处理数据报文的处理过程中,会存在以下问题:
[0009] 1、在多个接口板中的Qos调度芯片上均配置有同一出端口的VOQ的情形下,一旦这些Qos调度芯片接收到用于指示继续发送对应的VOQ中缓存的数据报文的流控帧,则均会按照最大发送速率发送相应的数据报文,这样一来,会造成网板侧的流量突发,导致框式交换设备的负载较大。
[0010] 2、容易在同一端口对应的VOQ和OQ所在的Qos调度芯片之间传输大量的用于指示停止发送相关的VOQ中缓存的数据报文的流控帧和用于指示继续发送相关的VOQ中缓存的数据报文的流控帧,进而影响框式交换设备的处理性能。

发明内容

[0011] 为克服相关技术中存在的问题,本申请提供了一种报文处理方法及装置。
[0012] 根据本申请实施例的第一方面,提供一种报文处理方法,所述方法应用于框式交换设备中任一接口板中的任一Qos调度芯片,所述方法包括:
[0013] 针对本地的任一VOQ,若接收到该VOQ对应的OQ所在的接口板发送的第一流控帧、且所述第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;
[0014] 按照确定出的发送速率发送该VOQ中缓存的数据报文;
[0015] 其中,该VOQ对应的OQ对应有多个VOQ,且所述多个VOQ所在的Qos调度芯片不完全相同。
[0016] 根据本申请实施例的第二方面,提供一种报文处理装置,所述装置应用于框式交换设备中任一接口板中的任一Qos调度芯片,所述装置包括:
[0017] 确定模块,用于针对本地的任一VOQ,若接收到该VOQ对应的OQ所在的接口板发送的第一流控帧、且所述第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;
[0018] 发送模块,用于按照确定出的发送速率发送该VOQ中缓存的数据报文;
[0019] 其中,该VOQ对应的OQ对应有多个VOQ,且所述多个VOQ所在的Qos调度芯片不完全相同。
[0020] 本申请的实施例提供的技术方案可以包括以下有益效果:
[0021] 在本申请实施例中,在框式交换设备的多个接口板中的Qos调度芯片上均配置有同一出端口的VOQ的情形下,一旦这些Qos调度芯片接收到用于指示继续发送对应的VOQ中缓存的数据报文的流控帧,不再直接按照最大发送速率发送相应的数据报文,而是根据流控帧中携带的发送速率索引值和预设的发送速率调整策略来确定发送速率。这样一来,本申请可以在一定程度上减少网板侧的流量突发,进而降低了框式交换设备的负载;并且,还可以在一定程度上减少同一端口对应的VOQ和OQ所在的Qos调度芯片之间传输的用于指示停止发送相关的VOQ中缓存的数据报文的流控帧和用于指示继续发送相关的VOQ中缓存的数据报文的流控帧的数量,从而提高了框式交换设备的处理性能。
[0022] 应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。

附图说明

[0023] 此处的附图被并入说明书中并构成本申请的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。
[0024] 图1为现有的框式交换设备中对应同一OQ的VOQ所在的接口板与OQ所在的接口板之间的交互示意图;
[0025] 图2为本申请实施例提供的一种报文处理方法的流程示意图;
[0026] 图3为本申请实施例提供的该VOQ的状态变化示意图;
[0027] 图4为本申请实施例提供的一种报文处理装置的结构示意图。

具体实施方式

[0028] 这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。
[0029] 在本申请使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本申请。在本申请和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
[0030] 应当理解,尽管在本申请可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本申请范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
[0031] 接下来对本申请实施例进行详细说明。
[0032] 本申请实施例提供了一种报文处理方法,该方法应用于框式交换设备中任一接口板中的任一Qos调度芯片,该Qos调度芯片可以为FAP芯片、现场可编程门阵列(Fiele‑Programmable Gate Array,FPGA)芯片等,如图2所示,该方法可以包括如下步骤:
[0033] S21、针对本地的任一VOQ,若接收到该VOQ对应的OQ所在的接口板发送的第一流控帧、且第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率。
[0034] S22、按照确定出的发送速率发送该VOQ中缓存的数据报文。
[0035] 需要说明的是,在本申请实施例中,该VOQ对应的OQ对应有多个VOQ,且多个VOQ所在的Qos调度芯片不完全相同。
[0036] 进一步地,在本申请实施例中,在第一流控帧为用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的流控帧时,则停止发送该VOQ中缓存的数据报文。
[0037] 具体地,在上述步骤S21中,该Qos调度芯片可以通过以下方式确定待发送该VOQ中缓存的数据报文的发送速率:
[0038] 第一种方式:在第一发送速率索引值为设定的发送速率索引值时,将最大发送速率确定为待发送该VOQ中缓存的数据报文的发送速率;在第一发送速率索引值不为设定的发送速率索引值时,在预设的发送速率索引值与发送速率的第一对应关系中,查找第一发送速率索引值对应的发送速率,并将查找到的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率。在这里,最大发送速率大于第一对应关系中的任一发送速率。
[0039] 例如,上述设定的发送速率索引值可以用0b’00000来标识,对应最大发送速率;第一对应关系中的发送速率索引值可以分别为0b’00001、0b’00010和0b’00011等,其中,0b’00001对应75%的最大发送速率,0b’00010对应50%的最大发送速率,0b’00011对应25%的最大发送速率。
[0040] 当然,上述设定的发送速率索引值以及第一对应关系中的发送速率索引值还可以用其他方式来标识,并且,第一对应关系中的发送速率还可以是其他设置方式,在此不再一一列举。
[0041] 第二种方式:在第一发送速率索引值为设定的发送速率索引值时,将最大发送速率确定为待发送该VOQ中缓存的数据报文的发送速率;在第一发送速率索引值不为设定的发送速率索引值时,比较第一发送速率索引值、和根据预设的第一数量区间与发送速率的第二对应关系和第一对应关系查找到的该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值的大小;在比较结果为相等时,将比较结果中的任一发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率;在比较结果为不相等时,将比较结果中的最小的发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率。
[0042] 在第二种方式中,该Qos调度芯片具体可以通过以下方式查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值:
[0043] 在第二对应关系中,查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率;
[0044] 在第一对应关系中,进一步查找查找到的发送速率对应的发送速率索引值。
[0045] 例如,第二对应关系中的第一数量区间可以分别为[XonSlowThreshold 3,XonSlowThreshold2)、[XonSlowThreshold 2,XonSlowThreshold1)和[XonSlowThreshold 1,Xon Threshold)等,对应的发送速率分别为25%的最大发送速率、50%的最大发送速率和75%的最大发送速率等。
[0046] 当然,本申请并不仅限于上述第二对应关系的设置方式,还可以采用其他方式设置,例如,第二对应关系可以包括更多的数量区间及其对应的发送速率,在此不再一一列举。
[0047] 进一步地,在本申请实施例中,为了实现精准调整发送速率,该Qos调度芯片在执行上述步骤S21中的根据第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤之前,还执行以下操作:
[0048] 判断该Qos调度芯片是否使能了精细调速功能;
[0049] 在判断结果为否时,执行根据第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;
[0050] 在判断结果为是时,若第一流控帧为第1次或者第2次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则执行根据第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;
[0051] 若第一流控帧不为前两次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧中的任一流控帧,则获取上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第二流控帧时确定出的发送速率对应的第二发送速率索引值、和上上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第三流控帧时确定出的发送速率对应的第三发送速率索引值,并进一步判断第三发送速率索引值是否与第一发送速率索引值相同、以及第二发送速率索引值和第三发送速率索引值是否为相邻的发送速率索引值;
[0052] 若是,则按照第一发送速率索引值对应的发送速率与第二发送速率索引值对应的发送之间的中间值发送该VOQ中缓存的数据报文;
[0053] 否则,执行根据第一流控帧中携带的第一发送速率索引值,确定待发送该VOQ中缓存的数据报文的发送速率的步骤。
[0054] 需要说明的是,在此操作流程中,该Qos调度芯片在执行根据第一流控帧中携带的第一发送速率索引值,确定待发送该VOQ中缓存的数据报文的发送速率的步骤时,具体可以执行上述第一种方式或者第二种方式。
[0055] 例如,仍以上述第一对应关系中的发送速率索引值为例,假设该Qos调度芯片在接收到第一流控帧之前已接收到过2次用于指示继续发送缓存到该VOQ中的数据报文的流控帧,并且上次和上上次确定出的发送速率对应的发送速率索引值分别为0b’00001和0b’00010(二者相邻),假设第一流控帧中携带的发送速率索引值为0b’00001,那么,在这种情形下,该Qos调度芯片会按照75%的最大发送速率和50%的最大发送速率之间的中间值发送该VOQ中缓存的数据报文,这样一来,可以使该VOQ和该VOQ对应的OQ中的数据报文被平稳地发送出去,从而可以减少网板侧的流量突发,以及减少相关流控帧的传输数量。
[0056] 更进一步地,在本申请实施例中,为了更好地减少网板侧的流量突发,以及减少相关流控帧的传输数量,该Qos调度芯片在接收到第一流控帧之前,还可以执行以下操作:
[0057] 在该Qos调度芯片上电后,将该VOQ的状态设置为初始(Init)状态(如图3所示),并监测该VOQ中缓存的数据报文的数量;
[0058] 在监测到的数量达到第一设定数量且未达到第二设定数量时,将该VOQ的状态由初始状态切换为慢启动(Slowstart)状态(如图3所示),并在预设的第二数量区间与发送速率的第三对应关系中,查找监测到的数量所处的第二数量区间对应的发送速率,并按照查找到的发送速率发送该VOQ中缓存的数据报文,其中,第三对应关系中不同的第二数量区间对应不同的发送速率;
[0059] 在监测到的数量达到第二设定数量时,将该VOQ的状态由慢启动状态切换为全速发包(ON)状态(如图3所示),并按照最大发送速率发送该VOQ中缓存的数据报文,其中,最大发送速率大于第三对应关系中的任一发送速率;
[0060] 在按照最大发送速率发送该VOQ中缓存的数据报文后,若接收到OQ所在的接口板发送的用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的第四流控帧,则将该VOQ的状态由全速发包状态切换为关闭(OFF)状态,并停止发送该VOQ中缓存的数据报文;
[0061] 该Qos调度芯片在接收到第一流控帧之后,还执行以下操作:
[0062] 在第一发送速率索引值为设定的发送速率索引值时,将该VOQ的当前状态(即,关闭状态或者调速状态)切换为全速发包状态(如图3所示),在这里,在该VOQ的当前状态为关闭状态时,说明该Qos调度芯片上一次接收到了用于指示停止发送缓存到该VOQ中的数据报文的流控帧;在该VOQ的当前状态为调速状态时,说明该Qos调度芯片上一次接收到了用于指示继续发送缓存到该VOQ中的数据报文的流控帧VOQ;
[0063] 在第一发送速率索引值不为设定的发送速率索引值时,若该VOQ的当前状态为调速状态,则维持该VOQ的当前状态不变(如图3所示);若该VOQ的当前状态为关闭状态或者全速发包状态,则将该VOQ的当前状态切换为调速状态(如图3所示)。
[0064] 需要说明的是,在此操作流程中,第一设定数量和第二设定数量可以根据实际经验来取值,例如,第三对应关系中的第二数量区间可以分别为[第一设定数量(例如xStartthreshold 1),xStartthreshold 2)、[xStartthreshold2,xStartthreshold 1)和[xStartthreshold 1,第二设定数量(例如,Xon Threshold))等,对应的发送速率分别为25%的最大发送速率、50%的最大发送速率和75%的最大发送速率等。
[0065] 当然,本申请并不仅限于上述第三对应关系的设置方式,还可以采用其他方式设置,例如,第三对应关系可以包括更多的数量区间及其对应的发送速率,在此不再一一列举。
[0066] 进一步需要说明的是,不管该VOQ处于Slowstart状态、Slow状态和ON状态下的哪一个状态,一旦该VOQ中的数据报文被全部发送完毕,该Qos调度芯片立即将状态切换为Init状态(如图3所示)。
[0067] 另外,在该Qos调度芯片上防止挂死的定时器超时,或者该VOQ对应的OQ所在的接口板被拔出时,该Qos调度芯片将该VOQ的OFF状态切换为Init状态(如图3所示)。
[0068] 由以上技术方案可以看出,在本申请实施例中,在框式交换设备的多个接口板中的Qos调度芯片上均配置有同一出端口的VOQ的情形下,一旦这些Qos调度芯片接收到用于指示继续发送对应的VOQ中缓存的数据报文的流控帧,不再直接按照最大发送速率发送相应的数据报文,而是根据流控帧中携带的发送速率索引值和预设的发送速率调整策略来确定发送速率。这样一来,本申请可以在一定程度上减少网板侧的流量突发,进而降低了框式交换设备的负载;并且,还可以在一定程度上减少同一端口对应的VOQ和OQ所在的Qos调度芯片之间传输的用于指示停止发送相关的VOQ中缓存的数据报文的流控帧和用于指示继续发送相关的VOQ中缓存的数据报文的流控帧的数量,从而提高了框式交换设备的处理性能。
[0069] 基于同一发明构思,本申请还提供了一种报文处理装置,所述装置应用于框式交换设备中任一接口板中的任一Qos调度芯片,其结构示意图如图4所示,具体包括:
[0070] 确定模块41,用于针对本地的任一虚拟出端口队列VOQ,若接收到该VOQ对应的出端口队列OQ所在的接口板发送的第一流控帧、且所述第一流控帧为用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率;
[0071] 发送模块42,用于按照确定出的发送速率发送该VOQ中缓存的数据报文;
[0072] 其中,该VOQ对应的OQ对应有多个VOQ,且所述多个VOQ所在的Qos调度芯片不完全相同。
[0073] 优选地,所述装置还包括:
[0074] 停止发送模块(图4中未示出),用于在所述第一流控帧为用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的流控帧时,则停止发送该VOQ中缓存的数据报文。
[0075] 优选地,所述装置还包括:
[0076] 判断模块(图4中未示出),用于在所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤之前,判断该Qos调度芯片是否使能了精细调速功能;
[0077] 在判断结果为否时,触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;
[0078] 在判断结果为是时,若所述第一流控帧为第1次或者第2次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧,则触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值和预设的发送速率调整策略,确定待发送该VOQ中缓存的数据报文的发送速率的步骤;
[0079] 若所述第一流控帧不为前两次接收到的用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的流控帧中的任一流控帧,则获取上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第二流控帧时确定出的发送速率对应的第二发送速率索引值、和上上次接收到用于指示该Qos调度芯片继续发送缓存到该VOQ中的数据报文的第三流控帧时确定出的发送速率对应的第三发送速率索引值,并进一步判断所述第三发送速率索引值是否与所述第一发送速率索引值相同、以及所述第二发送速率索引值和所述第三发送速率索引值是否为相邻的发送速率索引值;
[0080] 若是,则按照所述第一发送速率索引值对应的发送速率与所述第二发送速率索引值对应的发送之间的中间值发送该VOQ中缓存的数据报文;
[0081] 否则,触发所述确定模块执行所述根据所述第一流控帧中携带的第一发送速率索引值,确定待发送该VOQ中缓存的数据报文的发送速率的步骤。
[0082] 优选地,所述确定模块,具体用于通过以下方式确定待发送该VOQ中缓存的数据报文的发送速率:
[0083] 在所述第一发送速率索引值为设定的发送速率索引值时,将最大发送速率确定为待发送该VOQ中缓存的数据报文的发送速率;
[0084] 在所述第一发送速率索引值不为设定的发送速率索引值时,在预设的发送速率索引值与发送速率的第一对应关系中,查找所述第一发送速率索引值对应的发送速率,并将查找到的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率,其中,所述最大发送速率大于所述第一对应关系中的任一发送速率;或者,
[0085] 比较所述第一发送速率索引值、和根据预设的第一数量区间与发送速率的第二对应关系和所述第一对应关系查找到的该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值的大小;
[0086] 在比较结果为相等时,将比较结果中的任一发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率;
[0087] 在比较结果为不相等时,将比较结果中的最小的发送速率索引值对应的发送速率,确定为待发送该VOQ中缓存的数据报文的发送速率。
[0088] 优选地,所述确定模块41,具体用于通过以下方式查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率所对应的发送速率索引值:
[0089] 在所述第二对应关系中,查找该VOQ中当前缓存的数据报文的数量所处的第一数量区间对应的发送速率;
[0090] 在所述第一对应关系中,进一步查找查找到的发送速率对应的发送速率索引值。
[0091] 优选地,所述装置还包括:
[0092] 监测模块(图4中未示出),用于在所述确定模块接收到所述第一流控帧之前,在该Qos调度芯片上电后,将该VOQ的状态设置为初始状态,并监测该VOQ中缓存的数据报文的数量;
[0093] 第一切换模块(图4中未示出),用于在所述监测模块监测到的数量达到第一设定数量且未达到第二设定数量时,将该VOQ的状态由初始状态切换为慢启动状态,并在预设的第二数量区间与发送速率的第三对应关系中,查找监测到的数量所处的第二数量区间对应的发送速率,并按照查找到的发送速率发送该VOQ中缓存的数据报文,其中,所述第三对应关系中不同的第二数量区间对应不同的发送速率;
[0094] 第二切换模块(图4中未示出),用于在所述监测模块监测到的数量达到所述第二设定数量时,将该VOQ的状态由慢启动状态切换为全速发包状态,并按照最大发送速率发送该VOQ中缓存的数据报文,其中,所述最大发送速率大于所述第三对应关系中的任一发送速率;
[0095] 第三切换模块(图4中未示出),用于在所述第二切换模块按照最大发送速率发送该VOQ中缓存的数据报文后,若接收到所述OQ所在的接口板发送的用于指示该Qos调度芯片停止发送缓存到该VOQ中的数据报文的第四流控帧,则将该VOQ的状态由全速发包状态切换为关闭状态,并停止发送该VOQ中缓存的数据报文;
[0096] 第四切换模块(图4中未示出),用于在所述确定模块接收到所述第一流控帧之后,在所述第一发送速率索引值为设定的发送速率索引值时,将该VOQ的当前状态切换为全速发包状态,其中,该VOQ的当前状态为关闭状态或者调速状态;在所述第一发送速率索引值不为设定的发送速率索引值时,若该VOQ的当前状态为调速状态,则维持该VOQ的当前状态不变;若该VOQ的当前状态为关闭状态或者全速发包状态,则将该VOQ的当前状态切换为调速状态。
[0097] 由以上技术方案可以看出,在本申请实施例中,在框式交换设备的多个接口板中的Qos调度芯片上均配置有同一出端口的VOQ的情形下,一旦这些Qos调度芯片接收到用于指示继续发送对应的VOQ中缓存的数据报文的流控帧,不再直接按照最大发送速率发送相应的数据报文,而是根据流控帧中携带的发送速率索引值和预设的发送速率调整策略来确定发送速率。这样一来,本申请可以在一定程度上减少网板侧的流量突发,进而降低了框式交换设备的负载;并且,还可以在一定程度上减少同一端口对应的VOQ和OQ所在的Qos调度芯片之间传输的用于指示停止发送相关的VOQ中缓存的数据报文的流控帧和用于指示继续发送相关的VOQ中缓存的数据报文的流控帧的数量,从而提高了框式交换设备的处理性能。
[0098] 以上所述仅为本申请的较佳实施例而已,并不用以限制本申请,凡在本申请的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本申请保护的范围之内。