CN114070803A - 一种数据流的传输方法、装置、存储介质及电子装置 - Google Patents
一种数据流的传输方法、装置、存储介质及电子装置 Download PDFInfo
- Publication number
- CN114070803A CN114070803A CN202111633587.6A CN202111633587A CN114070803A CN 114070803 A CN114070803 A CN 114070803A CN 202111633587 A CN202111633587 A CN 202111633587A CN 114070803 A CN114070803 A CN 114070803A
- Authority
- CN
- China
- Prior art keywords
- data stream
- forwarding
- bandwidth
- interface
- forwarded
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 59
- 230000005540 biological transmission Effects 0.000 title claims abstract description 24
- 230000015654 memory Effects 0.000 claims description 15
- 238000001514 detection method Methods 0.000 claims description 9
- 238000004590 computer program Methods 0.000 claims description 7
- 230000008569 process Effects 0.000 abstract description 15
- 230000007246 mechanism Effects 0.000 abstract description 9
- 230000002776 aggregation Effects 0.000 description 12
- 238000004220 aggregation Methods 0.000 description 12
- 230000006870 function Effects 0.000 description 7
- 238000010586 diagram Methods 0.000 description 6
- 238000004891 communication Methods 0.000 description 5
- 238000005516 engineering process Methods 0.000 description 5
- 230000000694 effects Effects 0.000 description 3
- 238000004422 calculation algorithm Methods 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000002159 abnormal effect Effects 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 235000019800 disodium phosphate Nutrition 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000003672 processing method Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/15—Interconnection of switching modules
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/25—Routing or path finding in a switch fabric
- H04L49/252—Store and forward routing
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种数据流的传输方法、装置、存储介质及电子装置,其中,检测堆叠设备组中包括的第一设备上接收到的待转发的数据流;在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流。采用上述技术方案,解决了在基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题。
Description
技术领域
本发明涉及计算机领域,具体而言,涉及一种数据流的传输方法、装置、存储介质及电子装置。
背景技术
堆叠技术通常是使用多台设备,通过特定的背板接口(连接多台交换设备专门用于维护堆叠协议的接口,通常用于设备间信息同步及进行跨设备数据流转发),将多台转发设备(通常为交换机)模拟为逻辑上的一台堆叠设备,不同转发设备上的接口均可视为同一台设备上的接口,进行逻辑上单台设备内部的交换转发行为。同时,堆叠设备为了提高流量传输可靠性,会进行跨设备的链路聚合以便达成接入链路的备份。
但是流量在转发的同时,由于必须通过背板接口进行转发,在占用有限的背板接口带宽的同时,也会降低流量的传输效率因此当前存在一种本地优先转发的处理方式,在交换机上配置本地优先转发功能使能时,当本地设备收到流量后,会优先通过本设备出接口及本地转发链路向接入设备转发流量,这样既节省了背板接口的带宽,也提高了转发效率。同时当本地转发链路发生异常及断开时,流量同样能够通过背板接口进行跨设备的聚合组转发,仍旧保持了传输的可靠性。同理反向及通过其他设备收到的流量同样可以进行上述处理。
但是由于交换芯片,在本地转发链路始终up的情况下,由于不会将流量进行跨设备转发,可能会当流量造成超过本设备出接口带宽时,新增流量仍旧通过本设备出接口进行转发,在没有超过聚合组带宽的情况下造成流量丢失。
针对相关技术中,基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题,尚未提出有效的解决方案。
发明内容
本发明实施例提供了一种数据流的传输方法、装置、存储介质及电子装置,以至少解决相关技术中,基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题。
根据本发明实施例的一个实施例,提供了一种数据流的传输方法,包括:检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备;
在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;
在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;
在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
在一个示例性实施例中,所述检测所述第一设备的转发接口当前的带宽占用状态,包括:
检测所述转发接口当前的带宽占用率,其中,所述带宽占用率用于指示所述转发接口当前传输数据的带宽在所述转发接口允许传输数据的带宽中的占用比例;根据所述带宽占用率确定所述带宽占用状态。
在一个示例性实施例中,所述检测所述转发接口当前的带宽占用率,包括:
检测所述转发接口在目标时间内的转发数据量;确定所述转发数据量与所述目标时间之间的第一比值;将所述第一比值与所述转发接口允许传输数据的带宽之间的第二比值确定为所述带宽占用率。
在一个示例性实施例中,所述根据所述带宽占用率确定所述带宽占用状态,包括:
在所述带宽占用率大于或者等于第一阈值的情况下,确定所述带宽占用状态为拥塞状态;在所述带宽占用率小于所述第一阈值的情况下,确定所述带宽占用状态不为拥塞状态。
在一个示例性实施例中,在所述确定所述带宽占用状态不为拥塞状态之后,所述方法还包括:
在所述带宽占用率小于第二阈值的情况下,从所述其他设备上获取第二数据流,其中,所述第二阈值小于所述第一阈值,所述第二数据流是所述第一设备接收到的待通过所述其他设备转发的数据流;通过所述转发接口转发所述第二数据流。
在一个示例性实施例中,所述检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,包括:
确定所述第一设备上接收到第三数据流;获取所述第三数据流的数据流类型,以及所述转发接口当前转发的第四数据流的数据流类型;在所述第三数据流的数据流类型与所述第四数据流的数据流类型不同的情况下,将所述第三数据流确定为所述第一数据流。
在一个示例性实施例中,所述通过所述堆叠设备组中包括的第二设备转发所述第一数据流,包括:
从所述其他设备中获取与所述第一设备直接连接的设备;将与所述第一设备直接连接的设备中的一个设备确定为所述第二设备。
根据本发明实施例的另一个实施例,还提供了一种堆叠设备的流量动态调整装置,包括:
第一检测模块,用于检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备。
第二检测模块,用于在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态。
第一转发模块,用于在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流。
第二转发模块,用于在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
根据本发明实施例的又一方面,还提供了一种计算机可读的存储介质,所述计算机可读的存储介质包括存储的程序,其中,所述程序运行时执行上述一种数据流的传输方法。
根据本发明实施例的又一方面,还提供了一种电子装置,包括存储器和处理器,所述存储器中存储有计算机程序,所述处理器被设置为通过所述计算机程序执行上述一种数据流的传输方法。
在本发明实施例中,检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备;在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备,即堆叠设备组包含多个通过背板接口互相连接的设备,首先检测第一设备上接收到的待转发的数据流,当检测出上述数据流的类型与上述第一设备已经转发的数据流类型不同时,再检测上述第一设备的转发接口当前的带宽占用状态,根据上述带宽占用状态来决定第一数据流的转发方法,在上述带宽占用状态不为拥塞状态的情况下,通过上述第一设备的转发接口转发上述第一数据流,在上述带宽占用状态为拥塞状态的情况下,通过上述堆叠设备组中其他设备的接口转发上述第一数据流。采用上述技术方案,解决了相关技术中,基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题,实现了基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,降低流量丢失率的技术效果。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本发明的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1是本发明实施例的一种数据流的传输方法的交换设备一种可能的结构示意图;
图2是根据本发明实施例的一种数据流的传输方法的流程图;
图3是根据本发明实施例的一种堆叠设备的流量动态调整装置的结构框图;
图4是根据本发明实施例的一种堆叠设备的流量动态调整方法的流程图;
图5是根据本发明实施例的一种堆叠设备的流量动态调整装置的结构框图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
本发明实施例所提供的方法实施例可以在交换设备、交换机或者类似的运算装置中执行。以运行在交换设备上为例,图1是本发明实施例的一种数据流的传输方法的交换设备一种可能的结构示意图。如图1所示,交换设备可以包括:处理单元1001(处理单元1001用于对交换设备的动作进行控制管理,和/或用于执行本文所描述的技术的其它过程。)和通信单元1002、存储单元1003和总线1004。在一个示例性实施例中,通信单元1002用于支持交换设备与其他网络实体的通信。存储单元1003用于存储交换设备的程序代码和报文。本领域普通技术人员可以理解,图1所示的结构仅为示意,其并不对上述交换设备的结构造成限定。例如,交换设备还可包括比图1中所示更多或者更少的组件,或者具有与图1所示等同功能或比图1所示功能更多的不同的配置。
上述处理单元1001可以是交换设备中的处理器或控制器,该处理器或控制器可以实现或执行结合本申请公开内容所描述的各种示例性的逻辑方框,模块和电路。该处理器或控制器可以是中央处理器,通用处理器,数字信号处理器,专用集成电路,现场可编程门阵列或者其他可编程逻辑器件、晶体管逻辑器件、硬件部件或者其任意组合。其可以实现或执行结合本申请公开内容所描述的各种示例性的逻辑方框,模块和电路。所述处理器也可以是实现计算功能的组合,例如包含一个或多个微处理器组合,DSP和微处理器的组合等。
通信单元1002可以是交换设备中的收发器、收发电路或通信接口等。
存储单元1003可以是交换设备中的存储器等,该存储器可以包括易失性存储器,例如随机存取存储器;该存储器也可以包括非易失性存储器,例如只读存储器,快闪存储器,硬盘或固态硬盘;该存储器还可以包括上述种类的存储器的组合。
总线1004可以是扩展工业标准结构(Extended Industry StandardArchitecture,EISA)总线等。总线1004可以分为地址总线、数据总线、控制总线等。为便于表示,图1中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
在本实施例中提供了一种数据流的传输方法,应用于上述计算机终端,图2是根据本发明实施例的一种数据流的传输方法的流程图,该流程包括如下步骤:
步骤S202,检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备。
步骤S204,在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态。
步骤S206,在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流。
步骤S208,在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
通过上述步骤,堆叠设备组包含多个通过背板接口互相连接的设备,首先检测第一设备上接收到的待转发的数据流,当检测出上述数据流的类型与上述第一设备已经转发的数据流类型不同时,再检测上述第一设备的转发接口当前的带宽占用状态,根据上述带宽占用状态来决定第一数据流的转发方法,在上述带宽占用状态不为拥塞状态的情况下,通过上述第一设备的转发接口转发上述第一数据流,在上述带宽占用状态为拥塞状态的情况下,通过上述堆叠设备组中其他设备的接口转发上述第一数据流。采用上述技术方案,解决了相关技术中,基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题,实现了基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,降低流量丢失率的技术效果。
在上述步骤S202提供的技术方案中,所述堆叠设备组可以但不限于为任何形式的使用堆叠技术将多个设备进行堆叠连接的具备传输数据流能力的设备组,比如:可以但不限于是多台支持堆叠特性的交换机通过堆叠线缆连接在一起,从逻辑上虚拟成一台交换设备,作为一个整体参与数据转发的设备组,其中,上述堆叠技术的类型可以但不限于是菊花链式堆叠和星型堆叠技术。
可选地,在本实施例中,所述第一设备可以但不限于为上述堆叠设备组种的任何一个设备,也就是说,上述数据流的传输方法适用于上述堆叠设备组中的任何一个设备,比如:组成堆叠设备组中的任何一台使用堆叠技术连接的设备,都可以作为第一设备。
可选地,在本实施例中,所述数据流可以但不限于为任何形式的一组有序,有起点和终点的字节的数据序列,比如:可以但不限于为字节流和字符流。
可选地,在本实施例中,所述第一设备上接收到的待转发的数据流可以但不限于为上述第一设备已经接受到,但是还没有转发的数据流,也就是说,上述数据流虽然已经被第一设备所接收到,但是数据流还没有转发,并且上述数据流的转发接口还没有确定。
可选地,在本实施例中,所述背板接口可以但不限于为任何形式的用于连接上述堆叠设备组之间的堆叠设备的接口,也就是说背板接口可以但不限于是堆叠设备之间具备数据转发功能的物理通道,比如:路由器的背板接口为路由器输入端与输出端之间的物理通道。
在一个示例性实施例中,在上述步骤S202中,可以但不限于通过以下方式检测堆叠设备组中包括的第一设备上接收到的待转发的数据流:确定所述第一设备上接收到第三数据流;获取所述第三数据流的数据流类型,以及所述转发接口当前转发的第四数据流的数据流类型;在所述第三数据流的数据流类型与所述第四数据流的数据流类型不同的情况下,将所述第三数据流确定为所述第一数据流。
可选地,在本实施例中,所述第三数据流可以但不限于为任何形式的在当前时刻,被上述第一设备所接收到的数据流,也就是说,在当前时刻,任何被上述第一设备所接收到的数据流全部都作为第三数据流。
可选地,在本实施例中,所述第四数据流可以但不限于为任何形式的在当前时刻,已经被上述第一设备传输的数据流,也就是说,在当前时刻,已经被上述第一设备传输的数据流都可以作为第四数据流。
可选地,在本实施例中,所述第三数据流的数据流类型与所述第四数据流的数据流类型不同的情况可以但不限于为:任何上述数据流通过哈希算法计算获得的数据流所对应到的,长度固定的字符串(又称消息摘要)不同的情况,也就是说,当上述第三数据流和上述第四数据流,分别通过哈希算法计算获得两个对应到的,长度固定的字符串,如果两个字符串不同,那么,上述两个字符串所分别对应的上述第三数据流和上述第四数据流的数据流类型也不同。
在上述步骤S204提供的技术方案中,所述第一设备的转发接口可以但不限于为任何上述第一设备上具备转发数据流功能的接口。
可选地,在本实施例中,所述当前的带宽占用状态可以但不限于用于描述当前接口用于传输数据流已经占用的带宽的大小,例如,上述当前的带宽占用状态可以但不限于为以下几种类型:
类型一,拥塞状态,可以但不限于为上述当前的带宽占用率大于或者预设的当前的带宽允许的最大占用率的情况下,对应的当前的带宽占用状态。
类型二,正常状态,可以但不限于为上述当前的带宽占用率小于预设的当前的带宽允许的最大占用率,且大于当前的带宽允许的最小占用率的情况下,对应的当前的带宽占用状态。
类型三,闲置状态,可以但不限于为上述当前的带宽占用率小于预设的当前的带宽允许的最小占用率的情况下,对应的当前的带宽占用状态。
在一个示例性实施例中,在上述步骤S204中,可以但不限于通过以下方式在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态:检测所述转发接口当前的带宽占用率,其中,所述带宽占用率用于指示所述转发接口当前传输数据的带宽在所述转发接口允许传输数据的带宽中的占用比例;根据所述带宽占用率确定所述带宽占用状态。
可选地,在本实施例中,上述带宽占用率可以但不限于可以描述上述带宽占用情况的数据,上述带宽占用率可以但不限于为流率和带宽的比值,其中,上述流率可以但不限于为输出流率。
在一个示例性实施例中,可以但不限于通过以下方式检测所述转发接口当前的带宽占用率:检测所述转发接口在目标时间内的转发数据量;确定所述转发数据量与所述目标时间之间的第一比值;将所述第一比值与所述转发接口允许传输数据的带宽之间的第二比值确定为所述带宽占用率。
可选地,在本实施例中,上述目标时间的选取可以但不限于为选取与当前时间接近的,能够反映当前时间的带宽占用情况的时间段,也就是说,选择的目标时间可以但不限于与当前时刻接近,两个时间所对应的带宽占用率接近。
可选地,在本实施例中,上述转发数据量可以但不限于包括在上述目标时间内,经过上述转发接口输出的流量。
在一个示例性实施例中,可以但不限于通过以下方式根据所述带宽占用率确定所述带宽占用状态:在所述带宽占用率大于或者等于第一阈值的情况下,确定所述带宽占用状态为拥塞状态;在所述带宽占用率小于所述第一阈值的情况下,确定所述带宽占用状态不为拥塞状态。
可选地,在本实施例中,上述拥塞状态可以但不限于为描述在当前时刻,上述带宽占用情况比较大的情况,也就是说上述带宽的带宽占用率比较大,对应的接口可用于传输数据的带宽不足,可能会出现丢失数据的风险。
在一个示例性实施例中,在所述确定所述带宽占用状态不为拥塞状态之后,所述根据所述带宽占用率确定所述带宽占用状态的方法可以但不限于还包括:在所述带宽占用率小于第二阈值的情况下,从所述其他设备上获取第二数据流,其中,所述第二阈值小于所述第一阈值,所述第二数据流是所述第一设备接收到的待通过所述其他设备转发的数据流;通过所述转发接口转发所述第二数据流。
可选地,在本实施例中,上述第二阈值可以但不限于为用于描述上述带宽占用率较低的情况下对应的值,也就是说,当上述带宽占用率小于上述第二阈值的情况下,对应的接口可用于传输数据流的能力较大。
可选地,在本实施例中,上述第二数据流可以但不限于为任何被上述第一设备接收,但是由其他设备正在转发的数据流。
在一个示例性实施例中,在上述步骤S206中,可以但不限于在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流。
在一个示例性实施例中,在上述步骤S208中,可以但不限于在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
可选地,在本实施例中,上述第二设备可以但不限于为任何和上述第一设备共同组成上述堆叠设备组的具备转发数据流能力的其他设备。
在一个示例性实施例中,在上述步骤S208中,可以但不限于通过以下方式通过所述堆叠设备组中包括的第二设备转发所述第一数据流:从所述其他设备中获取与所述第一设备直接连接的设备;将与所述第一设备直接连接的设备中的一个设备确定为所述第二设备。
可选地,在本实施例中,上述直接连接可以但不限于为通过任何方式的物理连接,例如可以但不限于通过堆叠线缆直接连接。
为了更好的理解上述一种数据流的传输方法的过程,以下再结合可选实施例对上述一种数据流的传输方法的过程的实现方法流程进行说明,但不用于限定本发明实施例的技术方案。
基于上述实施例的内容,作为一种可选实施例,图3是根据本发明实施例的一种堆叠设备的流量动态调整装置的结构框图;如图3所示:
堆叠设备为了提高流量传输可靠性,会进行跨设备的链路聚合以便达成接入链路的备份,如下图中需要转发至接入设备的流量到达Switch 1设备后,由于两台switch被模拟为一台堆叠设备,因此进行简单的处理通过二层交换或三层路由转发至聚合组内,可能直接通过link1转发至接入设备,也可能通过背板接口转发至Switch 2后经link 2转发至接入设备。
堆叠设备使能本地优先转发的情况下,提供动态调节功能,监控本地出接口带宽占用率,当本地接口带宽使用率达到某一水平(max阈值)后,将转发至此端口的新流通过背板接口进行跨设备转发,否则进行本地接口转发,同时判断接口带宽使用率低于min阈值时,将跨设备转发流量切换至本地转发用于解决本地优先转发出现没有超过聚合组带宽的情况下造成的流量丢失。
在switch上进行此动态调节功能配置,即max threshold及min threshold两个阈值后,当一条新增流量转发至Switch1时,同样如前文需要转发至聚合组进而到达接入设备,Switch1会获取当前port1端口的带宽占用率,并与max threshold进行比较,若当前带宽占用率已超过max threshold,将此流量进行跨设备转发至port2口发出。若此时带宽占用率未到达max threshold,仍旧将此流量进行本地转发通过port1发出。
同时,将当前port1端口的带宽占用率与min threshold进行比较,若此时带宽占用率仍旧高于min threshold,则维持现状不做任何操作,若带宽占用率低于minthreshold,说明当前本地转发端口带宽存在较多空闲,将跨设备通过port2转发的流量切换至本地进行转发。灵活的,当不需要进行流量回切操作时,可将min threshold设置为不生效状态,避免不必要的流量切换。
上述过程均由新流触发,具体的,新流可以根据不同的关键字段定义,如使用源ip地址作为关键字段,则不同源ip地址的流量可认为是不同的流。当出现一个关键字段与当前保持转发状态的流量(可能是多条)不一致时,即认为此流量为新流。
图4是根据本发明实施例的一种堆叠设备的流量动态调整方法的流程图;如图4所示,当一个新流到达启用了本地优先转发功能的堆叠设备时,相关处理流程如下:
J1:比较当前跨设备链路聚合组本地出口(若存在多个则计算总和)的带宽占用率与max threshold的大小,若当前带宽占用率大于max threshold,则执行P2;否则执行P1。
P1:将当前这条新流转发至跨设备链路聚合组的本地出口,然后执行J2。
P2:将当前这条新流转通过背板接口进行跨设备转发,转发至跨设备链路聚合组的远端出口发出。
J2:比较当前跨设备链路聚合组本地出口(若存在多个则计算总和)的带宽占用率与min threshold的大小,若当前带宽占用率小于min threshold,则执行P3;否则结束执行。
P3:将通过跨设备链路聚合组的远端出口转发的流量切换至本地出口进行转发。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到根据上述实施例的方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本发明各个实施例的方法。
图5是根据本发明实施例的一种堆叠设备的流量动态调整装置的结构框图;如图5所示,包括:
第一检测模块52,用于检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备;
第二检测模块54,用于在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;
第一转发模块56,用于在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;
第二转发模块58,用于在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
在一个示例性实施例中,所述第一检测模块,包括:
第一确定单元,用于确定所述第一设备上接收到第三数据流。
第一获取单元,用于获取所述第三数据流的数据流类型,以及所述转发接口当前转发的第四数据流的数据流类型。
第二确定单元,用于在所述第三数据流的数据流类型与所述第四数据流的数据流类型不同的情况下,将所述第三数据流确定为所述第一数据流。
在一个示例性实施例中,所述第二检测模块,包括:
第一检测单元,用于检测所述转发接口当前的带宽占用率,其中,所述带宽占用率用于指示所述转发接口当前传输数据的带宽在所述转发接口允许传输数据的带宽中的占用比例。
第三确定单元,用于根据所述带宽占用率确定所述带宽占用状态。
在一个示例性实施例中,所述第一检测单元,用于:
检测所述转发接口在目标时间内的转发数据量。
确定所述转发数据量与所述目标时间之间的第一比值。
将所述第一比值与所述转发接口允许传输数据的带宽之间的第二比值确定为所述带宽占用率。
在一个示例性实施例中,所述第三确定单元,用于:
在所述带宽占用率大于或者等于第一阈值的情况下,确定所述带宽占用状态为拥塞状态;在所述带宽占用率小于所述第一阈值的情况下,确定所述带宽占用状态不为拥塞状态。
在一个示例性实施例中,所述第三确定单元,还用于:
在所述带宽占用率小于第二阈值的情况下,从所述其他设备上获取第二数据流,其中,所述第二阈值小于所述第一阈值,所述第二数据流是所述第一设备接收到的待通过所述其他设备转发的数据流;通过所述转发接口转发所述第二数据流。
在一个示例性实施例中,所述第二转发模块,包括:
第三获取单元,用于从所述其他设备中获取与所述第一设备直接连接的设备。
第八确定单元,用于将与所述第一设备直接连接的设备中的一个设备确定为所述第二设备。
通过上述实施例,堆叠设备组包含多个通过背板接口互相连接的设备,首先检测第一设备上接收到的待转发的数据流,当检测出上述数据流的类型与上述第一设备已经转发的数据流类型不同时,再检测上述第一设备的转发接口当前的带宽占用状态,根据上述带宽占用状态来决定第一数据流的转发方法,在上述带宽占用状态不为拥塞状态的情况下,通过上述第一设备的转发接口转发上述第一数据流,在上述带宽占用状态为拥塞状态的情况下,通过上述堆叠设备组中其他设备的接口转发上述第一数据流。采用上述技术方案,解决了相关技术中,基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,流量丢失率较高等问题,实现了基于本地优先转发机制的堆叠设备在流量转发过程中,转发流量超本地带宽的情况下,降低流量丢失率的技术效果。
本发明的实施例还提供了一种存储介质,该存储介质包括存储的程序,其中,上述程序运行时执行上述任一项的方法。
可选地,在本实施例中,上述存储介质可以被设置为存储用于执行以下步骤的程序代码:
S1,检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备。
S2,在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态。
S4,在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流。
S5,在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
本发明的实施例还提供了一种电子装置,包括存储器和处理器,该存储器中存储有计算机程序,该处理器被设置为运行计算机程序以执行上述任一项方法实施例中的步骤。
可选地,上述电子装置还可以包括传输设备以及输入输出设备,其中,该传输设备和上述处理器连接,该输入输出设备和上述处理器连接。
可选地,在本实施例中,上述处理器可以被设置为通过计算机程序执行以下步骤:
S1,检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备。
S2,在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态。
S4,在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流。
S5,在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
可选地,在本实施例中,上述存储介质可以包括但不限于:U盘、只读存储器(Read-Only Memory,简称为ROM)、随机存取存储器(Random Access Memory,简称为RAM)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。
可选地,本实施例中的具体示例可以参考上述实施例及可选实施方式中所描述的示例,本实施例在此不再赘述。
显然,本领域的技术人员应该明白,上述的本发明的各模块或各步骤可以用通用的计算装置来实现,它们可以集中在单个的计算装置上,或者分布在多个计算装置所组成的网络上,可选地,它们可以用计算装置可执行的程序代码来实现,从而,可以将它们存储在存储装置中由计算装置来执行,并且在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤,或者将它们分别制作成各个集成电路模块,或者将它们中的多个模块或步骤制作成单个集成电路模块来实现。这样,本发明不限制于任何特定的硬件和软件结合。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种数据流的传输方法,其特征在于,包括:
检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备;
在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;
在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;
在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
2.根据权利要求1所述的方法,其特征在于,所述检测所述第一设备的转发接口当前的带宽占用状态,包括:
检测所述转发接口当前的带宽占用率,其中,所述带宽占用率用于指示所述转发接口当前传输数据的带宽在所述转发接口允许传输数据的带宽中的占用比例;
根据所述带宽占用率确定所述带宽占用状态。
3.根据权利要求2所述的方法,其特征在于,所述检测所述转发接口当前的带宽占用率,包括:
检测所述转发接口在目标时间内的转发数据量;
确定所述转发数据量与所述目标时间之间的第一比值;
将所述第一比值与所述转发接口允许传输数据的带宽之间的第二比值确定为所述带宽占用率。
4.根据权利要求2所述的方法,其特征在于,所述根据所述带宽占用率确定所述带宽占用状态,包括:
在所述带宽占用率大于或者等于第一阈值的情况下,确定所述带宽占用状态为拥塞状态;
在所述带宽占用率小于所述第一阈值的情况下,确定所述带宽占用状态不为拥塞状态。
5.根据权利要求4所述的方法,其特征在于,在所述确定所述带宽占用状态不为拥塞状态之后,所述方法还包括:
在所述带宽占用率小于第二阈值的情况下,从所述其他设备上获取第二数据流,其中,所述第二阈值小于所述第一阈值,所述第二数据流是所述第一设备接收到的待通过所述其他设备转发的数据流;
通过所述转发接口转发所述第二数据流。
6.根据权利要求1所述的方法,其特征在于,所述检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,包括:
确定所述第一设备上接收到第三数据流;
获取所述第三数据流的数据流类型,以及所述转发接口当前转发的第四数据流的数据流类型;
在所述第三数据流的数据流类型与所述第四数据流的数据流类型不同的情况下,将所述第三数据流确定为所述第一数据流。
7.根据权利要求1所述的方法,其特征在于,所述通过所述堆叠设备组中包括的第二设备转发所述第一数据流,包括:
从所述其他设备中获取与所述第一设备直接连接的设备;
将与所述第一设备直接连接的设备中的一个设备确定为所述第二设备。
8.一种堆叠设备的流量动态调整装置,其特征在于,包括:
第一检测模块,用于检测堆叠设备组中包括的第一设备上接收到的待转发的数据流,其中,所述堆叠设备组中包括多个通过背板接口互相连接的设备;
第二检测模块,用于在检测到所述第一设备上待转发的第一数据流的情况下,检测所述第一设备的转发接口当前的带宽占用状态;
第一转发模块,用于在所述带宽占用状态不为拥塞状态的情况下,通过所述转发接口转发所述第一数据流;
第二转发模块,用于在所述带宽占用状态为拥塞状态的情况下,通过所述堆叠设备组中包括的第二设备转发所述第一数据流,其中,所述第二设备是所述堆叠设备组所包括的设备中除所述第一设备外的其他设备中的一个设备。
9.一种计算机可读的存储介质,其特征在于,所述计算机可读的存储介质包括存储的程序,其中,所述程序运行时执行上述权利要求1至7任一项中所述的方法。
10.一种电子装置,包括存储器和处理器,其特征在于,所述存储器中存储有计算机程序,所述处理器被设置为通过所述计算机程序执行所述权利要求1至7任一项中所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111633587.6A CN114070803B (zh) | 2021-12-28 | 一种数据流的传输方法、装置、存储介质及电子装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111633587.6A CN114070803B (zh) | 2021-12-28 | 一种数据流的传输方法、装置、存储介质及电子装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114070803A true CN114070803A (zh) | 2022-02-18 |
CN114070803B CN114070803B (zh) | 2024-07-02 |
Family
ID=
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050036488A1 (en) * | 1999-05-21 | 2005-02-17 | Broadcom Corporation | Stacked network switch configuration |
CN101645850A (zh) * | 2009-09-25 | 2010-02-10 | 杭州华三通信技术有限公司 | 转发路径确定方法和设备 |
CN108282406A (zh) * | 2017-12-15 | 2018-07-13 | 瑞斯康达科技发展股份有限公司 | 一种数据传输方法、堆叠设备及堆叠系统 |
CN109104376A (zh) * | 2018-07-16 | 2018-12-28 | 新华三技术有限公司 | 一种数据的转发方法、装置、堆叠设备和计算机可读介质 |
CN110995607A (zh) * | 2019-12-19 | 2020-04-10 | 锐捷网络股份有限公司 | 一种传输流量的方法、装置、网络设备及存储介质 |
WO2021120796A1 (zh) * | 2019-12-16 | 2021-06-24 | 中兴通讯股份有限公司 | 流量控制方法、电子设备及存储介质 |
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050036488A1 (en) * | 1999-05-21 | 2005-02-17 | Broadcom Corporation | Stacked network switch configuration |
CN101645850A (zh) * | 2009-09-25 | 2010-02-10 | 杭州华三通信技术有限公司 | 转发路径确定方法和设备 |
CN108282406A (zh) * | 2017-12-15 | 2018-07-13 | 瑞斯康达科技发展股份有限公司 | 一种数据传输方法、堆叠设备及堆叠系统 |
CN109104376A (zh) * | 2018-07-16 | 2018-12-28 | 新华三技术有限公司 | 一种数据的转发方法、装置、堆叠设备和计算机可读介质 |
WO2021120796A1 (zh) * | 2019-12-16 | 2021-06-24 | 中兴通讯股份有限公司 | 流量控制方法、电子设备及存储介质 |
CN110995607A (zh) * | 2019-12-19 | 2020-04-10 | 锐捷网络股份有限公司 | 一种传输流量的方法、装置、网络设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6373840B1 (en) | Stackable networking device and method having a switch control circuit | |
CN101873269B (zh) | 数据转发设备和端口缓存的分配方法 | |
CN104756451A (zh) | 用于lag接口上网络流的动态负载平衡的方法 | |
CN110166280B (zh) | 一种网络扩容方法和装置 | |
JP2001292164A (ja) | パケット・スイッチおよびその切替方法 | |
CN108306824B (zh) | 报文发送方法及装置 | |
CN111181873B (zh) | 数据发送方法、装置、存储介质和电子设备 | |
CN109194585B (zh) | 报文转发方法及网络设备 | |
CN114363180A (zh) | 一种聚合链路流量节能控制方法、装置、终端及存储介质 | |
US8132029B2 (en) | Method for managing the power transmitted from a central network component to a decentralized network component via a line | |
CN114070803B (zh) | 一种数据流的传输方法、装置、存储介质及电子装置 | |
CN113765796B (zh) | 流量转发控制方法及装置 | |
CN114070803A (zh) | 一种数据流的传输方法、装置、存储介质及电子装置 | |
CN110995607A (zh) | 一种传输流量的方法、装置、网络设备及存储介质 | |
CN114499762A (zh) | 一种通信系统、5g网络下的多路转发方法及通信设备 | |
KR101014977B1 (ko) | 링크통합 기능에서 로드밸런싱 방법 | |
CN113497753A (zh) | 一种跨设备链路聚合方法及系统 | |
CN112383471A (zh) | 一种刀箱链路管理方法、装置、设备及机器可读存储介质 | |
CN111953615A (zh) | 一种负载分担的方法、装置以及bras | |
JP2982755B2 (ja) | スイッチ装置 | |
CN116684912A (zh) | 一种确定异常链路的方法及装置 | |
CN113794593B (zh) | 一种集群故障处理方法及装置 | |
CN113726614B (zh) | 一种防止报文丢包的方法、装置、分布式设备及存储介质 | |
CN110995621B (zh) | 一种选择上行口进行通信的方法和交换机 | |
CN109088752A (zh) | 内部控制链路端口动态配置方法及相关装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant |