CN106330756B - 一种数据传输方法和设备 - Google Patents
一种数据传输方法和设备 Download PDFInfo
- Publication number
- CN106330756B CN106330756B CN201510386543.6A CN201510386543A CN106330756B CN 106330756 B CN106330756 B CN 106330756B CN 201510386543 A CN201510386543 A CN 201510386543A CN 106330756 B CN106330756 B CN 106330756B
- Authority
- CN
- China
- Prior art keywords
- data
- sending
- rate
- control information
- receiving
- 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.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/22—Traffic shaping
- H04L47/225—Determination of shaping rate, e.g. using a moving window
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/23—Bit dropping
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/24—Traffic characterised by specific attributes, e.g. priority or QoS
- H04L47/2425—Traffic characterised by specific attributes, e.g. priority or QoS for supporting services specification, e.g. SLA
- H04L47/2433—Allocation of priorities to traffic types
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Communication Control (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本申请公开了一种数据传输方法和设备,有助于解决接收端需要在短时间内接收至少两个发送端的数据而产生的拥塞或丢包的问题。方法包括:接收端接收第一发送端发送的业务信息,所述业务信息用于表示所述第一发送端所需传输的数据的信息;所述接收端判断所述接收端能否满足所述业务信息对应的传输需求;所述接收端确定所述接收端能够满足所述业务信息对应的传输需求后,控制所述第一发送端的数据传输。
Description
技术领域
本发明涉及通信技术领域,特别涉及一种数据传输方法和设备。
背景技术
在数据中心,数据传输通常为多对一(many-to-one)的通信模式,如图1所示。图1中,客户端(client)通过交换机(switch)同时向多个服务器(server)发送用于获取数据的请求。多个服务器中的每个服务器在收到客户端的请求后,通过交换机向客户端推送被请求的数据。由于交换机与客户端连接的端口需要在短时间内处理多个服务器推送的数据,使得交换机与客户端连接的端口容易产生拥塞、丢包、网络吞吐量下降、延迟增加等问题。
发明内容
有鉴于此,本发明实施例提供了一种数据传输方法和设备,有助于解决接收端需要在短时间内接收至少两个发送端的数据而产生的拥塞或丢包的问题,有助于提高数据传输的稳定性。
第一方面,提供一种数据接收方法,包括:
接收端接收第一发送端发送的业务信息,所述业务信息用于表示所述第一发送端所需传输的数据的信息;
所述接收端判断所述接收端能否满足所述业务信息对应的传输需求;
所述接收端确定所述接收端能够满足所述业务信息对应的传输需求后,控制所述第一发送端的数据传输。
结合第一方面,在第一方面的第一种可能的实现方式中,还包括:
所述接收端确定所述接收端不满足所述业务信息对应的传输需求后,向所述第一发送端发送第一控制信息,所述第一控制信息用于表示所述接收端拒绝所述第一发送端的接入。
结合第一方面或第一方面的第一种可能的实现方式,在第一方面的第二种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段,所述接收端判断所述接收端能否满足所述业务信息对应的传输需求包括:
所述接收端根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;
所述接收端判断所述接收端的物理带宽是否大于或等于所述第一速率对应的带宽。
结合第一方面或第一方面的第一种可能的实现方式,在第一方面的第三种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段,所述接收端判断所述接收端能否满足所述业务信息对应的传输需求包括:
所述接收端根据第二时限和所述接收端的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述接收端的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;
所述接收端判断所述第二数据量是否大于或等于所述第一数据量。
结合第一方面或第一方面的第一种可能的实现方式,在第一方面的第四种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段,所述接收端判断所述接收端能否满足所述业务信息对应的传输需求包括:
所述接收端根据所述第一时限和所述接收端的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述接收端的物理带宽的乘积;
所述接收端判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二发送端在所述第一时限内传输的数据的大小。
结合第一方面或第一方面的第一种可能的实现方式,在第一方面的第五种可能的实现方式中,所述业务信息包括第二速率,所述第二速率为所述第一发送端传输数据所需的最小速率,所述接收端判断所述接收端能否满足所述业务信息对应的传输需求包括:
所述接收端判断所述接收端的物理带宽是否大于或等于所述第二速率对应的带宽。
结合第一方面、第一方面的第一种至第一方面的第五种可能的实现方式中的任一种可能的实现方式,在第一方面的第六种可能的实现方式中,所述控制所述第一发送端的数据传输包括:
所述接收端根据所述第一发送端的优先级和所述接收端的物理带宽,为所述第一发送端分配第三速率,所述第三速率为所述第一发送端用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述第三速率。
结合第一方面的第六种可能的实现方式,在第一方面的第七种可能的实现方式中,所述第一发送端的优先级高于第二发送端的优先级,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述方法还包括:
所述接收端向所述第二发送端发送第三控制信息,所述第三控制信息包括所述接收端为所述第二发送端分配的第五速率,所述第五速率小于所述第四速率;或者
所述接收端向所述第二发送端发送第四控制信息,所述第四控制信息用于指示所述第二发送端暂停传输数据。
结合第一方面的第六种可能的实现方式,在第一方面的第八种可能的实现方式中,所述第一发送端的优先级低于第二发送端的优先级,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第三速率小于所述第一发送端传输数据所需的最小速率,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第六速率,所述第六速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第五控制信息,所述第五控制信息包括所述第六速率。
结合第一方面、第一方面的第一种至第一方面的第五种可能的实现方式中的任一种可能的实现方式,在第一方面的第九种可能的实现方式中,所述控制所述第一发送端的数据传输包括:
所述接收端确定所述第一发送端的优先级低于第二发送端的优先级,向所述第一发送端发送第六控制信息,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第六控制信息用于指示所述第一发送端暂停数据传输。
结合第一方面的第九种可能的实现方式,在第一方面的第十种可能的实现方式中,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第七速率,所述第七速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第七控制信息,所述第七控制信息包括所述第七速率。
结合第一方面的第一种可能的实现方式,在第一方面的第十一种可能的实现方式中,所述接收端将所述第一控制信息携带在报文头中的选项option字段中,向所述第一发送端发送携带所述第一控制信息的报文。
结合第一方面的第六种可能的实现方式,在第一方面的第十二种可能的实现方式中,所述接收端将所述第二控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第二控制信息的报文。
结合第一方面的第七种可能的实现方式,在第一方面的第十三种可能的实现方式中,所述接收端将所述第三控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第三控制信息的报文;或者,所述接收端将所述第四控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第四控制信息的报文。
结合第一方面的第八种可能的实现方式,在第一方面的第十四种可能的实现方式中,所述接收端将所述第五控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第五控制信息的报文。
结合第一方面的第九种可能的实现方式,在第一方面的第十五种可能的实现方式中,所述接收端将所述第六控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第六控制信息的报文。
结合第一方面的第十种可能的实现方式,在第一方面的第十六种可能的实现方式中,所述接收端将所述第七控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第七控制信息的报文。
第二方面,提供一种数据接收方法,包括:
接收端接收第一发送端发送的第一数据量,所述第一数据量用于表示所述第一发送端需传输的数据的大小;
所述接收端根据所述第一数据量,控制所述第一发送端的数据传输。
结合第二方面,在第二方面的第一种可能的实现方式中,所述接收端根据所述第一数据量,控制所述第一发送端的数据传输包括:
所述接收端确定所述第一数据量小于第二数据量,向所述第二发送端发送第一控制信息或第三控制信息,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为以第一速率向所述接收端传输数据的发送端,所述第一速率对应的带宽小于或等于所述接收端的物理带宽,所述第一控制信息包括所述接收端为所述第二发送端分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二发送端暂停传输数据;
所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述接收端为所述第一发送端分配的第三速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽。
结合第二方面的第一种可能的实现方式,在第二方面的第二种可能的实现方式中,该方法还包括:
接收端接收第一发送端发送的所述第一发送端允许的最大速率;
其中,所述第三速率小于或等于所述第一发送端允许的最大速率。
结合第二方面,在第二方面的第三种可能的实现方式中,所述接收端根据所述第一数据量,控制所述第一发送端的数据传输包括:
所述接收端确定所述第一数据量大于或等于第二数据量,向所述第一发送端发送第四控制信息或第五控制信息;
其中,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为已向所述接收端传输数据的发送端,所述第四控制信息包括所述接收端为所述第一发送端分配的第四速率,所述第四速率小于所述第一发送端传输数据所需的最小速率,所述第五控制信息用于指示所述第一发送端暂停传输数据。
结合第二方面的第三种可能的实现方式,在第二方面的第四种可能的实现方式中,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第五速率,所述第五速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第六控制信息,所述第六控制信息包括所述第五速率。
结合第二方面的第一种可能的实现方式,在第二方面的第五种可能的实现方式中,所述接收端将所述第一控制信息携带在报文头中的选项options字段中,向所述第二发送端发送携带所述第一控制信息的报文;或者
所述接收端将所述第三控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第三控制信息的报文;或者
所述接收端将所述第二控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第二控制信息的报文。
结合第二方面的第三种可能的实现方式,在第二方面的第六种可能的实现方式中,所述接收端将所述第四控制信息携带在报文头中的选项options字段中,向所述第一发送端发送携带所述第四控制信息的报文;或者
所述接收端将所述第五控制信息携带在报文头中的选项options字段中,向所述第一发送端发送携带所述第五控制信息的报文。
结合第二方面的第四种可能的实现方式,在第二方面的第七种可能的实现方式中,所述接收端将所述第六控制信息携带在报文头中的选项options字段中,向所述第一发送端发送携带所述第六控制信息的报文。
第三方面,提供了一种数据发送方法,包括:
发送端向接收端发送业务信息,所述业务信息用于表示所述发送端所需传输的数据的信息;
所述发送端在所述接收端的控制下进行数据传输。
结合第三方面,在第三方面的第一种可能的实现方式中,还包括:
所述发送端接收来自所述接收端的第一控制信息,所述第一控制信息用于表示所述接收端拒绝所述发送端的接入;
所述发送端根据所述第一控制信息,丢弃所需传输的数据。
结合第三方面或第三方面的第一种可能的实现方式,在第三方面的第二种可能的实现方式中,所述业务信息包括数据量和时限,所述数据量用于表示所述发送端需传输的数据的大小,所述时限用于表示所述发送端传输所述数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述发送端需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述发送端传输数据所需的最小速率。
结合第三方面、第三方面的第一种可能的实现方式、或第三方面的第二种可能的实现方式,在第三方面的第三种可能的实现方式中,所述发送端在所述接收端的控制下进行数据传输包括:
所述发送端接收来自所述接收端的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述接收端为所述发送端分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述接收端的物理带宽;
所述发送端采用所述第二速率,向所述接收端传输数据。
结合第三方面、第三方面的第一种可能的实现方式、或第三方面的第二种可能的实现方式,在第三方面的第四种可能的实现方式中,所述发送端在所述接收端的控制下进行数据传输包括:
所述发送端接收来自所述接收端的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述接收端为所述发送端分配的用于传输数据的速率,所述第三速率小于所述发送端传输数据所需的最小速率;
所述发送端根据所述第三速率,暂停向所述接收端传输数据。
结合第三方面、第三方面的第一种可能的实现方式、或第三方面的第二种可能的实现方式,在第三方面的第五种可能的实现方式中,所述发送端在所述接收端的控制下进行数据传输包括:
所述发送端接收来自所述接收端的第四控制信息,所述第四控制信息用于指示所述发送端暂停数据传输;
所述发送端根据所述第四控制信息,暂停向所述接收端传输数据。
结合第三方面的第四种可能的实现方式、或第三方面的第五种可能的实现方式,在第三方面的第六种可能的实现方式中,还包括:
所述发送端接收来自所述接收端的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述发送端传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述接收端的物理带宽;
所述发送端采用所述第四速率,向所述接收端发送需传输的数据。
结合第三方面,在第三方面的第七种可能的实现方式中,所述发送端将所述业务信息携带在报文头中的选项options字段中,向所述接收端发送携带所述业务信息的报文。
第四方面,提供了一种数据接收设备,包括:
接收模块,用于接收第一数据发送设备发送的业务信息,所述业务信息用于表示所述第一数据发送设备所需传输的数据的信息;
判断模块,用于判断所述数据接收设备能否满足所述业务信息对应的传输需求;
控制模块,用于在所述判断模块确定所述数据接收设备能够满足所述业务信息对应的传输需求后,控制所述第一数据发送设备的数据传输。
结合第四方面,在第四方面的第一种可能的实现方式中,所述控制模块还用于:
在所述判断模块确定所述数据接收设备不满足所述业务信息对应的传输需求后,向所述第一数据发送设备发送第一控制信息,所述第一控制信息用于表示拒绝所述第一数据发送设备的接入。
结合第四方面或第四方面的第一种可能的实现方式,在第四方面的第二种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,则所述判断模块具体用于:
根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述数据接收设备的物理带宽是否大于或等于所述第一速率对应的带宽。
结合第四方面或第四方面的第一种可能的实现方式,在第四方面的第三种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,则所述判断模块具体用于:
根据第二时限和所述数据接收设备的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述第二数据量是否大于或等于所述第一数据量。
结合第四方面或第四方面的第一种可能的实现方式,在第四方面的第四种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,则所述判断模块具体用于:
根据所述第一时限和所述数据接收设备的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述数据接收设备的物理带宽的乘积;
判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二数据发送设备在所述第一时限内传输的数据的大小。
结合第四方面或第四方面的第一种可能的实现方式,在第四方面的第五种可能的实现方式中,所述业务信息包括第二速率,所述第二速率为所述第一数据发送设备传输数据所需的最小速率,则所述判断模块具体用于:
判断所述数据接收设备的物理带宽是否大于或等于所述第二速率对应的带宽。
结合第四方面、第四方面的第一种至第四方面的第五种可能的实现方式中的任一种可能的实现方式,在第四方面的第六种可能的实现方式中,所述控制模块具体用于:
根据所述第一数据发送设备的优先级和所述数据接收设备的物理带宽,为所述第一数据发送设备分配第三速率,所述第三速率为所述第一数据发送设备用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述第三速率。
结合第四方面的第六种可能的实现方式,在第四方面的第七种可能的实现方式中,所述第一数据发送设备的优先级高于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述控制模块还用于:
向所述第二数据发送设备发送第三控制信息,所述第三控制信息包括所述数据接收设备为所述第二数据发送设备分配的第五速率,所述第五速率小于所述第四速率;或者
向所述第二数据发送设备发送第四控制信息,所述第四控制信息用于指示所述第二数据发送设备暂停传输数据。
结合第四方面的第六种可能的实现方式,在第四方面的第八种可能的实现方式中,所述第一数据发送设备的优先级低于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第三速率小于所述第一数据发送设备传输数据所需的最小速率,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第六速率,所述第六速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第五控制信息,所述第五控制信息包括所述第六速率。
结合第四方面、第四方面的第一种至第四方面的第五种可能的实现方式中的任一种可能的实现方式,在第四方面的第九种可能的实现方式中,所述控制模块具体用于:
确定所述第一数据发送设备的优先级低于第二数据发送设备的优先级,向所述第一数据发送设备发送第六控制信息,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第六控制信息用于指示所述第一数据发送设备暂停数据传输。
结合第四方面的第九种可能的实现方式,在第四方面的第十种可能的实现方式中,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第七速率,所述第七速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第七控制信息,所述第七控制信息包括所述第七速率。
结合第四方面的第一种可能的实现方式,在第四方面的第十一种可能的实现方式中,所述控制模块具体用于:
将所述第一控制信息携带在报文头中的选项option字段中,向所述第一数据发送设备发送携带所述第一控制信息的报文。
结合第四方面的第六种可能的实现方式,在第四方面的第十二种可能的实现方式中,所述控制模块具体用于:
将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
结合第四方面的第七种可能的实现方式,在第四方面的第十三种可能的实现方式中,所述控制模块具体用于:
将所述第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文;或者,将所述第四控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第四控制信息的报文。
结合第四方面的第八种可能的实现方式,在第四方面的第十四种可能的实现方式中,所述控制模块具体用于:
将所述第五控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
结合第四方面的第九种可能的实现方式,在第四方面的第十五种可能的实现方式中,所述控制模块具体用于:
将所述第六控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
结合第四方面的第十种可能的实现方式,在第四方面的第十六种可能的实现方式中,所述控制模块具体用于:
将所述第七控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第七控制信息的报文。
第五方面,提供了一种数据接收设备,包括:
接收器,用于接收第一数据发送设备发送的业务信息,所述业务信息用于表示所述第一数据发送设备所需传输的数据的信息;
处理器,用于判断所述数据接收设备能否满足所述业务信息对应的传输需求;在确定所述数据接收设备能够满足所述业务信息对应的传输需求后,控制所述第一数据发送设备的数据传输。
结合第五方面,在第五方面的第一种可能的实现方式中,还包括:
发送器,用于在所述处理器的控制下发送数据;
所述处理器还用于:在确定所述数据接收设备不满足所述业务信息对应的传输需求后,控制所述发送器向所述第一数据发送设备发送第一控制信息,所述第一控制信息用于表示拒绝所述第一数据发送设备的接入。
结合第五方面或第五方面的第一种可能的实现方式,在第五方面的第二种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器用于:
根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述数据接收设备的物理带宽是否大于或等于所述第一速率对应的带宽。
结合第五方面或第五方面的第一种可能的实现方式,在第五方面的第三种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器具体用于:
根据第二时限和所述数据接收设备的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述数据接收设备的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述第二数据量是否大于或等于所述第一数据量。
结合第五方面或第五方面的第一种可能的实现方式,在第五方面的第四种可能的实现方式中,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器具体用于:
根据所述第一时限和所述数据接收设备的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述数据接收设备的物理带宽的乘积;
判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二数据发送设备在所述第一时限内传输的数据的大小。
结合第五方面或第五方面的第一种可能的实现方式,在第五方面的第五种可能的实现方式中,所述业务信息包括第二速率,所述第二速率为所述第一数据发送设备传输数据所需的最小速率,所述处理器具体用于:
判断所述数据接收设备的物理带宽是否大于或等于所述第二速率对应的带宽。
结合第五方面、第五方面的第一种至第五方面的第五种可能的实现方式中的任一种可能的实现方式,在第五方面的第六种可能的实现方式中,所述处理器具体用于:
根据所述第一数据发送设备的优先级和所述数据接收设备的物理带宽,为所述第一数据发送设备分配第三速率,所述第三速率为所述第一数据发送设备用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述第三速率。
结合第五方面的第六种可能的实现方式,在第五方面的第七种可能的实现方式中,若所述第一数据发送设备的优先级高于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述处理器还用于:
控制所述发送器向所述第二数据发送设备发送第三控制信息,所述第三控制信息包括所述处理器为所述第二数据发送设备分配的第五速率,所述第五速率小于所述第四速率;或者
控制所述发送器向所述第二数据发送设备发送第四控制信息,所述第四控制信息用于指示所述第二数据发送设备暂停传输数据。
结合第五方面的第六种可能的实现方式,在第五方面的第八种可能的实现方式中,若所述第一数据发送设备的优先级低于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第三速率小于所述第一数据发送设备传输数据所需的最小速率,所述处理器还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第六速率,所述第六速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器向所述第一数据发送设备发送第五控制信息,所述第五控制信息包括所述第六速率。
结合第五方面、第五方面的第一种至第五方面的第五种可能的实现方式中的任一种可能的实现方式,在第五方面的第九种可能的实现方式中,所述处理器具体用于:
确定所述第一数据发送设备的优先级低于第二数据发送设备的优先级,控制所述发送器向所述第一数据发送设备发送第六控制信息,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第六控制信息用于指示所述第一数据发送设备暂停数据传输。
结合第五方面的第九种可能的实现方式,在第五方面的第十种可能的实现方式中,所述处理器还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第七速率,所述第七速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器向所述第一数据发送设备发送第七控制信息,所述第七控制信息包括所述第七速率。
结合第五方面的第一种可能的实现方式,在第五方面的第十一种可能的实现方式中,所述处理器具体用于:
将所述第一控制信息携带在报文头中的选项option字段中,控制所述发送器向所述第一数据发送设备发送携带所述第一控制信息的报文。
结合第五方面的第六种可能的实现方式,在第五方面的第十二种可能的实现方式中,所述处理器具体用于:
将所述第二控制信息携带在报文头中的options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第二控制信息的报文。
结合第五方面的第七种可能的实现方式,在第五方面的第十三种可能的实现方式中,所述处理器具体用于:
将所述第三控制信息携带在报文头中的options字段中,控制所述发送器向所述第二数据发送设备发送携带所述第三控制信息的报文;或者,所述第四控制信息携带在报文头中的options字段中,控制所述发送器向所述第二数据发送设备发送携带所述第四控制信息的报文。
结合第五方面的第八种可能的实现方式,在第五方面的第十四种可能的实现方式中,所述处理器具体用于:
将所述第五控制信息携带在报文头中的options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第五控制信息的报文。
结合第五方面的第九种可能的实现方式,在第五方面的第十五种可能的实现方式中,所述处理器具体用于:
将所述第六控制信息携带在报文头中的options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第六控制信息的报文。
结合第五方面的第十种可能的实现方式,在第五方面的第十六种可能的实现方式中,所述处理器具体用于:
将所述第七控制信息携带在报文头中的options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第七控制信息的报文。
第六方面,提供了一种数据接收设备,包括:
接收模块,用于接收第一数据发送设备发送的第一数据量,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小;
控制模块,用于根据所述第一数据量,控制所述第一数据发送设备的数据传输。
结合第六方面,在第六方面的第一种可能的实现方式中,所述控制模块具体用于:
确定所述第一数据量小于第二数据量,向所述第二数据发送设备发送第一控制信息或第三控制信息,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为以第一速率向所述数据接收设备传输数据的数据发送设备,所述第一速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第一控制信息包括所述控制模块为所述第二数据发送设备分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二数据发送设备暂停传输数据;
向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述控制模块为所述第一数据发送设备分配的第三速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽。
结合第六方面的第一种可能的实现方式,在第六方面的第二种可能的实现方式中,所述接收模块还用于:
接收第一数据发送设备发送的所述第一数据发送设备允许的最大速率;
其中,所述第三速率小于或等于所述第一数据发送设备允许的最大速率。
结合第六方面,在第六方面的第三种可能的实现方式中,所述控制模块具体用于:
确定所述第一数据量大于或等于第二数据量,向所述第一数据发送设备发送第四控制信息或第五控制信息;
其中,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为已向所述数据接收设备传输数据的数据发送设备,所述第四控制信息包括所述控制模块为所述第一数据发送设备分配的第四速率,所述第四速率小于所述第一数据发送设备传输数据所需的最小速率,所述第五控制信息用于指示所述第一数据发送设备暂停传输数据。
结合第六方面的第三种可能的实现方式,在第六方面的第四种可能的实现方式中,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第五速率,所述第五速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第六控制信息,所述第六控制信息包括所述第五速率。
结合第六方面的第一种可能的实现方式,在第六方面的第五种可能的实现方式中,所述控制模块具体用于:
将所述第一控制信息携带在报文头中的选项options字段中,向所述第二数据发送设备发送携带所述第一控制信息的报文;或者
将所述第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文;或者
将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
结合第六方面的第三种可能的实现方式,在第六方面的第六种可能的实现方式中,所述控制模块具体用于:
将所述第四控制信息携带在报文头中的选项options字段中,向所述第一数据发送设备发送携带所述第四控制信息的报文;或者
将所述第五控制信息携带在报文头中的选项options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
结合第六方面的第四种可能的实现方式,在第六方面的第七种可能的实现方式中,所述控制模块具体用于:
将所述第六控制信息携带在报文头中的选项options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
第七方面,提供了一种数据接收设备,包括:
接收器,用于接收第一数据发送设备发送的第一数据量,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小;
处理器,用于根据所述第一数据量,控制所述第一数据发送设备的数据传输。
结合第七方面,在第七方面的第一种可能的实现方式中,所述数据接收设备还包括:
发送器,用于在所述处理器的控制下发送数据;
所述处理器具体用于:
确定所述第一数据量小于第二数据量,控制所述发送器向所述第二数据发送设备发送第一控制信息或第三控制信息,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为以第一速率向所述数据接收设备传输数据的数据发送设备,所述第一速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第一控制信息包括所述处理器为所述第二数据发送设备分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二数据发送设备暂停传输数据;
控制所述发送器向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述处理器为所述第一数据发送设备分配的第三速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽。
结合第七方面的第一种可能的实现方式,在第七方面的第二种可能的实现方式中,所述接收器还用于:接收所述第一数据发送设备发送的所述第一数据发送设备允许的最大速率;其中,所述第三速率小于或等于所述第一数据发送设备允许的最大速率。
结合第七方面,在第七方面的第三种可能的实现方式中,所述数据接收设备还包括:
发送器,用于在所述处理器的控制下发送数据;
所述处理器具体用于:
确定所述第一数据量大于或等于第二数据量,控制所述发送器向所述第一数据发送设备发送第四控制信息或第五控制信息;
其中,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为已向所述数据接收设备传输数据的数据发送设备,所述第四控制信息包括所述处理器为所述第一数据发送设备分配的第四速率,所述第四速率小于所述第一数据发送设备传输数据所需的最小速率,所述第五控制信息用于指示所述第一数据发送设备暂停传输数据。
结合第七方面的第三种可能的实现方式,在第七方面的第四种可能的实现方式中,所述数据接收设备还包括:
发送器,用于在所述处理器的控制下发送数据;
所述处理器还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第五速率,所述第五速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器向所述第一数据发送设备发送第六控制信息,所述第六控制信息包括所述第五速率。
结合第七方面的第一种可能的实现方式,在第七方面的第五种可能的实现方式中,所述处理器具体用于:
将所述第一控制信息携带在报文头中的选项options字段中,控制所述发送器向所述第二数据发送设备发送携带所述第一控制信息的报文;或者
将所述第三控制信息携带在报文头中的options字段中,控制所述发送器向所述第二数据发送设备发送携带所述第三控制信息的报文;或者
将所述第二控制信息携带在报文头中的options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第二控制信息的报文。
结合第七方面的第三种可能的实现方式,在第七方面的第六种可能的实现方式中,所述处理器具体用于:
将所述第四控制信息携带在报文头中的选项options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第四控制信息的报文;或者
将所述第五控制信息携带在报文头中的选项options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第五控制信息的报文。
结合第七方面的第四种可能的实现方式,在第七方面的第七种可能的实现方式中,所述处理器具体用于:
将所述第六控制信息携带在报文头中的选项options字段中,控制所述发送器向所述第一数据发送设备发送携带所述第六控制信息的报文。
第八方面,提供了一种数据发送设备,包括:
发送模块,用于向数据接收设备发送业务信息,所述业务信息用于表示所述数据发送设备所需传输的数据的信息;
数据传输模块,用于在所述数据接收设备的控制下进行数据传输。
结合第八方面,在第八方面的第一种可能的实现方式中,所述数据传输模块具体用于:
接收来自所述数据接收设备的第一控制信息,所述第一控制信息用于表示所述数据接收设备拒绝所述数据发送设备的接入;根据所述第一控制信息,丢弃所需传输的数据。
结合第八方面或第八方面的第一种可能的实现方式,在第八方面的第二种可能的实现方式中,所述业务信息包括数据量和时限,所述数据量用于表示所述数据发送设备需传输的数据的大小,所述时限用于表示所述数据发送设备传输所述数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述数据发送设备需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述数据发送设备传输数据所需的最小速率。
结合第八方面、第八方面的第一种可能的实现方式、或第八方面的第二种可能的实现方式,在第八方面的第三种可能的实现方式中,所述数据传输模块具体用于:
接收来自所述数据接收设备的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述数据接收设备的物理带宽;采用所述第二速率,向所述数据接收设备传输数据。
结合第八方面、第八方面的第一种可能的实现方式、或第八方面的第二种可能的实现方式,在第八方面的第四种可能的实现方式中,所述数据传输模块具体用于:
接收来自所述数据接收设备的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第三速率小于所述数据发送设备传输数据所需的最小速率;根据所述第三速率,暂停向所述数据接收设备传输数据。
结合第八方面、第八方面的第一种可能的实现方式、或第八方面的第二种可能的实现方式,在第八方面的第五种可能的实现方式中,所述数据传输模块具体用于:
接收来自所述数据接收设备的第四控制信息,所述第四控制信息用于指示所述数据发送设备暂停数据传输;根据所述第四控制信息,暂停向所述数据接收设备传输数据。
结合第八方面的第四种可能的实现方式、或第八方面的第五种可能的实现方式,在第八方面的第六种可能的实现方式中,所述数据传输模块还用于:
接收来自所述数据接收设备的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述数据发送设备传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽;采用所述第四速率,向所述数据接收设备发送需传输的数据。
结合第八方面,在第八方面的第七种可能的实现方式中,所述发送模块具体用于:
将所述业务信息携带在报文头中的选项options字段中,向所述数据接收设备发送携带所述业务信息的报文。
第九方面,提供了一种数据发送设备,包括:
发送器,用于向数据接收设备发送业务信息,所述业务信息用于表示所述数据发送设备所需传输的数据的信息;
接收器,用于接收来自所述数据接收设备的信息;
处理器,用于在所述数据接收设备的控制下进行数据传输。
结合第九方面,在第九方面的第一种可能的实现方式中,接收器具体用于:接收来自所述数据接收设备的第一控制信息,所述第一控制信息用于表示所述数据接收设备拒绝所述数据发送设备的接入;
处理器具体用于:根据所述第一控制信息,丢弃所需传输的数据。
结合第九方面或第九方面的第一种可能的实现方式,在第九方面的第二种可能的实现方式中,所述业务信息包括数据量和时限,所述数据量用于表示所述数据发送设备需传输的数据的大小,所述时限用于表示所述数据发送设备传输所述数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述数据发送设备需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述数据发送设备传输数据所需的最小速率。
结合第九方面、第九方面的第一种可能的实现方式、或第九方面的第二种可能的实现方式,在第九方面的第三种可能的实现方式中,所述接收器具体用于:接收来自所述数据接收设备的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述数据接收设备的物理带宽;
所述处理器具体用于:控制所述发送器采用所述第二速率,向所述数据接收设备传输数据。
结合第九方面、第九方面的第一种可能的实现方式、或第九方面的第二种可能的实现方式,在第九方面的第四种可能的实现方式中,所述接收器具体用于:接收来自所述数据接收设备的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第三速率小于所述数据传输模块传输数据所需的最小速率;
所述处理器具体用于:根据所述第三速率,控制所述发送器暂停向所述数据接收设备传输数据。
结合第九方面、第九方面的第一种可能的实现方式、或第九方面的第二种可能的实现方式,在第九方面的第五种可能的实现方式中,所述接收器具体用于:接收来自所述数据接收设备的第四控制信息,所述该第四控制信息用于指示所述数据发送设备暂停数据传输;
处理器具体用于:根据所述第四控制信息,控制发送器暂停向所述数据接收设备传输数据。
结合第九方面的第四种可能的实现方式、或第九方面的第五种可能的实现方式,在第九方面的第六种可能的实现方式中,所述接收器具体用于:接收来自所述数据接收设备的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述数据发送设备传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽;
所述处理器还用于:控制所述发送器采用所述第四速率,向所述数据接收设备发送需传输的数据。
结合第九方面,在第九方面的第七种可能的实现方式中,所述处理器具体用于:
将所述业务信息携带在报文头中的选项options字段中,控制所述发送器向所述数据接收设备发送携带所述业务信息的报文。
本发明实施例提供的方法和设备中,在接收端对第一发送端的接入控制和/或数据传输的控制,从而避免了由于需要在最短时间内接收完多个发送端的数据,而导致的接收端的缓冲区溢出的问题。
附图说明
图1为数据中心中的many-to-one通信模式示意图;
图2为本发明提供的第一种数据接收方法的示意图;
图3A为TCP报文头中的options字段的第一种结构图;
图3B为TCP报文头中的options字段的第二种结构图;
图4A为IPV4报文头中的options字段的第一种结构图;
图4B为IPV4报文头中的options字段的第二种结构图;
图5为本发明提供的第二种数据接收方法的示意图;
图6为本发明提供的第一种数据发送方法的示意图;
图7为本发明提供的实施例一的交互示意图;
图8为本发明提供的实施例二的交互示意图;
图9为本发明提供的实施例三的交互示意图;
图10为本发明提供的第一种数据接收设备的示意图;
图11为本发明提供的第二种数据接收设备的示意图;
图12为本发明提供的第三种数据接收设备的示意图;
图13为本发明提供的第四种数据接收设备的示意图;
图14为本发明提供的第一种数据发送设备的示意图;
图15为本发明提供的第二种数据发送设备的示意图。
具体实施方式
下面结合说明书附图对本发明实施例作进一步详细描述。应当理解,此处所描述的实施例仅用于说明和解释本发明,并不用于限定本发明。
基于传输控制协议(Transmission Control Protocol,TCP)的聚播拥塞控制(Incast Congestion Control for TCP,ICTCP),是基于TCP确认(Acknowledgement,ACK)的接收窗口,来控制发送者的发送速率,从而可以在接收端协调各发送端的数据发送。但是,ICTCP存在如下不足:
1、由于ICTCP采用公平调度的方式,没有实现对尾延时(tail latency)的优化。
2、接收端若要停止某个发送端的数据传输,可以将接收窗口为0。该发送端只能在持续定时器(persist timer)超时后才能继续发送已暂停的数据。由于超时时间一般都在秒级,这样会导致更大的延时。
3、接收端无法实现对发送端的接入控制。
为了解决上述问题,本发明实施例提供了一种数据接收方法,该方法中,接收端接收第一发送端发送的业务信息,所述业务信息用于表示所述第一发送端所需传输的数据的信息;所述接收端判断所述接收端能否满足所述业务信息对应的传输需求;所述接收端确定所述接收端能够满足所述业务信息对应的传输需求后,控制所述第一发送端的数据传输。在本发明另一实施例中,接收端接收第一发送端发送的第一数据量,所述第一数据量用于表示所述第一发送端需传输的数据的大小;所述接收端根据所述第一数据量,控制所述第一发送端的数据传输。本发明实施例提供的方法中,接收端能够根据来自发送端的业务信息或来自发送端的数据量,控制发送端的接入以及数据传输,有助于解决接收端需要在短时间内接收至少两个发送端的数据而产生的拥塞或丢包的问题,有助于提高数据传输的稳定性。
图2对应的实施例是从接收端的角度,对本发明实施例提供的一种数据接收方法进行说明。如图2所示,该方法包括:
S21、接收端接收第一发送端发送的业务信息,所述业务信息用于表示所述第一发送端所需传输的数据的信息;
其中,所述第一发送端为需要向所述接收端传输数据的多个发送端中的任意一个。
S22、所述接收端判断所述接收端能否所述满足业务信息对应的传输需求;
S23、所述接收端确定所述接收端能够满足所述业务信息对应的传输需求后,控制所述第一发送端的数据传输。
本发明提供的该实施例实现了在接收端对第一发送端的接入控制以及数据传输的控制,从而避免了由于需要在最短时间内接收完多个发送端的数据,而导致的接收端的缓冲区溢出的问题。
本发明实施例提供的方法可用于采用many-to-one通信模式进行数据传输的数据中心,还可用于其他采用many-to-one通信模式的网络场景中,在此不再逐一举例说明。
作为另一种实现方式,本发明实施例提供的方法还包括:
所述接收端确定所述接收端不满足所述业务信息对应的传输需求后,向所述第一发送端发送第一控制信息,第一控制信息用于表示所述接收端拒绝所述第一发送端的接入。
举例说明,所述接收端将所述第一控制信息携带在报文头中的选项(option)字段中,向所述第一发送端发送了携带所述第一控制信息的报文。
需要说明的是,若因特网协议(Internet Protocol,IP)报文采用TCP协议,则所述接收端可以将所述第一控制信息携带在ACK报文的报文头中的options字段中,比如TCP报文头(header)中的options字段或IP header中的options字段,将携带了所述第一控制信息的ACK报文发送给所述第一发送端。若IP报文采用用户数据报协议(User DatagramProtocol,UDP),由于UDP没有ACK报文,则所述接收端可以将所述第一控制信息携带在定义的控制报文的IP header,如IPV4 header,中的options字段中,将携带了所述第一控制信息的控制报文发给所述第一发送端。当然,除了可以扩展报文头中的options字段携带所述第一控制信息之外,还可以定义新的控制信令用于专门携带所述第一控制信息。
举例说明,通过扩展TCP header中的options字段携带所述第一控制信息。options字段可包括至少一个option。其中,option data可用于表示options字段中的一个option的数据,option kind可用于表示options字段中的一个option的种类,optionlength可用于表示options字段中的一个option的长度。TCP header中options字段的一个option的具体结构包括以下两种:
当该option不包括option data时,该option占用一个字节(8bits),该字节表示option kind,如图3A所示。
当该option包括option data时,该option包括option kind、option length和option data,如图3B所示。其中,option kind和option length可分别占用一个字节(8bits)。
在对TCP header中的options字段进行扩展时,option kind所携带的数值可用于表示option data中携带的数据的类型。比如:若option kind为第一数值,所述第一数值用于表示第一数据量,则option data携带的数据为所述第一数据量的具体数值,比如2M。若option kind为第二数值,所述第二数值用于表示第一时限,则option data携带的数据为所述第一时限的具体数值,比如2s。若option kind为第三数值,所述第三数值用于表示第二速率,所述第二速率为所述第一发送端传输数据所需的最小速率,则option data携带的数据为所述第二速率的具体数值,比如2Mbps。其中,所述第一数值、所述第二数值和所述第三数值中的“第一”、“第二”和“第三”用于区分不同的数值,不用于表示先后顺序。
举例说明,通过扩展IPV4 header中的options字段携带第一控制信息。options字段可包括至少一个option。其中,option data可用于表示options字段中的一个option的数据,option type可用于表示options字段中的一个option的类型,option length可用于表示options字段中的一个option的长度。option type又包含三个域:复制标记(copiedflag),type class和type number。其中,type class用于表示该option type的等级;typenumber用于表示该option type的标号。IPV4 header中options字段的一个option的具体结构包括以下两种:
当该option不包括option data时,该option占用一个字节(8bits),该字节表示option type,如图4A所示;
当该option不包括option data时,该option包括option type,option length和option data,如图4B所示。其中,option type和option-length可分别占用8bits。copiedflag可占用1bit,type class可占用2bits,type number可占用5bits。
在对IPV4 header中的options字段进行扩展时,type number所携带的数值可用于表示option data中携带的数据的类型。比如:若type number为第一数值,所述第一数值用于表示第一数据量,则option data携带的数据为所述第一数据量的具体数值,比如2M。若type number为第二数值,所述第二数值用于表示第一时限,则option data携带的数据为所述第一时限的具体数值,比如2s。若type number为第三数值,所述第三数值用于表示第二速率,所述第二速率为所述第一发送端传输数据所需的最小速率,则option data携带的数据为所述第二速率的具体数值,比如2Mbps。其中,所述第一数值、所述第二数值和所述第三数值中的“第一”、“第二”和“第三”用于区分不同的数值,不用于表示先后顺序。
在实施中,所述业务信息可包括第一数据量和第一时限。其中,所述第一数据量用于表示第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段。所述第一时限也可以为截至时限(deadline),即用于表示所述第一发送端希望在所述第一时限对应的时长内完成所述第一数据量的数据传输。
若本发明实施例中的业务信息包括第一数据量和第一时限,则S22中所述接收端判断所述接收端能否满足所述业务信息对应的传输需求可以为以下三种方式:
方式1包括:所述接收端根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值;所述接收端判断所述接收端的物理带宽是否大于或等于所述第一速率对应的带宽;其中,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段。
举例说明,所述第二发送端为已接入所述接收端且以所述接收端为其分配的速率向所述接收端传输数据的发送端。所述接收端接收到来自所述第一发送的业务信息之前或同时,所述第二发送端可以向所述接收端传输数据。所述第二发送端被分配的速率对应的带宽可以小于或等于所述接收端的物理带宽,即所述接收端在所述第二发送端传输数据的时间段内的可提供其他发送端使用的带宽接近0。这样,所述第三时限的数值为从所述接收端接收到来自所述第一发送端的业务信息的时刻起算到所述第二发送端完成数据传输的时刻为止的时间段。或者,所述第三时限的数值为从所述第一发送端向所述接收端发送业务信息的时刻起算到所述第二发送端完成数据传输的时刻为止的时间段。
具体的,若所述接收端判断自身的物理带宽大于或等于所述第一速率对应的带宽,则所述接收端确定自身能够满足所述业务信息对应的传输需求;若所述接收端判断自身的物理带宽小于所述第一速率对应的带宽,则所述接收端确定自身不满足所述业务信息对应的传输需求。
方式2包括:所述接收端根据第二时限和自身的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述接收端的物理带宽的乘积;所述接收端判断所述第二数据量是否大于或等于所述第一数据量;其中,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段。
举例说明,所述第二发送端的含义和所述第三时限的含义与方式1中的相应内容相同,在此不再赘述。所述第二数据量用于表示所述接收端在所述第二时限内能够接收的最大数据量。
具体的,若所述接收端判断所述第二数据量大于或等于所述第一数据量,则所述接收端确定自身能够满足所述业务信息对应的传输需求;若所述接收端判断所述第二数据量小于所述第一数据量,则所述接收端确定自身不满足所述业务信息对应的传输需求。
方式3包括:所述接收端根据所述第一时限和所述接收端的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述接收端的物理带宽的乘积;所述接收端判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二发送端在所述第一时限内传输的数据的大小。
举例说明,所述第二发送端的含义与方式1中的相应内容相同。所述第五数据量的数值是所述第二发送端需要完成的数据量与所述接收端接收来自所述第一发送端的业务信息之前已经传输的数据量的差值。换句话说,所述第五数据量的数值为所述第二发送端在所述第一时限内仍需向所述接收端传输的数据大小。
具体的,若所述接收端判断所述第四数据量大于或等于所述第一数据量,则所述接收端确定自身能够满足所述业务信息对应的传输需求;若所述接收端判断所述第四数据量小于所述第一数据量,则所述接收端确定自身不满足所述业务信息对应的传输需求。
若本发明实施例中的业务信息包括第二速率,所述第二速率为所述第一发送端传输数据所需的最小速率,则S22中所述接收端判断该接收端能否满足所述业务信息对应的传输需求包括:所述接收端判断所述接收端的物理带宽是否大于或等于所述第二速率对应的带宽。
举例说明,所述第一发送端可以根据所述第一数据量和所述第一时限,计算获得所述第二速率。或者所述第一发送端可以被预先配置一个传输数据所需的最小速率。在此不再对其他可能的实现方式进行逐一举例说明。所述第一数据量用于表示所述第一发送端需传输的数据的大小。所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段。
具体的,若所述接收端判断自身的物理带宽大于或等于所述第二速率对应的带宽,则所述接收端确定自身能够满足所述业务信息对应的传输需求;若所述接收端判断自身的物理带宽小于所述第二速率对应的带宽,则所述接收端确定自身不满足所述业务信息对应的传输需求。
基于上述任意一种方式或实施例,S23中,控制所述第一发送端的数据传输可采用以下两种方式:
方式A
所述接收端控制所述第一发送端的数据传输包括:所述接收端根据所述第一发送端的优先级和该接收端的物理带宽,为所述第一发送端分配第三速率,所述第三速率为所述第一发送端用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽;所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述第三速率。
举例说明,所述接收端可将所述第二控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第二控制信息的报文。
方式A进一步包括以下两种情况:
情况1:所述第一发送端的优先级高于第二发送端的优先级,其中,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽。即所述接收端接收到来自所述第一发送端的业务信息之前或同时,所述第二发送端已经以所述第四速率向所述接收端传输数据。
对于情况1,S23之后,本发明实施例提供的方法还包括:
所述接收端向所述第二发送端发送第三控制信息,所述第三控制信息包括所述接收端为所述第二发送端分配的第五速率,所述第五速率小于所述第四速率;或者
所述接收端向所述第二发送端发送第四控制信息,所述第四控制信息用于指示所述第二发送端暂停传输数据。
具体的,由于所述第一发送端的优先级高于所述第二发送端的优先级,因此,所述接收端可以重新为所述第二发送端分配速率,比如降低为所述第二发送端分配的速率,以优先满足所述第一发送端的传输需求。所述接收端为所述第二发送端重新分配的第五速率小于所述接收端之前为所述第二发送端分配的第四速率,以降低所述第二发送端传输数据所采用的速率。如果所述第五速率为0,相当于所述接收端指示所述第二发送端暂停传输数据。
举例说明,所述接收端将所述第三控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第三控制信息的报文。或者,所述接收端将所述第四控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第四控制信息的报文。
情况2:所述第一发送端的优先级低于第二发送端的优先级,其中,第二发送端为以第四速率向接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第三速率小于所述第一发送端传输数据所需的最小速率。
情况2中,为了优先满足所述第二发送端的传输需求,所述接收端为所述第一发送端分配的第三速率小于该第一发送端传输数据所需的最小速率,以指示所述第一发送端暂停传输数据。其中,所述第三速率的数值可以为0。
对于情况2,S23之后,本发明实施例提供的方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第六速率,所述第六速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第五控制信息,所述第五控制信息包括所述第六速率。
举例说明,所述接收端将所述第五控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第五控制信息的报文。
举例说明,所述第一发送端的优先级和所述第二发送端的优先级可以根据所述第一发送端的第一时限和所述第二发送端的时限来确定。所述第二发送端的时限是所述第二发送端传输数据量所需的时长。所述第二发送端的时限可携带在所述第二发送端发送给所述接收端的业务信息中。如果所述第一时限比所述第二发送端的时限短,则所述第一发送端的优先级高于所述第二发送端的优先级;如果所述第一时限比所述第二发送端的时限长,则所述第一发送端的优先级低于所述第二发送端的优先级;如果所述第一时限与所述第二发送端的时限相同,则所述第一发送端的优先级与所述第二发送端的优先级相同。
举例说明,发送端的优先级还可根据在所述第一时限对应的时间段内实际完成数据传输的时限来确定。比如所述第一发送端未被分配速率,则在所述第一时限对应的时间段内,所述第一发送端实际完成数据传输的时限是根据所述接收端的物理带宽预估出来的数值,即所述第一发送端发送的第一数据量和所述接收端的物理带宽的商。所述第二发送端已被分配了速率,则在所述第一时限对应的时间段内,所述第二发送端实际完成数据传输的时限是所述第二发送端在所述第一时限内待传输的数据量和所述第二发送端被分配的速率的商。如果在所述第一时限对应的时间段内,所述第一发送端实际完成数据传输的时限小于所述第二发送端实际完成数据传输的时限,则所述第一发送端的优先级高于所述第二发送端的优先级。如果在所述第一时限对应的时间段内,所述第一发送端实际完成数据传输的时限大于所述第二发送端实际完成数据传输的时限,则所述第一发送端的优先级低于所述第二发送端的优先级。如果在所述第一时限对应的时间段内,所述第一发送端实际完成数据传输的时限等于所述第二发送端实际完成数据传输的时限,则所述第一发送端的优先级与所述第二发送端的优先级相同。当然,本发明不限于采用上述两种方法确定发送端的优先级。
方式B
所述接收端控制所述第一发送端的数据传输包括:所述接收端确定所述第一发送端的优先级低于第二发送端的优先级,向所述第一发送端发送第六控制信息,所述第二发送端为以第四速率向接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第六控制信息用于指示所述第一发送端暂停数据传输。
举例说明,所述接收端将所述第六控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第六控制信息的报文。
对于方式B,S23之后,本发明实施例提供的方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第七速率,所述第七速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第七控制信息,所述第七控制信息包括所述第七速率。
举例说明,所述接收端将所述第七控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第七控制信息的报文。
基于同一发明构思,本发明实施例还提供了另一种数据接收方法。图5对应的实施例是从接收端的角度,对本发明实施例提供的另一种数据接收方法进行说明。如图5所示,该方法包括:
S51、接收端接收第一发送端发送的第一数据量,所述第一数据量用于表示所述第一发送端需传输的数据的大小;
S52、所述接收端根据所述第一数据量,控制所述第一发送端的数据传输。
本发明实施例中,接收端根据接收到的第一发送端发送的第一数据量,优先满足第一发送端和第二发送端中需要传输数据量较小的发送端的传输需求,或者优先满足第一发送端和第二发送端中预估传输时间较小的发送端的传输需求,从而实现了在接收端对发送端的数据传输的控制,避免了由于需要在最短时间内接收完多个发送端的数据,而导致的接收端的缓冲区溢出的问题。
该实施中,S52中所述接收端根据所述第一数据量,控制所述第一发送端的数据传输可采用以下两种方式:
方式1包括:所述接收端确定所述第一数据量小于第二数据量,向所述第二发送端发送第一控制信息或第三控制信息,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为以第一速率向所述接收端传输数据的发送端,所述第一速率对应的带宽小于或等于所述接收端的物理带宽,所述第一控制信息包括所述接收端为所述第二发送端分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二发送端暂停传输数据;所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述接收端为所述第一发送端分配的第三速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽。
举例说明,所述第二数据量的数值是所述接收端接到来自所述第一发送端发送的第一数据量的时刻起算第二发送端需要传输但仍未完成传输的数据的大小。所述第二发送端是所述接收端接收到来自所述第一发送端发送的第一数据量的时刻之前或同时,已经向所述接收端传输数据的发送端。
具体的,为了实现较短的传输时延,如果所述第一数据量小于所述第二数据量,则所述接收端可优先满足所述第一发送端的传输需求,所述接收端重新为已接入且以第一速率向接收端传输数据的第二发送端分配第二速率,且所述第二速率小于所述第一速率。如果所述第二速率的数值为0,则数值为0的第二速率用于表示所述接收端指示所述第二发送端暂停传输数据。
可选地,S52之前,本发明实施例提供的方法还包括:所述接收端接收所述第一发送端发送的该第一发送端允许的最大速率;所述接收端为所述第一发送端分配的第三速率小于或等于所述第一发送端允许的最大速率。
具体的,若所述接收端接收所述第一发送端发送的该第一发送端允许的最大速率,则所述接收端为所述第一发送端分配的第三速率需要小于或等于所述第一发送端允许的最大速率。比如:若所述接收端的物理带宽大于所述第一发送端允许的最大速率对应的带宽,则所述接收端为所述第一发送端分配的第三速率小于或等于所述第一发送端允许的最大速率。若所述接收端的物理带宽小于或等于所述第一发送端允许的最大速率,则所述接收端为所述第一发送端分配的第三速率对应的带宽小于或等于所述接收端的物理带宽。可选地,所述第一发送端允许的最大速率和所述第一数据量携带在同一信令中发送给接收端。
举例说明,所述接收端将所述第一控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第一控制信息的报文。所述接收端将所述第三控制信息携带在报文头中的options字段中,向所述第二发送端发送携带所述第三控制信息的报文。所述接收端可将所述第二控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第二控制信息的报文。
方式2包括:所述接收端确定所述第一数据量大于或等于第二数据量,向所述第一发送端发送第四控制信息或第五控制信息;其中,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为已向所述接收端传输数据的发送端,所述第四控制信息包括所述接收端为所述第一发送端分配的第四速率,所述第四速率小于所述第一发送端传输数据所需的最小速率,所述第五控制信息用于指示所述第一发送端暂停传输数据。
举例说明,如果所述第四速率的数值为0,则数值为0的第四速率用于表示所述接收端指示所述第一发送端暂停传输数据。所述接收端将所述第四控制信息携带在报文头中的options字段中,向所述第一发送端发送携带所述第四控制信息的报文。所述接收端将所述第五控制信息携带在报文头中的options字段中,向所述第一发送端发送携带第五控制信息的报文。
对于方式2,S52之后,本发明实施例提供的方法还包括:所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第五速率,所述第五速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述接收端的物理带宽;所述接收端向所述第一发送端发送第六控制信息,所述第六控制信息包括所述第五速率。
图6对应的实施例是从发送端的角度,对本发明实施例提供的一种数据发送方法进行说明。图6对应的实施例中提及的接收端可执行图2对应的实施例提供的方法,即图6对应的实施例中提及的接收端可以与图2对应的实施例中的接收端相同。如图6所示,该方法包括:
S61、发送端向接收端发送业务信息,所述业务信息用于表示所述发送端所需传输的数据的信息;
S62、所述发送端在所述接收端的控制下进行数据传输。
本发明实施例中,发送端向接收端发送业务信息,以使接收端根据业务信息控制该发送端的数据传输,从而实现了在接收端对第一发送端的数据传输的控制,避免了由于需要在最短时间内接收完多个发送端的数据,而导致的接收端的缓冲区溢出的问题。
举例说明,所述发送端将所述业务信息携带在报文头中的options字段中,向所述接收端发送携带所述业务信息的报文。
可选地,本发明实施例提供的方法还包括:所述发送端接收来自所述接收端的第一控制信息,所述第一控制信息用于表示所述接收端拒绝所述发送端的接入;所述发送端根据所述第一控制信息,丢弃所需传输的数据。
本发明实施例中,所述业务信息包括数据量和时限,所述数据量用于表示所述发送端需传输的数据的大小,所述时限用于表示所述发送端传输该数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述发送端需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述发送端传输数据所需的最小速率。
基于上述任一实施例,S62中,所述发送端在所述接收端的控制下进行数据传输可采用以下三种方式:
方式一包括:所述发送端接收来自所述接收端的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述接收端为所述发送端分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述接收端的物理带宽;所述发送端采用所述第二速率,向所述接收端传输数据。
方式二包括:所述发送端接收来自所述接收端的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述接收端为所述发送端分配的用于传输数据的速率,所述第三速率小于所述发送端传输数据所需的最小速率;所述发送端根据所述第三速率,暂停向所述接收端传输数据。其中,所述第三速率的数值可以为0。
方式三包括:所述发送端接收来自所述接收端的第四控制信息,所述第四控制信息用于指示所述发送端暂停数据传输;所述发送端根据所述第四控制信息,暂停向所述接收端传输数据。
基于上述方式二或方式三,S62之后,本发明实施例提供的方法还包括:所述发送端接收来自所述接收端的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述发送端传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述接收端的物理带宽;所述发送端采用所述第四速率,向所述接收端发送需传输的数据。
下面通过以下具体实施例,从接收端与发送端之间的交互过程,来说明本发明实施例提供的数据传输方法。
实施例一、假设发送端的数据量大小(size)为13MB,deadline要求为1ms,但接收端的最大带宽为1Gbps,可见,所述接收端无法满足所述发送端的服务质量(Quality ofService,QoS)需求,即所述接收端无法满足所述发送端的deadline的要求,此时,所述接收端向所述发送端发送第一控制信息,如发送拒绝(deny)消息,以拒绝所述发送端接入。所述接收端和所述发送端之间的交互过程如图7所示,包括:
701,所述发送端向所述接收端发送业务信息,所述业务信息包括数值为13M的数据量和数值为1ms的时限。
702,所述接收端确定自身无法满足所述发送端的QoS需求,向所述发送端返回DENY,以拒绝所述发送端接入。
实施例二、假设发送端B的数据量size为2MB,deadline要求为5ms,接收端的最大带宽为1Gbps,所述接收端可以满足所述发送端B的QoS需求,即所述接收端可以满足所述发送端B的deadline要求,但由于已接入的发送端A(图8中未示出)能够实现更优的taillatency,需要暂停所述发送端B的数据传输。更优的tail latency可以是完成所述发送端A的数据传输和完成所述发送端B的数据传输所耗费的平均时间,比如:所述发送端A占用了所述接收端的物理带宽,所述发送端A在传输数据的过程中,所述发送端B处于暂停等待传输数据的状态,则完成所述发送端A的数据传输所耗费的时长是所述发送端A从所述接收端接收到所述发送端B的业务信息的时刻开始至传输完待传输的数据为止。完成所述发送端B的数据传输所耗费的时长是所述发送端B处于暂停传输数据的状态所耗费的时间和所述发送端B实际完成其所要传输的数据所耗费的时间。因此,所述接收端为所述发送端B分配数值为0的速率。所述接收端在所述发送端A完成了数据传输后,为所述发送端B重新分配速率。所述接收端与所述发送端B间的交互过程如图8所示,包括:
801,所述发送端B向所述接收端发送业务信息,所述业务信息包括数值为2M的数据量和数值为5ms的时限。
802,所述接收端确定自身可以满足所述发送端B的QoS需求,但由于需要优先满足所述发送端A,因此,所述接收端向所述发送端B返回的ACK信息中携带的速率为0,即RAT 0。
803,所述接收端确定所述发送端A的数据发送完成,向所述发送端B发送为其分配的速率信息,比如RAT 900Mbps。
804,所述发送端B按照被分配的速率,比如RAT 900Mbps,发送数据。
实施例三、在发送端C已接入并向接收端传输数据的过程中,所述接收端接收到发送端B的业务信息,所述接收端确定出自身可以满足所述发送端B的QoS需求,即所述接收端可以满足所述发送端B的deadline的要求。为了实现更优的tail latency,所述接收端优先满足所述发送端B的QoS需求,而中断所述发送端C的数据传输。所述发送端C与所述接收端的交互流程如图9所示,交互过程包括:
901,所述发送端C向所述接收端发送业务信息,所述业务信息包含数值为3M的数据量和数值为10ms的时限。
902,所述接收端根据所述发送端C的业务信息,确定自身可以满足所述发送端C的QoS需求,即所述接收端可以满足所述发送端C的deadline的要求,为所述发送端C分配速率,如900Mbps。所述接收端可将为所述发送端C分配的速率携带在报文头,发送给所述发送端C。
903~904,所述发送端C按照所述接收端为其分配的速率传输数据。
905,所述接收端接收到有size更小且deadline要求更高的发送端B发送的业务信息。为了优先满足所述发送端B的QoS需求,所述接收端暂停所述发送端C的数据传输。即所述接收端向所述发送端C发送第三控制信息,如RAT 0,以使所述发送端C暂停传输数据。
906,为了进一步保证所述发送端C能够接收到第三控制信息,所述接收端在后续向发送端C发送的ACK信息中的报文头中携带第三控制信息,如RAT0。
下面通过两个具体实施例,说明如何通过扩展报文头中的options字段,发送业务信息和控制信息,比如第一控制信息至第七控制信息中的任意种控制信息。
实施例四、通过扩展TCP header携带所述控制信息和所述业务信息,如表1所示。
kind | length | meaning(含义) | mark(标记) |
79 | 6 | 数据量大小 | size |
80 | 4 | deadline大小,单位ms | deadline |
81 | 4 | 分配的速率大小,单位Mbps | RAT |
82 | 4 | 发送端当前使用的速率 | RAT1 |
83 | 4 | 发送端可允许最大使用速率 | RAT2 |
84 | - | 传输需求无法满足 | DENY |
表1
实施例五、通过扩展IPV4 header携带所述控制信息和所述业务信息,如表2所示。
表2
其中,type class为0表示type class所在的option用于携带与控制有关的信息。
需要说明的是,发送端当前使用的速率与接收端分配的速率有可能相同,也有可能不同,具体的:所述发送端在接收到所述接收端为其分配的速率(RAT)后,若所述接收端分配的速率(RAT1)小于或等于所述发送端可允许最大使用速率(RAT2),则所述发送端当前使用的速率即为所述接收端分配的速率。若所述接收端分配的速率大于所述发送端可允许最大使用速率,则所述发送端按当前使用的速率即为所述发送端可允许最大使用速率。所述发送端在按照所述接收端为其分配的速率传输数据的过程中,若所述发送端可允许最大使用速率发生变化,则所述发送端将最新的可允许最大使用速率通知给所述接收端。
上述方法处理流程可以用软件程序实现,该软件程序可以存储在存储介质中,当存储的软件程序被调用时,执行上述方法步骤。
图10对应的实施例提供的数据接收设备可执行图2对应的实施例提供的方法。图10对应的实施例提供的数据接收设备可以是数据中心的服务器,也可以是其他能够执行图2对应的实施例提供的方法的设备,在此不再逐一举例说明。如图10所示,所述数据接收设备包括:
接收模块101,用于接收第一数据发送设备发送的业务信息,所述业务信息用于表示所述第一数据发送设备所需传输的数据的信息;
判断模块102,用于判断所述数据接收设备能否满足所述业务信息对应的传输需求;
控制模块103,用于在所述判断模块102确定所述数据接收设备能够满足所述业务信息对应的传输需求后,控制所述第一数据发送设备的数据传输。
可选地,所述控制模块103还用于:
在所述判断模块102确定所述数据接收设备不满足所述业务信息对应的传输需求后,向所述第一数据发送设备发送第一控制信息,所述第一控制信息用于表示拒绝所述第一数据发送设备的接入。
举例说明,所述控制模块103将所述第一控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送了携带所述第一控制信息的报文。
作为第一种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述判断模块102具体用于:
根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述数据接收设备的物理带宽是否大于或等于所述第一速率对应的带宽。
具体的,若判断出所述数据接收设备的物理带宽大于或等于所述第一速率对应的带宽,则确定能够满足所述业务信息对应的传输需求;若判断出所述数据接收设备的物理带宽小于所述第一速率对应的带宽,则确定不满足所述业务信息对应的传输需求。
作为第二种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述判断模块102具体用于:
根据第二时限和所述数据接收设备的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述数据接收设备的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述第二数据量是否大于或等于所述第一数据量。
具体的,若判断出所述第二数据量大于或等于所述第一数据量,则确定能够满足所述业务信息对应的传输需求;若判断出所述第二数据量小于所述第一数据量,则确定不满足所述业务信息对应的传输需求。
作为第三种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述判断模块102具体用于:
根据所述第一时限和所述数据接收设备的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述数据接收设备的物理带宽的乘积;
判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二数据发送设备在所述第一时限内传输的数据的大小。
具体的,若判断出所述第四数据量大于或等于所述第一数据量,则确定能够满足所述业务信息对应的传输需求;若判断出所述第四数据量小于所述第一数据量,则确定不满足所述业务信息对应的传输需求。
基于上述任一方式,所述第一时限也可以为截至时限(deadline),即用于表示所述第一数据发送设备希望在所述第一时限对应的时长内完成所述第一数据量的数据传输。
作为第四种实现方式,所述业务信息包括第二速率,所述第二速率为所述第一数据发送设备传输数据所需的最小速率,所述判断模块102具体用于:
判断所述数据接收设备的物理带宽是否大于或等于所述第二速率对应的带宽。
具体的,若判断出所述数据接收设备的物理带宽大于或等于所述第二速率对应的带宽,则确定能够满足所述业务信息对应的传输需求;若判断出所述数据接收设备的物理带宽小于所述第二速率对应的带宽,则确定不满足所述业务信息对应的传输需求。
基于上述任一实施例,作为一种实现方式,所述控制模块103具体用于:
根据所述第一数据发送设备的优先级和所述数据接收设备的物理带宽,为所述第一数据发送设备分配第三速率,所述第三速率为所述第一数据发送设备用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述第三速率。
举例说明,所述控制模块103将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
在实施中,若所述第一数据发送设备的优先级高于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述控制模块103还用于:
向所述第二数据发送设备发送第三控制信息,所述第三控制信息包括所述数据接收设备为所述第二数据发送设备分配的第五速率,所述第五速率小于所述第四速率;
或者
向所述第二数据发送设备发送第四控制信息,所述第四控制信息用于指示所述第二数据发送设备暂停传输数据。
举例说明,所述控制模块103将所述第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文。
举例说明,所述控制模块103将所述第四控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第四控制信息的报文。
在实施中,若所述第一数据发送设备的优先级低于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第三速率小于所述第一数据发送设备传输数据所需的最小速率,所述控制模块103还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第六速率,所述第六速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述数据接收设备的物理带宽;向所述第一数据发送设备发送第五控制信息,所述第五控制信息包括所述第六速率。
举例说明,所述控制模块103将所述第五控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
作为另一种实现方式,所述控制模块103具体用于:
确定所述第一数据发送设备的优先级低于第二数据发送设备的优先级,向所述第一数据发送设备发送第六控制信息,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第六控制信息用于指示所述第一数据发送设备暂停数据传输。
举例说明,所述控制模块103将所述第六控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
进一步,所述控制模块103还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第七速率,所述第七速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述数据接收设备的物理带宽;向所述第一数据发送设备发送第七控制信息,所述第七控制信息包括所述第七速率。
举例说明,所述控制模块103将第七控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第七控制信息的报文。
图11对应的实施例提供的数据接收设备可执行图5对应的实施例提供的方法。图11对应的实施例提供的数据接收设备可以是数据中心的服务器,也可以是其他能够执行图5对应的实施例提供的方法的设备,在此不再逐一举例说明。如图11所示,该数据接收设备包括:
接收模块111,用于接收第一数据发送设备发送的第一数据量,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小;
控制模块112,用于根据所述第一数据量,控制所述第一数据发送设备的数据传输。
作为一种实现方式,所述控制模块112具体用于:
确定所述第一数据量小于第二数据量,向所述第二数据发送设备发送第一控制信息或第三控制信息,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为以第一速率向所述数据接收设备传输数据的数据发送设备,所述第一速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第一控制信息包括所述控制模块112为所述第二数据发送设备分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二数据发送设备暂停传输数据;
向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述控制模块112为所述第一数据发送设备分配的第三速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽。
举例说明,所述控制模块112将所述第一控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第一控制信息的报文。
举例说明,所述控制模块112将所述第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文。
举例说明,所述控制模块112将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
可选地,所述接收模块111还用于:接收所述第一数据发送设备发送的所述第一数据发送设备允许的最大速率;其中,所述第三速率小于或等于所述第一数据发送设备允许的最大速率。
作为另一种实现方式,所述控制模块112具体用于:
确定所述第一数据量大于或等于第二数据量,向所述第一数据发送设备发送第四控制信息或第五控制信息;
其中,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为已向所述数据接收设备传输数据的数据发送设备,所述第四控制信息包括所述控制模块112为所述第一数据发送设备分配的第四速率,所述第四速率小于所述第一数据发送设备传输数据所需的最小速率,所述第五控制信息用于指示所述第一数据发送设备暂停传输数据。
举例说明,所述控制模块112将所述第四控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第四控制信息的报文。
举例说明,所述控制模块112将所述第五控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
对于该方式,所述控制模块112还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第五速率,所述第五速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述数据接收设备的物理带宽;向所述第一数据发送设备发送第六控制信息,所述第六控制信息包括所述第五速率。
举例说明,所述控制模块112将第六控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
图12对应的实施例提供的数据接收设备可执行图2对应的实施例提供的方法。图12对应的实施例提供的数据接收设备可以和图10对应的实施例提供的数据接收设备相同。如图12所示,所述数据接收设备包括:
接收器121,用于接收第一数据发送设备发送的业务信息,所述业务信息用于表示所述第一数据发送设备所需传输的数据的信息;
处理器122,用于判断所述数据接收设备能否满足所述业务信息对应的传输需求;在确定所述数据接收设备能够满足所述业务信息对应的传输需求后,控制所述第一数据发送设备的数据传输。
举例说明,所述接收器121可以是具有接收功能的通信接口或具有接收功能的部件。
可选地,所述数据接收设备还包括:
发送器123,用于在所述处理器122的控制下发送数据;
所述处理器122还用于:在确定所述数据接收设备不满足所述业务信息对应的传输需求后,控制所述发送器123向所述第一数据发送设备发送第一控制信息,所述第一控制信息用于表示拒绝所述第一数据发送设备的接入。
举例说明,所述发送器123可以是具有发送功能的通信接口或具有发送功能的部件。
举例说明,所述发送器123将第一控制信息携带在报文头中的选项options字段中,向所述第一数据发送设备发送携带所述第一控制信息的报文。
作为第一种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器122用于:
根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述数据接收设备的物理带宽是否大于或等于所述第一速率对应的带宽。
具体的,若判断出所述数据接收设备的物理带宽大于或等于所述第一速率对应的带宽,则确定能够满足所述业务信息对应的传输需求;若判断出所述数据接收设备的物理带宽小于所述第一速率对应的带宽,则确定不满足所述业务信息对应的传输需求。
作为第二种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器122具体用于:
根据第二时限和所述数据接收设备的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述数据接收设备的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二数据发送设备传输数据所占用的时间段;
判断所述第二数据量是否大于或等于所述第一数据量。
具体的,若判断出所述第二数据量大于或等于所述第一数据量,则确定能够满足所述业务信息对应的传输需求;若判断出所述第二数据量小于所述第一数据量,则确定不满足所述业务信息对应的传输需求。
作为第三种实现方式,所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小,所述第一时限用于表示所述第一数据发送设备传输所述第一数据量所需的时间段,所述处理器122具体用于:
根据所述第一时限和所述数据接收设备的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述数据接收设备的物理带宽的乘积;
判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二数据发送设备在所述第一时限内传输的数据的大小。
具体的,若判断出所述第四数据量大于或等于所述第一数据量,则确定能够满足所述业务信息对应的传输需求;若判断出所述第四数据量小于所述第一数据量,则确定不满足所述业务信息对应的传输需求。
作为第四种实现方式,所述业务信息包括第二速率,所述第二速率为所述第一数据发送设备传输数据所需的最小速率,所述处理器122具体用于:
判断所述数据接收设备的物理带宽是否大于或等于所述第二速率对应的带宽。
具体的,若判断出所述数据接收设备的物理带宽大于或等于所述第二速率对应的带宽,则确定能够满足所述业务信息对应的传输需求;若判断出所述数据接收设备的物理带宽小于所述第二速率对应的带宽,则确定不满足所述业务信息对应的传输需求。
基于上述任一实施例,作为一种实现方式,所述处理器122具体用于:
根据所述第一数据发送设备的优先级和所述数据接收设备的物理带宽,为所述第一数据发送设备分配第三速率,所述第三速率为所述第一数据发送设备用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器123向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述第三速率。
举例说明,所述发送器123将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
在实施中,若所述第一数据发送设备的优先级高于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述处理器122还用于:
控制所述发送器123向所述第二数据发送设备发送第三控制信息,所述第三控制信息包括所述处理器122为所述第二数据发送设备分配的第五速率,所述第五速率小于所述第四速率;或者
控制所述发送器123向所述第二数据发送设备发送第四控制信息,所述第四控制信息用于指示所述第二数据发送设备暂停传输数据。
举例说明,所述发送器123将第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文。
举例说明,所述发送器123将所述第四控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第四控制信息的报文。
在实施中,若所述第一数据发送设备的优先级低于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第三速率小于所述第一数据发送设备传输数据所需的最小速率,所述处理器122还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第六速率,所述第六速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器123向所述第一数据发送设备发送第五控制信息,所述第五控制信息包括所述第六速率。
举例说明,所述发送器123将所述第五控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
作为另一种实现方式,所述处理器122具体用于:
确定所述第一数据发送设备的优先级低于第二数据发送设备的优先级,控制所述发送器123向所述第一数据发送设备发送第六控制信息,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第六控制信息用于指示所述第一数据发送设备暂停数据传输。
举例说明,所述发送器123将所述第六控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
进一步,所述处理器122还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第七速率,所述第七速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器123向所述第一数据发送设备发送第七控制信息,所述第七控制信息包括所述第七速率。
举例说明,所述发送器123将所述第七控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第七控制信息的报文。
图13对应的实施例提供的数据接收设备可执行图5对应的实施例提供的方法。图13对应的实施例提供的数据接收设备可以和图11对应的实施例提供的数据接收设备相同。如图13所示,所述数据接收设备包括:
接收器131,用于接收第一数据发送设备发送的第一数据量,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小;
处理器132,用于根据所述第一数据量,控制所述第一数据发送设备的数据传输。
举例说明,所述接收器131可以是具有接收功能的通信接口或具有接收功能的部件。
可选地,所述数据接收设备还包括:
发送器133,用于在所述处理器132的控制下发送数据。
举例说明,所述发送器133可以是具有接收功能的通信接口或具有发送功能的部件。
作为一种实现方式,所述处理器132具体用于:
确定所述第一数据量小于第二数据量,控制所述发送器133向所述第二数据发送设备发送第一控制信息或第三控制信息,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为以第一速率向所述数据接收设备传输数据的数据发送设备,所述第一速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第一控制信息包括所述处理器132为所述第二数据发送设备分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二数据发送设备暂停传输数据;
控制所述发送器133向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述处理器132为所述第一数据发送设备分配的第三速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽。
举例说明,所述发送器133将所述第一控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带第一控制信息的报文。
所述发送器133将所述第三控制信息携带在报文头中的options字段中,向所述第二数据发送设备发送携带所述第三控制信息的报文。
举例说明,所述发送器133将所述第二控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第二控制信息的报文。
进一步,所述接收器131还用于:接收所述第一数据发送设备发送的所述第一数据发送设备允许的最大速率;其中,所述第三速率小于或等于所述第一数据发送设备允许的最大速率。
作为另一种实现方式,所述处理器132具体用于:
确定所述第一数据量大于或等于第二数据量,控制所述发送器133向所述第一数据发送设备发送第四控制信息或第五控制信息;
其中,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为已向所述数据接收设备传输数据的数据发送设备,所述第四控制信息包括所述处理器132为所述第一数据发送设备分配的第四速率,所述第四速率小于所述第一数据发送设备传输数据所需的最小速率,所述第五控制信息用于指示所述第一数据发送设备暂停传输数据。
举例说明,所述发送器133将所述第四控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第四控制信息的报文。所述发送器133将所述第五控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第五控制信息的报文。
进一步,所述处理器132还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第五速率,所述第五速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述数据接收设备的物理带宽;控制所述发送器133向所述第一数据发送设备发送第六控制信息,所述第六控制信息包括所述第五速率。
举例说明,所述发送器133将所述第六控制信息携带在报文头中的options字段中,向所述第一数据发送设备发送携带所述第六控制信息的报文。
图14对应的实施例提供的数据发送设备可执行图6对应的实施例提供的方法。图14对应的实施例提供的数据发送设备可以是数据中心的服务器,也可以是其他能够执行图6对应的实施例提供的方法的设备,在此不再逐一举例说明。如图14所示,所述数据发送设备包括:
发送模块141,用于向数据接收设备发送业务信息,所述业务信息用于表示所述数据发送设备所需传输的数据的信息;
数据传输模块142,用于在所述数据接收设备的控制下进行数据传输。
举例说明,所述发送模块141将所述业务信息携带在报文头中的options字段中,向所述数据接收设备发送携带所述业务信息的报文。
可选地,所述数据传输模块142具体用于:
接收来自所述数据接收设备的第一控制信息,所述第一控制信息用于表示所述数据接收设备拒绝所述数据发送设备的接入;根据所述第一控制信息,丢弃所需传输的数据。
本发明实施例中,所述业务信息包括数据量和时限,所述数据量用于表示所述数据发送设备需传输的数据的大小,所述时限用于表示所述数据发送设备传输所述数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述数据发送设备需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述数据发送设备传输数据所需的最小速率。
基于上述任一实施例,作为第一种实现方式,所述数据传输模块142具体用于:
接收来自所述数据接收设备的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述数据接收设备的物理带宽;采用所述第二速率,向所述数据接收设备传输数据。
作为第二种实现方式,所述数据传输模块142具体用于:
接收来自所述数据接收设备的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第三速率小于所述数据发送设备传输数据所需的最小速率;根据所述第三速率,暂停向所述数据接收设备传输数据。其中,所述第三速率的数值可以为0。
作为第三种实现方式,所述数据传输模块142具体用于:
接收来自所述数据接收设备的第四控制信息,该第四控制信息用于指示所述数据发送设备暂停数据传输;根据所述第四控制信息,暂停向所述数据接收设备传输数据。
基于上述第二种或第三种实现方式,所述数据传输模块142还用于:
接收来自所述数据接收设备的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述数据发送设备传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽;采用所述第四速率,向所述数据接收设备发送需传输的数据。
图15对应的实施例提供的数据发送设备可执行图6对应的实施例提供的方法。图15对应的实施例提供的数据发送设备与图14对应的实施例提供的数据发送设备相同。如图15所示,所述数据发送设备包括:
发送器151,用于向数据接收设备发送业务信息,所述业务信息用于表示所述数据发送设备所需传输的数据的信息;
接收器152,用于接收来自所述数据接收设备的信息;
处理器153,用于在所述数据接收设备的控制下进行数据传输。
举例说明,所述发送器151可以是具有发送功能的通信接口或具有发送功能的部件。所述接收器152可以是具有接收功能的通信接口或具有接收功能的部件。
举例说明,所述数据发送设备将所述业务信息携带在报文头中的options字段中,向所述数据接收设备发送携带所述业务信息的报文。
可选地,接收器152具体用于:接收来自所述数据接收设备的第一控制信息,所述第一控制信息用于表示所述数据接收设备拒绝所述数据发送设备的接入;
处理器153具体用于:根据所述第一控制信息,丢弃所需传输的数据。
本发明实施例中,所述业务信息包括数据量和时限,所述数据量用于表示所述数据发送设备需传输的数据的大小,所述时限用于表示所述数据发送设备传输所述数据量所需的时间段;或者
所述业务信息包括数据量,所述数据量用于表示所述数据发送设备需传输的数据的大小;或者
所述业务信息包括第一速率,所述第一速率为所述数据发送设备传输数据所需的最小速率。
基于上述任一实施例,作为第一种实现方式,所述接收器152具体用于:接收来自所述数据接收设备的第二控制信息,所述第二控制信息包括第二速率,所述第二速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第二速率对应的带宽小于或等于所述数据接收设备的物理带宽;
所述处理器153具体用于:控制所述发送器151采用所述第二速率,向所述数据接收设备传输数据。
作为第二种实现方式,所述接收器152具体用于:接收来自所述数据接收设备的第三控制信息,所述第三控制信息包括第三速率,所述第三速率为所述数据接收设备为所述数据发送设备分配的用于传输数据的速率,所述第三速率小于所述数据传输模块传输数据所需的最小速率;
所述处理器153具体用于:根据所述第三速率,控制所述发送器151暂停向所述数据接收设备传输数据。
作为第三种实现方式,所述接收器152具体用于:接收来自所述数据接收设备的第四控制信息,所述该第四控制信息用于指示所述数据发送设备暂停数据传输;
处理器153具体用于:根据所述第四控制信息,控制发送器151暂停向所述数据接收设备传输数据。
基于上述第二种或第三种实现方式,所述接收器152具体用于:接收来自所述数据接收设备的第五控制信息,所述第五控制信息包括第四速率,所述第四速率大于或等于所述数据发送设备传输数据所需的最小速率,且所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽;
所述处理器153还用于:控制所述发送器151采用所述第四速率,向所述数据接收设备发送需传输的数据。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明范围的所有变更和修改。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。
Claims (20)
1.一种数据接收方法,其特征在于,该方法包括:
接收端接收第一发送端发送的业务信息,所述业务信息用于表示所述第一发送端所需传输的数据的信息;所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段;
所述接收端判断所述接收端能否满足所述业务信息对应的传输需求;
所述接收端确定所述接收端能够满足所述业务信息对应的传输需求后,控制所述第一发送端的数据传输;
其中,所述接收端判断所述接收端能否满足所述业务信息对应的传输需求包括:所述接收端根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;所述接收端判断所述接收端的物理带宽是否大于或等于所述第一速率对应的带宽;或者,
所述接收端根据第二时限和所述接收端的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述接收端的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;所述接收端判断所述第二数据量是否大于或等于所述第一数据量;或者,
所述接收端根据所述第一时限和所述接收端的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述接收端的物理带宽的乘积;所述接收端判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二发送端在所述第一时限内传输的数据的大小。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
所述接收端确定所述接收端不满足所述业务信息对应的传输需求后,向所述第一发送端发送第一控制信息,所述第一控制信息用于表示所述接收端拒绝所述第一发送端的接入。
3.根据权利要求1或2所述的方法,其特征在于,所述控制所述第一发送端的数据传输包括:
所述接收端根据所述第一发送端的优先级和所述接收端的物理带宽,为所述第一发送端分配第三速率,所述第三速率为所述第一发送端用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述第三速率。
4.根据权利要求3所述的方法,其特征在于,所述第一发送端的优先级高于第二发送端的优先级,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述方法还包括:
所述接收端向所述第二发送端发送第三控制信息,所述第三控制信息包括所述接收端为所述第二发送端分配的第五速率,所述第五速率小于所述第四速率;或者
所述接收端向所述第二发送端发送第四控制信息,所述第四控制信息用于指示所述第二发送端暂停传输数据。
5.根据权利要求3所述的方法,其特征在于,所述第一发送端的优先级低于第二发送端的优先级,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第三速率小于所述第一发送端传输数据所需的最小速率,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第六速率,所述第六速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第五控制信息,所述第五控制信息包括所述第六速率。
6.根据权利要求1或2所述的方法,其特征在于,所述控制所述第一发送端的数据传输包括:
所述接收端确定所述第一发送端的优先级低于第二发送端的优先级,向所述第一发送端发送第六控制信息,所述第二发送端为以第四速率向所述接收端传输数据的发送端,所述第四速率对应的带宽小于或等于所述接收端的物理带宽,所述第六控制信息用于指示所述第一发送端暂停数据传输。
7.根据权利要求6所述的方法,其特征在于,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第七速率,所述第七速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第七控制信息,所述第七控制信息包括所述第七速率。
8.一种数据接收方法,其特征在于,该方法包括:
接收端接收第一发送端发送的第一数据量,所述第一数据量用于表示所述第一发送端需传输的数据的大小;
所述接收端确定所述第一数据量小于第二数据量,向第二发送端发送第一控制信息或第三控制信息,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为以第一速率向所述接收端传输数据的发送端,所述第一速率对应的带宽小于或等于所述接收端的物理带宽,所述第一控制信息包括所述接收端为所述第二发送端分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二发送端暂停传输数据;所述接收端向所述第一发送端发送第二控制信息,所述第二控制信息包括所述接收端为所述第一发送端分配的第三速率,所述第三速率对应的带宽小于或等于所述接收端的物理带宽;或者,
所述接收端确定所述第一数据量大于或等于第二数据量,向所述第一发送端发送第四控制信息或第五控制信息;其中,所述第二数据量用于表示第二发送端待发送至所述接收端的数据的大小,所述第二发送端为已向所述接收端传输数据的发送端,所述第四控制信息包括所述接收端为所述第一发送端分配的第四速率,所述第四速率小于所述第一发送端传输数据所需的最小速率,所述第五控制信息用于指示所述第一发送端暂停传输数据。
9.根据权利要求8所述的方法,其特征在于,该方法还包括:
接收端接收第一发送端发送的所述第一发送端允许的最大速率;
其中,所述第三速率小于或等于所述第一发送端允许的最大速率。
10.根据权利要求8所述的方法,其特征在于,所述方法还包括:
所述接收端确定所述第二发送端完成数据传输后,为所述第一发送端分配第五速率,所述第五速率大于或等于所述第一发送端传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述接收端的物理带宽;
所述接收端向所述第一发送端发送第六控制信息,所述第六控制信息包括所述第五速率。
11.一种数据接收设备,其特征在于,所述数据接收设备包括:
接收模块,用于接收第一数据发送设备发送的业务信息,所述业务信息用于表示所述第一数据发送设备所需传输的数据的信息;所述业务信息包括第一数据量和第一时限,所述第一数据量用于表示所述第一发送端需传输的数据的大小,所述第一时限用于表示所述第一发送端传输所述第一数据量所需的时间段;
判断模块,用于判断所述数据接收设备能否满足所述业务信息对应的传输需求;
控制模块,用于在所述判断模块确定所述数据接收设备能够满足所述业务信息对应的传输需求后,控制所述第一数据发送设备的数据传输;
其中,所述判断模块具体用于:根据第二时限和所述第一数据量,计算获得第一速率,所述第一速率是所述第一数据量除以所述第二时限所获得的数值,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;判断所述接收端的物理带宽是否大于或等于所述第一速率对应的带宽;或者,
根据第二时限和所述接收端的物理带宽,计算获得第二数据量,所述第二数据量是所述第二时限与所述接收端的物理带宽的乘积,所述第二时限为所述第一时限和第三时限的差值,所述第三时限为第二发送端传输数据所占用的时间段;判断所述第二数据量是否大于或等于所述第一数据量;或者,
根据所述第一时限和所述接收端的物理带宽,计算获得第三数据量,所述第三数据量是所述第一时限和所述接收端的物理带宽的乘积;判断第四数据量是否大于或等于所述第一数据量,所述第四数据量是所述第三数据量与第五数据量的差值,所述第五数据量是第二发送端在所述第一时限内传输的数据的大小。
12.如权利要求11所述的设备,其特征在于,所述控制模块还用于:
在所述判断模块确定所述数据接收设备不满足所述业务信息对应的传输需求后,向所述第一数据发送设备发送第一控制信息,所述第一控制信息用于表示拒绝所述第一数据发送设备的接入。
13.根据权利要求11或12所述的设备,其特征在于,所述控制模块具体用于:
根据所述第一数据发送设备的优先级和所述数据接收设备的物理带宽,为所述第一数据发送设备分配第三速率,所述第三速率为所述第一数据发送设备用于传输数据所采用的速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述第三速率。
14.根据权利要求13所述的设备,其特征在于,所述第一数据发送设备的优先级高于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述控制模块还用于:
向所述第二数据发送设备发送第三控制信息,所述第三控制信息包括所述数据接收设备为所述第二数据发送设备分配的第五速率,所述第五速率小于所述第四速率;或者
向所述第二数据发送设备发送第四控制信息,所述第四控制信息用于指示所述第二数据发送设备暂停传输数据。
15.根据权利要求13所述的设备,其特征在于,所述第一数据发送设备的优先级低于第二数据发送设备的优先级,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第三速率小于所述第一数据发送设备传输数据所需的最小速率,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第六速率,所述第六速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第六速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第五控制信息,所述第五控制信息包括所述第六速率。
16.根据权利要求11或12所述的设备,其特征在于,所述控制模块具体用于:
确定所述第一数据发送设备的优先级低于第二数据发送设备的优先级,向所述第一数据发送设备发送第六控制信息,所述第二数据发送设备为以第四速率向所述数据接收设备传输数据的数据发送设备,所述第四速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第六控制信息用于指示所述第一数据发送设备暂停数据传输。
17.根据权利要求16所述的设备,其特征在于,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第七速率,所述第七速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第七速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第七控制信息,所述第七控制信息包括所述第七速率。
18.一种数据接收设备,其特征在于,所述数据接收设备包括:
接收模块,用于接收第一数据发送设备发送的第一数据量,所述第一数据量用于表示所述第一数据发送设备需传输的数据的大小;
控制模块,用于确定所述第一数据量小于第二数据量,向第二数据发送设备发送第一控制信息或第三控制信息,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为以第一速率向所述数据接收设备传输数据的数据发送设备,所述第一速率对应的带宽小于或等于所述数据接收设备的物理带宽,所述第一控制信息包括所述控制模块为所述第二数据发送设备分配的第二速率,所述第二速率小于所述第一速率,所述第三控制信息用于指示所述第二数据发送设备暂停传输数据;向所述第一数据发送设备发送第二控制信息,所述第二控制信息包括所述控制模块为所述第一数据发送设备分配的第三速率,所述第三速率对应的带宽小于或等于所述数据接收设备的物理带宽;或者,
确定所述第一数据量大于或等于第二数据量,向所述第一数据发送设备发送第四控制信息或第五控制信息;其中,所述第二数据量用于表示第二数据发送设备待发送至所述数据接收设备的数据的大小,所述第二数据发送设备为已向所述数据接收设备传输数据的数据发送设备,所述第四控制信息包括所述控制模块为所述第一数据发送设备分配的第四速率,所述第四速率小于所述第一数据发送设备传输数据所需的最小速率,所述第五控制信息用于指示所述第一数据发送设备暂停传输数据。
19.根据权利要求18所述的设备,其特征在于,所述接收模块还用于:
接收第一数据发送设备发送的所述第一数据发送设备允许的最大速率;
其中,所述第三速率小于或等于所述第一数据发送设备允许的最大速率。
20.根据权利要求18所述的设备,其特征在于,所述控制模块还用于:
确定所述第二数据发送设备完成数据传输后,为所述第一数据发送设备分配第五速率,所述第五速率大于或等于所述第一数据发送设备传输数据所需的最小速率,且所述第五速率对应的带宽小于或等于所述数据接收设备的物理带宽;
向所述第一数据发送设备发送第六控制信息,所述第六控制信息包括所述第五速率。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510386543.6A CN106330756B (zh) | 2015-07-03 | 2015-07-03 | 一种数据传输方法和设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510386543.6A CN106330756B (zh) | 2015-07-03 | 2015-07-03 | 一种数据传输方法和设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106330756A CN106330756A (zh) | 2017-01-11 |
CN106330756B true CN106330756B (zh) | 2020-01-03 |
Family
ID=57727305
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201510386543.6A Active CN106330756B (zh) | 2015-07-03 | 2015-07-03 | 一种数据传输方法和设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106330756B (zh) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109218222B (zh) * | 2017-06-30 | 2021-06-22 | 华为技术有限公司 | 一种实现发送端调速的方法、装置和系统 |
CN107819697B (zh) * | 2017-11-27 | 2020-03-27 | 锐捷网络股份有限公司 | 数据传输方法、交换机及数据中心 |
CN112019363B (zh) * | 2019-05-30 | 2021-12-14 | 华为技术有限公司 | 确定业务传输需求的方法、设备及系统 |
CN112039686B (zh) * | 2019-06-03 | 2023-08-04 | 杭州海康威视系统技术有限公司 | 一种数据流传输控制方法、装置、监控设备及存储介质 |
CN113055293B (zh) * | 2019-12-27 | 2023-06-23 | 华为技术有限公司 | 软件定义广域网中的选路方法及装置、通信系统 |
CN111782938B (zh) * | 2020-05-29 | 2021-02-09 | 广西博士海意信息科技有限公司 | 一种信息查询推送方法、装置及计算机设备 |
CN114157604A (zh) * | 2021-12-01 | 2022-03-08 | 锐捷网络股份有限公司 | 一种调节交换网板拥塞的方法、装置及系统 |
CN115396383B (zh) * | 2022-07-18 | 2023-08-11 | 伟乐视讯科技股份有限公司 | 一种多台设备传输码流中反向控制码流的方法 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101741722A (zh) * | 2009-12-10 | 2010-06-16 | 中兴通讯股份有限公司 | 数据交互方法及装置 |
CN102739357A (zh) * | 2012-05-30 | 2012-10-17 | 深圳市通盛网络技术有限公司 | 数据无差错传输处理方法 |
CN103493449A (zh) * | 2011-04-28 | 2014-01-01 | 微软公司 | 分组交换网络中的有效电路 |
CN103746975A (zh) * | 2013-12-26 | 2014-04-23 | 小米科技有限责任公司 | 一种数据传输方法、装置及移动终端 |
CN104254109A (zh) * | 2013-06-25 | 2014-12-31 | 华为技术有限公司 | 用户设备、基站、流媒体自适应传输系统和方法 |
-
2015
- 2015-07-03 CN CN201510386543.6A patent/CN106330756B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101741722A (zh) * | 2009-12-10 | 2010-06-16 | 中兴通讯股份有限公司 | 数据交互方法及装置 |
CN103493449A (zh) * | 2011-04-28 | 2014-01-01 | 微软公司 | 分组交换网络中的有效电路 |
CN102739357A (zh) * | 2012-05-30 | 2012-10-17 | 深圳市通盛网络技术有限公司 | 数据无差错传输处理方法 |
CN104254109A (zh) * | 2013-06-25 | 2014-12-31 | 华为技术有限公司 | 用户设备、基站、流媒体自适应传输系统和方法 |
CN103746975A (zh) * | 2013-12-26 | 2014-04-23 | 小米科技有限责任公司 | 一种数据传输方法、装置及移动终端 |
Also Published As
Publication number | Publication date |
---|---|
CN106330756A (zh) | 2017-01-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106330756B (zh) | 一种数据传输方法和设备 | |
US10084882B2 (en) | Method for processing requests and server device processing requests | |
CN107534981B (zh) | 资源重分配 | |
JP2013516107A5 (zh) | ||
CN109417720B (zh) | 拥塞控制方法、基站及终端 | |
CN102413056B (zh) | 网络流量控制方法、装置及出口网关设备 | |
KR102275579B1 (ko) | 이동 통신 시스템에서 전송 차별화를 제공하는 방법 및 장치 | |
US11070466B2 (en) | Method for link aggregation and related devices | |
WO2013117126A1 (zh) | 业务速率控制方法和系统以及设备 | |
US9432999B1 (en) | Optimization of airtime among Wi-Fi clients connected to an access point | |
KR20180126401A (ko) | 멀티코어 기반 데이터 처리 방법 및 장치 | |
JP2017532888A (ja) | サービススケジューリング方法およびデバイス | |
CN111294758B (zh) | 逻辑信道优先级处理方法及装置、存储介质、终端 | |
US11159441B2 (en) | QoS/QoE enforcement driven sub-service flow management in 5G system | |
CN109995608B (zh) | 网络速率计算方法和装置 | |
CN104427630B (zh) | 一种分组调度方法及装置 | |
CN103974339A (zh) | 一种数据缓存的方法和装置 | |
CN106941729B (zh) | 一种上传和接收缓冲区状态的方法、装置 | |
JP7074181B2 (ja) | 制御装置、通信制御方法、及びプログラム | |
CN111416775B (zh) | 数据接收和发送方法、装置及系统 | |
JP5564603B1 (ja) | 中継ノード | |
US10455261B2 (en) | Signaling scheme for improved video streaming | |
CN112714081A (zh) | 一种数据处理方法及其装置 | |
CN107155220B (zh) | 一种资源调度方法及装置 | |
CN107371263B (zh) | 上行资源的调度方法和装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |