WO2008148173A1 - A system and method for improving throughput in a network device - Google Patents
A system and method for improving throughput in a network device Download PDFInfo
- Publication number
- WO2008148173A1 WO2008148173A1 PCT/AU2008/000826 AU2008000826W WO2008148173A1 WO 2008148173 A1 WO2008148173 A1 WO 2008148173A1 AU 2008000826 W AU2008000826 W AU 2008000826W WO 2008148173 A1 WO2008148173 A1 WO 2008148173A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- data
- accordance
- acknowledgement
- packet
- preferred rate
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 33
- 230000005540 biological transmission Effects 0.000 claims description 16
- 238000012913 prioritisation Methods 0.000 claims description 5
- 238000011144 upstream manufacturing Methods 0.000 description 20
- 238000004891 communication Methods 0.000 description 5
- 238000004422 calculation algorithm Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 238000004364 calculation method Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000002452 interceptive effect Effects 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000002457 bidirectional effect Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000000737 periodic effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 230000002441 reversible effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/2854—Wide area networks, e.g. public data networks
- H04L12/2856—Access arrangements, e.g. Internet access
-
- 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
-
- 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/19—Flow control; Congestion control at layers above the network layer
- H04L47/193—Flow control; Congestion control at layers above the network layer at the transport layer, e.g. TCP related
-
- 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/2466—Traffic characterised by specific attributes, e.g. priority or QoS using signalling traffic
-
- 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/25—Flow control; Congestion control with rate being modified by the source upon detecting a change of network conditions
Definitions
- the present invention generally relates to a system and method for improving throughput in a network device .
- Embodiments of the invention find particular, but not exclusive, use in asymmetric devices, such as an Asymmetric Digital Subscriber Line (ADSL) modem device.
- ADSL Asymmetric Digital Subscriber Line
- TCP Transmission Control Protocol
- the term 'data' includes emails, data files (whether as email attachments or raw files) , web pages, objects inside web pages (such as images) , non-interactive video or audio transmissions, etc. That is, the term ⁇ data' can be construed to include any type of electronic information that is capable of being sent over an electronic network (including a wireless network) .
- the TCP standard automatically adjusts the data transmission rate to best suit the apparent network capacity between source and destination. TCP adjusts the transmission rate by attempting to measure (or estimate) apparent network capacity. This is achieved by sending data packets to a destination and monitoring the stream of returned Acknowledgment (ACK) packets from the destination. TCP adjusts the transmission of data based on the rate at which matching ACK packets return from the destination.
- TCP detects packet loss events by tracking the non-receipt of matching ACK packets. TCP responds to loss events by repeating transmission of lost data packets, and temporarily slowing down the transmission of subsequent data packets.
- Network behaviour that interferes with or constrains the free flow of ACK packets from destination to source is known to cause suboptimal data transfer performance from source to destination.
- the present invention provides a system for a method for managing data packets to be sent through an asymmetric network device, comprising the steps of receiving data from at least one computing device, determining whether the data is acknowledgement data, and if so, prioritising the upload of the acknowledgement data to the asymmetric network device .
- the method may include the initial step of determining a preferred rate of acknowledgement data to be uploaded to the asymmetric network device, and prioritising the upload of the acknowledgement data until the preferred rate is reached.
- the preferred rate may be predetermined (by a user, for example) , or it may be calculated dynamically. Where the preferred rate is calculated dynamically, the dynamic calculation may be a function of the instantaneous download rate, the data packet size and/or the acknowledgement data packet size.
- U m i n is the preferred rate
- B 3 is the average size of an acknowledgement packet
- B d is the average size of a data packet
- F is a predetermined fraction set by a user
- D is the maximum download capacity through the network device.
- B a may be calculated utilising the formula
- B avg is the network defined average size of an acknowledgment packet
- X is the number of data packets downloaded for every acknowledgment packet uploaded. All received data may be placed into a queuing structure, such that acknowledgement data is placed in one queue, and the acknowledgement data queue is prioritised.
- the step of determining whether data is acknowledgement data may include the step of, inspecting the header within the data packet to determine whether the data is acknowledgement data and/or inspecting the size of the data packet to determine whether the data is acknowledgement data.
- the present invention provides a method for a system for managing a device connected to an asymmetric network device, comprising a receiving module arranged to receive data from at least one computing device, and a prioritisation module arranged determine whether the data is acknowledgement data, and if so, prioritise the upload of the data to the asymmetric network device .
- the present invention provides a computing program including at least one instruction which, when loaded on a programmable device, causes the programmable device to perform a method in accordance with the second aspect of the invention.
- the present invention provides a computer readable medium incorporating a computing program in accordance with a third aspect of the invention.
- Figure 1 is a diagram illustrating a computing system suitable for implementing a methodology or system in accordance with an embodiment of the present invention.
- Figure 2 is a flowchart illustrating a methodology in accordance with an embodiment of the present invention.
- FIG. 1 there is shown a schematic diagram of a device 100 suitable for use with an embodiment of the present invention.
- the device 100 may be used to execute applications and/or system services such as a throughput improvement algorithm or methodology in accordance with an embodiment of the present invention.
- the device 100 may comprise suitable components necessary to receive, store and execute appropriate computing instructions.
- the components may include a processor 102, read only memory (ROM) 104, random access memory (RAM) 106, and input/output devices such as disk drives 108, input device 110 (such as an Ethernet port, a USB port, etc.), display 112 (such as a liquid crystal display, a light emitting diode display, or any other suitable display) and communications link 114.
- the device includes instructions that may be stored in ROM 104, RAM 106, or disk drives 108 and may be executed by the processor 102.
- There may be provided a plurality of communications links 114 which may variously connect to one or more computing devices, such as servers, personal computers, terminals, wireless or handheld computing devices. At least one of the plurality of communications links may be connected to an external computing network through a telephone line or other type of communications link.
- the device may include persistent storage devices such as disk drives 108 which may encompass solid state drives, hard disk drives, optical drives or magnetic tape drives.
- the device 100 may- use a single disk drive or multiple disk drives.
- the device 100 may use a suitable operating system.
- the device 100 may be a router or gateway device arranged to receive data packets from an asymmetric source such as an asymmetric digital subscription line modem which is arranged to receive data from an external network.
- an asymmetric source such as an asymmetric digital subscription line modem which is arranged to receive data from an external network.
- the device 100 includes a software application 116 (or instructions) which cause the device to implement a method or computer program in accordance with an embodiment of the invention.
- an asymmetric device is one which exhibits more capacity (greater bandwidth) downstream (towards the local client) and less capacity (lower bandwidth) upstream (out towards the service provider's network, or the Internet) .
- TCP standard's ability to send data packets downstream over an asymmetric link is limited not only by the physical capacity of the link, but also by the rate at which ACK packets can be sent upstream over that same link.
- TCP Data packets are typically far larger than ACK packets (often 1500 bytes for full Data packets compared to 40 bytes for typical ACK packets) .
- the downlink speed is denoted as D (bytes/sec)
- the uplink speed is denoted as U (bytes/sec) .
- D bytes/sec
- U bytes/sec
- the minimum value of the uplink speed U m i n required to fully utilise downlink capacity D can be calculated to be approximately:
- the TCP protocol is unable to fully utilise all of the downlink capacity D for data transmission, regardless of how large D becomes, due to the inability of any uplink sites being able to receive the requisite number of ACK packets.
- the downstream transmission rate will be limited to approximately:
- U ack may be limited to less than U where the upstream link is being shared by multiple flows of packets, where not all of the ACK packets relate to the TCP session of interest. Therefore, the downstream transmission rate, in the presence of competing traffic in the upstream direction, will be limited to (U ac k/40) *1500 bytes/second.
- the need to send data through the uplink i.e. data other than ACK packets
- the upstream link may be shared amongst various applications running on one or more computing devices that are all connected to the LAN.
- Some applications may require substantial fractions of the capacity in the upstream link.
- the amount of uplink bandwidth available for the sending of ACK packets decreases.
- the interface between the LAN and the broadband access service is a router (or gateway) which accepts packets to be transmitted on a first-come-first- served basis, U ack can be forced to an exceedingly low fraction of U, as the traffic is competing for the upstream link on a first-come-first-served basis.
- a router/gateway (such as the device described with reference to Figure 1) can be programmed to implement a manually configurable scheme for providing minimum bandwidth guarantees to particular traffic in the upstream direction.
- the embodiment described herein provides a method and system for configuring the device 100 to provide (i.e. reserve) a predetermined bandwidth of upstream U for the transmission of TCP ACK packets. That is, the embodiment contemplates determining a value for U aCk and embodying the determined value in the device in a manner which ensures that a certain amount of ACK packets are correctly delivered upstream.
- the predetermined value of U aCk remains fixed. That is, U aCk is set to a value that remains constant irrespective of other traffic demands. This value may be set permanently (for example, by an Internet Service Provider or Network Administrator) or may be varied by an end user, through a software application.
- the device 100 determines or is given a predetermined value for U aCk - Then, as traffic is received by the device 205, ACK packets are identified 210, and prioritised 215 so that the packets are sent upstream with minimal delay.
- U aCk is optimal, which in the example described herein, is denoted as U m i n (i.e. the optimal minimum bandwidth reserved for ACK packets)
- the value is recalculated on a periodic basis, to ensure that the download capacity D is optimised at all times.
- the value of D can fluctuate from time to time as the access service adjusts physical layer parameters to suit line conditions or where contractual parameters set by the customer's internet service provider are changed (for example, a user upgrades from a 256/64k plan to a 1024/128k plan) . Therefore, in order to calculate an optimal value of U m i n , the actual, current value of D must be known.
- the value of D is obtained by probing the downstream physical layer circuitry built into the device 100. Many routers/gateways such as device 100 provide such information through a standard software tool or library function.
- the value of U m i n is calculated to allow TCP downstream data traffic to utilise a predetermined optimal fraction (F) of the downstream capacity D.
- U tn in (B a /B d )*F*D
- B a is the average size of TCP ACK packets
- B d is the average size of TCP Data packets in bytes.
- the term 'optimal' is utilised to denote a condition that is most desirable or advantageous to a user or network.
- the optimal value may be a value of 1 (i.e. 100% usage of the download capacity) .
- the optimal value may be a fraction less than 1 (i.e. under 100% usage of download capacity) .
- an optimal value may not necessarily be the maximum value theoretically available, but may be the maximum value available in light of other constraints, such as the need to reserve uplink bandwidth for other applications .
- the embodiment described herein also contemplates periodically recalculating B a and Ba as the device detects changes in the TCP MSS (maximum segment size) of the downstream TCP traffic. This ensures that U m i n is optimised.
- B a may be adjusted to take into account particular network implementations. For example, some TCP implementations may send one ACK packet for every two TCP data packets (rather than one ACK per TCP data packet) . The amount of upstream bandwidth required to optimally utilise the downstream bandwidth is therefore halved, and correspondingly, the upload bandwidth required to ensure optimal download is also changed.
- the variation in the number of ACK packets uploaded can be accounted for dynamically through the introduction of an optional scaling factor to change the value of B a (the size of an ACK packet) .
- B a is taken to be 40 bytes if one 40 byte ACK packet is uploaded up for each TCP data packet downloaded. However, if one 40 byte ACK packet is uploaded for every two TCP data packets downloaded, then B a can be scaled to 20 bytes to take into account the reduced bandwidth requirements for ACK packets .
- the value of B a can be calculated utilising a mathematical relationship such as :
- X is the number of TCP data packets downloaded for each ACK packet that is uploaded
- B avg is 40 bytes, the size of the average ACK packet.
- the calculation can also be extended to cover cases where D and U m i n do not necessarily vary in a linear manner (e.g. where an Asynchronous Transfer Mode layer sits between the packet layer and the physical link layer) .
- One method for determining the types of packets received by the device 100 is to inspect upstream packets in detail to determine if they are TCP ACK packets. This may be done by inspecting the header of each TCP packet which arrives at device 100.
- all TCP packets of a given size may be forwarded preferentially through the reserved bandwidth.
- the router may exclude from U m j .n any ACK packets that piggyback on larger upstream TCP Data packets going in the reverse direction.
- ACK packet size is fixed
- ACK packets that piggyback on larger upstream TCP Data packets may be ignored. This may be done consciously for the sake of simplicity.
- the device may also identify upstream Data packets that carry an ACK signal for associated downstream packets as packets which should be forwarded preferentially.
- the ACK packets are forwarded through the uplink in a preferential manner. In other words, the ACK packets receive priority.
- the prioritisation of ACK packets may be implemented by utilising any suitable form of queuing system which is arranged to provide the ACK packets with some 'preference' over other packets.
- One methodology is differential queuing and scheduling, which prioritises any ACK packets sent on the upstream link, to a guaranteed minimum of U m i n bytes per second.
- packets may be placed in one of two main queues- ACK or non-ACK.
- the queuing algorithm gives the ACK queue absolute preferential treatment over the non-ACK queue, but only to the guaranteed U m i n value. It will be understood that other queuing algorithms which provide ACK packets with priority may also be utilised. Such variations are within the purview of a person skilled in the art.
- other upstream traffic is capable of utilising all of the available U during periods where there is no TCP ACK traffic.
- the embodiment described herein provides a number of advantages. Firstly, the embodiment may be implemented in either software or firmware, as desired, and is retro- fittable to many network devices such as routers and gateways .
- the embodiment while being capable of being implemented as part of a network standard or protocol, does not require changes to existing standards or protocols in order to operate. Therefore, the embodiment can work harmoniously with existing standards, while being capable of being integrated into future standards .
- the methodology and system optimises download bandwidth on asymmetric devices, thereby enhancing user experience and user satisfaction. This is particularly important in networks and jurisdictions where a large percentage of users utilise asymmetric communication devices.
- asymmetric communication devices One example is Australia, where a large number of Internet users are connected through ADSL modems or satellite links.
- the incremental impact on TCP throughput from the RTT (round trip time) increase perceived by ACKs that are forced to be queued on a congested uplink is improved by ensuring that there is less or no congestion of ACK packets.
- the decreased need to resend data reduces congestion throughout the network as a whole, thereby potentially providing more available bandwidth for all users on the network.
- the embodiments described with reference to the Figures can be implemented via an application programming interface (API) or as a series of libraries, for use by a developer, and can be included within another software application, such as a terminal or personal computer operating system or a portable computing device operating system.
- API application programming interface
- program modules include routines, programs, objects, components, and data files that perform or assist in the performance of particular functions, it will be understood that the functionality of the software application may be distributed across a number of routines, objects and components yet achieve the same functionality as the embodiment and the broader invention claimed herein. Such variations and modifications are within the purview of those skilled in the art.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
The present invention provides a system and method for managing data packets to be sent through an asymmetric network device. the method comrpises the steps of receiving data from at least one computing device, and determining whether the data is acknowledgement data. if so, the upload of the acknowledgement data is prioritised to the asymmetric network device.
Description
A SYSTEM AND METHOD FOR IMPROVING THROUGHPUT IN A NETWORK
DEVICE
Field of the Invention
The present invention generally relates to a system and method for improving throughput in a network device . Embodiments of the invention find particular, but not exclusive, use in asymmetric devices, such as an Asymmetric Digital Subscriber Line (ADSL) modem device.
Background of the Invention
A large amount of data is transferred across the Internet using the Transmission Control Protocol (TCP) Standard.
In the present context, the term 'data' includes emails, data files (whether as email attachments or raw files) , web pages, objects inside web pages (such as images) , non-interactive video or audio transmissions, etc. That is, the term λdata' can be construed to include any type of electronic information that is capable of being sent over an electronic network (including a wireless network) . The TCP standard automatically adjusts the data transmission rate to best suit the apparent network capacity between source and destination. TCP adjusts the transmission rate by attempting to measure (or estimate) apparent network capacity. This is achieved by sending data packets to a destination and monitoring the stream of returned Acknowledgment (ACK) packets from the destination.
TCP adjusts the transmission of data based on the rate at which matching ACK packets return from the destination.
As the Internet is a loosely coupled system of computing systems with no predetermined hierarchy or overarching organisation, transmission of data across any portion of the Internet is inherently prone to loss of packets (known as 'best effort1 service) .
It is for this reason that TCP detects packet loss events by tracking the non-receipt of matching ACK packets. TCP responds to loss events by repeating transmission of lost data packets, and temporarily slowing down the transmission of subsequent data packets.
Network behaviour that interferes with or constrains the free flow of ACK packets from destination to source is known to cause suboptimal data transfer performance from source to destination.
Summary of the Invention
In a first aspect, the present invention provides a system for a method for managing data packets to be sent through an asymmetric network device, comprising the steps of receiving data from at least one computing device, determining whether the data is acknowledgement data, and if so, prioritising the upload of the acknowledgement data to the asymmetric network device .
The method may include the initial step of determining a preferred rate of acknowledgement data to be uploaded to the asymmetric network device, and prioritising the upload of the acknowledgement data until the preferred rate is reached.
The preferred rate may be predetermined (by a user, for example) , or it may be calculated dynamically. Where the preferred rate is calculated dynamically, the dynamic calculation may be a function of the instantaneous download rate, the data packet size and/or the acknowledgement data packet size. The formula
Umin = (Ba/Bd)*F*D
may be used to calculate the preferred rate, where Umin is the preferred rate, B3 is the average size of an acknowledgement packet, Bd is the average size of a data packet, F is a predetermined fraction set by a user, and D is the maximum download capacity through the network device.
where Bavg is the network defined average size of an acknowledgment packet, and X is the number of data packets downloaded for every acknowledgment packet uploaded. All received data may be placed into a queuing structure, such that acknowledgement data is placed in one queue, and the acknowledgement data queue is prioritised.
The step of determining whether data is acknowledgement data may include the step of, inspecting the header within the data packet to determine whether the data is acknowledgement data and/or inspecting the size of the data packet to determine whether the data is acknowledgement data.
Data may be transmitted utilising the Transmission Control Protocol (TCP) Standard.
In a second aspect, the present invention provides a method for a system for managing a device connected to an asymmetric network device, comprising a receiving module arranged to receive data from at least one computing device, and a prioritisation module arranged determine whether the data is acknowledgement data, and if so, prioritise the upload of the data to the asymmetric network device .
In a third aspect, the present invention provides a computing program including at least one instruction which, when loaded on a programmable device, causes the programmable device to perform a method in accordance with the second aspect of the invention.
In a fourth aspect, the present invention provides a computer readable medium incorporating a computing program in accordance with a third aspect of the invention.
Detailed Description of the Drawings
Notwithstanding any other forms which may fall within the scope of the present invention, a preferred embodiment will now be described, by way of example only, with reference to the accompanying drawings in which:
Figure 1 is a diagram illustrating a computing system suitable for implementing a methodology or system in accordance with an embodiment of the present invention; and
Figure 2 is a flowchart illustrating a methodology in accordance with an embodiment of the present invention.
Description of Specific Embodiments
Overview
The system and methodology (and associated software and/or hardware application) in accordance with an embodiment of the invention may be executed on a device such as the example device shown in Figure 1. In Figure 1 there is shown a schematic diagram of a device 100 suitable for use with an embodiment of the present invention. The device 100 may be used to execute applications and/or system services such as a throughput improvement algorithm or methodology in accordance with an embodiment of the present invention.
The device 100 may comprise suitable components necessary to receive, store and execute appropriate computing instructions. The components may include a processor 102, read only memory (ROM) 104, random access memory (RAM) 106, and input/output devices such as disk drives 108, input device 110 (such as an Ethernet port, a USB port, etc.), display 112 (such as a liquid crystal display, a light emitting diode display, or any other suitable display) and communications link 114. The device includes instructions that may be stored in ROM 104, RAM 106, or disk drives 108 and may be executed by the processor 102. There may be provided a plurality of communications links 114 which may variously connect to one or more computing devices, such as servers, personal computers, terminals, wireless or handheld computing devices. At least one of the plurality of communications links may be connected to an external computing network through a telephone line or other type of communications link.
In one particular embodiment, the device may include persistent storage devices such as disk drives 108 which may encompass solid state drives, hard disk drives,
optical drives or magnetic tape drives. The device 100 may- use a single disk drive or multiple disk drives. The device 100 may use a suitable operating system.
The device 100 may be a router or gateway device arranged to receive data packets from an asymmetric source such as an asymmetric digital subscription line modem which is arranged to receive data from an external network.
The device 100 includes a software application 116 (or instructions) which cause the device to implement a method or computer program in accordance with an embodiment of the invention.
It will be understood that the device described in the preceding paragraphs is illustrative only and that the presently described embodiment or other embodiments which fall within the scope of the invention claimed herein may be executed on any suitable computing device, which in turn may be realized utilizing any suitable hardware and/or software. Any device which receives data from and/or sends data to an asymmetric device may utilise an embodiment of the broader invention described herein.
Bandwidth Limitations of Asymmetric Devices when utilising the TCP/IP Standard
The embodiment described herein is applicable to devices which interact with devices that have asymmetric bandwidth characteristics. Examples of such devices include, but are not limited to, an Asymmetric Digital Subscriber Line (ADSL) modem, a cable modem with utilises Data Over Cable Service Interface Specification (DOCSIS) and/or a Wireless Local Area Network (WLAN) .
In the context of the embodiment described herein, an asymmetric device is one which exhibits more capacity (greater bandwidth) downstream (towards the local client) and less capacity (lower bandwidth) upstream (out towards the service provider's network, or the Internet) .
The TCP standard's ability to send data packets downstream over an asymmetric link is limited not only by the physical capacity of the link, but also by the rate at which ACK packets can be sent upstream over that same link. TCP Data packets are typically far larger than ACK packets (often 1500 bytes for full Data packets compared to 40 bytes for typical ACK packets) .
The limitations inherent in a typical implementation of the TCP standard, when sending data packets downstream via an asymmetric device, is best illustrated with reference to an example .
In the example, the downlink speed is denoted as D (bytes/sec) , and the uplink speed is denoted as U (bytes/sec) . For the purpose of this example, it is assumed that there is only a single TCP session utilising the asymmetric link, and the packet sizes are 1500 bytes for full data packets and 40 bytes for ACK packets.
Therefore, the minimum value of the uplink speed Umin required to fully utilise downlink capacity D can be calculated to be approximately:
Umin = D* (40/1500)
However, there may be cases where a value less than Umin is available in the uplink for ACK packets (for example, an application may be utilising a portion of U to send a file to another computer on the uplink) .
Where a value less than Umin is available, the TCP protocol is unable to fully utilise all of the downlink capacity D for data transmission, regardless of how large
D becomes, due to the inability of any uplink sites being able to receive the requisite number of ACK packets.
In other words, for a given value of U, the downstream transmission rate will be limited to approximately:
(U/40)*1500 bytes/second for all D > (U/40)*1500
From this example, a more general relationship may be defined. Define UaCk as the upstream capacity available to carry ACK packets, where Uack <= U (since U is limited by the physical layer of the asymmetric link) .
Uack may be limited to less than U where the upstream link is being shared by multiple flows of packets, where not all of the ACK packets relate to the TCP session of interest. Therefore, the downstream transmission rate, in the presence of competing traffic in the upstream direction, will be limited to (Uack/40) *1500 bytes/second. As stated earlier, the need to send data through the uplink (i.e. data other than ACK packets) results in the limitation of downlink speeds, no matter how fast the downlink speed. In some scenarios, such as a local area network (LAN) connected to the Internet through an asymmetric 'broadband' service, the upstream link may be shared amongst various applications running on one or more computing devices that are all connected to the LAN. Some applications, such as interactive video or audio conferencing, may require substantial fractions of the capacity in the upstream link. As a larger portion of upstream bandwidth is reserved or utilised by the various applications, the amount of uplink bandwidth available for the sending of ACK packets decreases.
Moreover, if the interface between the LAN and the broadband access service is a router (or gateway) which accepts packets to be transmitted on a first-come-first- served basis, Uack can be forced to an exceedingly low fraction of U, as the traffic is competing for the upstream link on a first-come-first-served basis.
Reserving Space for the delivery of ACK Packets
A router/gateway (such as the device described with reference to Figure 1) can be programmed to implement a manually configurable scheme for providing minimum bandwidth guarantees to particular traffic in the upstream direction. The embodiment described herein provides a method and system for configuring the device 100 to provide (i.e. reserve) a predetermined bandwidth of upstream U for the transmission of TCP ACK packets. That is, the embodiment contemplates determining a value for UaCk and embodying the determined value in the device in a manner which ensures that a certain amount of ACK packets are correctly delivered upstream.
In one embodiment , the predetermined value of UaCk remains fixed. That is, UaCk is set to a value that remains constant irrespective of other traffic demands. This value may be set permanently (for example, by an Internet Service Provider or Network Administrator) or may be varied by an end user, through a software application.
The process is illustrated with reference to the flow chart in Figure 2. As a first step 200, the device 100 determines or is given a predetermined value for UaCk- Then, as traffic is received by the device 205, ACK
packets are identified 210, and prioritised 215 so that the packets are sent upstream with minimal delay.
Dynamic allocation of Optimal ACK Packet delivery
However, in another embodiment, there is provided a methodology (and associated software or firmware routine) for calculating an optimal value of UaCk-
To ensure that the value of UaCk is optimal, which in the example described herein, is denoted as Umin (i.e. the optimal minimum bandwidth reserved for ACK packets) , the value is recalculated on a periodic basis, to ensure that the download capacity D is optimised at all times.
The value of D can fluctuate from time to time as the access service adjusts physical layer parameters to suit line conditions or where contractual parameters set by the customer's internet service provider are changed (for example, a user upgrades from a 256/64k plan to a 1024/128k plan) . Therefore, in order to calculate an optimal value of Umin, the actual, current value of D must be known. The value of D is obtained by probing the downstream physical layer circuitry built into the device 100. Many routers/gateways such as device 100 provide such information through a standard software tool or library function.
Once D is known, the value of Umin is calculated to allow TCP downstream data traffic to utilise a predetermined optimal fraction (F) of the downstream capacity D.
Urain is calculated utilising the formula:
Utnin = (Ba/Bd)*F*D
where Ba is the average size of TCP ACK packets and Bd is the average size of TCP Data packets in bytes.
In the context of the embodiment described herein, the term 'optimal' is utilised to denote a condition that is most desirable or advantageous to a user or network. For example, if a user uses the link primarily for download, the optimal value may be a value of 1 (i.e. 100% usage of the download capacity) . However, where a user utilises video conferencing software or other bidirectional software applications which also reserve a portion of the uplink bandwidth, the optimal value may be a fraction less than 1 (i.e. under 100% usage of download capacity) . In other words, an optimal value may not necessarily be the maximum value theoretically available, but may be the maximum value available in light of other constraints, such as the need to reserve uplink bandwidth for other applications . In addition to detecting varying values of D over time, the embodiment described herein also contemplates periodically recalculating Ba and Ba as the device detects changes in the TCP MSS (maximum segment size) of the downstream TCP traffic. This ensures that Umin is optimised.
It will be understood that the value of Ba may be adjusted to take into account particular network implementations. For example, some TCP implementations may send one ACK packet for every two TCP data packets (rather than one ACK per TCP data packet) . The amount of upstream bandwidth required to optimally utilise the downstream bandwidth is therefore halved, and correspondingly, the
upload bandwidth required to ensure optimal download is also changed.
The variation in the number of ACK packets uploaded can be accounted for dynamically through the introduction of an optional scaling factor to change the value of Ba (the size of an ACK packet) .
For example, in most implementations, Ba is taken to be 40 bytes if one 40 byte ACK packet is uploaded up for each TCP data packet downloaded. However, if one 40 byte ACK packet is uploaded for every two TCP data packets downloaded, then Ba can be scaled to 20 bytes to take into account the reduced bandwidth requirements for ACK packets .
To generalise this relationship, the value of Ba can be calculated utilising a mathematical relationship such as :
where X is the number of TCP data packets downloaded for each ACK packet that is uploaded, and Bavg is 40 bytes, the size of the average ACK packet.
The calculation can also be extended to cover cases where D and Umin do not necessarily vary in a linear manner (e.g. where an Asynchronous Transfer Mode layer sits between the packet layer and the physical link layer) .
Identifying ACK Packets
In addition to determining how much bandwidth must be reserved or provided for ACK packets, it is also necessary to identify the ACK packets as they arrive in the device 100, so that they may be preferentially forwarded through the reserved bandwidth without delay.
One method for determining the types of packets received by the device 100 is to inspect upstream packets in detail to determine if they are TCP ACK packets. This may be done by inspecting the header of each TCP packet which arrives at device 100.
Alternatively, if the size of ACK packets is known and fixed, all TCP packets of a given size (e.g. 40 bytes, the typical size for an ACK packet) may be forwarded preferentially through the reserved bandwidth. The router may exclude from Umj.n any ACK packets that piggyback on larger upstream TCP Data packets going in the reverse direction.
In the embodiment where it is assumed that ACK packet size is fixed, ACK packets that piggyback on larger upstream TCP Data packets may be ignored. This may be done consciously for the sake of simplicity.
However, in the embodiment where each packet's header is reviewed, the device may also identify upstream Data packets that carry an ACK signal for associated downstream packets as packets which should be forwarded preferentially.
Preferential forwarding of ACK packets
Once uplink TCP ACK packets are identified, the ACK packets are forwarded through the uplink in a preferential manner. In other words, the ACK packets receive priority. The prioritisation of ACK packets may be implemented by utilising any suitable form of queuing system which is arranged to provide the ACK packets with some 'preference' over other packets. One methodology is differential queuing and scheduling, which prioritises any ACK packets
sent on the upstream link, to a guaranteed minimum of Umin bytes per second.
In more detail, packets may be placed in one of two main queues- ACK or non-ACK. During transmission, the queuing algorithm gives the ACK queue absolute preferential treatment over the non-ACK queue, but only to the guaranteed Umin value. It will be understood that other queuing algorithms which provide ACK packets with priority may also be utilised. Such variations are within the purview of a person skilled in the art.
In one embodiment, other upstream traffic is capable of utilising all of the available U during periods where there is no TCP ACK traffic.
Advantages and Industrial Applicability
The embodiment described herein provides a number of advantages. Firstly, the embodiment may be implemented in either software or firmware, as desired, and is retro- fittable to many network devices such as routers and gateways .
Secondly, the embodiment, while being capable of being implemented as part of a network standard or protocol, does not require changes to existing standards or protocols in order to operate. Therefore, the embodiment can work harmoniously with existing standards, while being capable of being integrated into future standards .
Thirdly, the methodology and system optimises download bandwidth on asymmetric devices, thereby enhancing user experience and user satisfaction. This is particularly important in networks and jurisdictions where a large percentage of users utilise asymmetric
communication devices. One example is Australia, where a large number of Internet users are connected through ADSL modems or satellite links.
As a corollary, the incremental impact on TCP throughput from the RTT (round trip time) increase perceived by ACKs that are forced to be queued on a congested uplink is improved by ensuring that there is less or no congestion of ACK packets. The decreased need to resend data reduces congestion throughout the network as a whole, thereby potentially providing more available bandwidth for all users on the network.
Although not required, the embodiments described with reference to the Figures can be implemented via an application programming interface (API) or as a series of libraries, for use by a developer, and can be included within another software application, such as a terminal or personal computer operating system or a portable computing device operating system. Generally, as program modules include routines, programs, objects, components, and data files that perform or assist in the performance of particular functions, it will be understood that the functionality of the software application may be distributed across a number of routines, objects and components yet achieve the same functionality as the embodiment and the broader invention claimed herein. Such variations and modifications are within the purview of those skilled in the art.
Claims
1. A method for managing data packets to be sent through an asymmetric network device, comprising the steps of receiving data from at least one computing device, determining whether the data is acknowledgement data, and if so, prioritising the upload of the acknowledgement data to the asymmetric network device .
2. The method in accordance with claim 1, comprising the initial step of determining a preferred rate of acknowledgement data to be uploaded to the asymmetric network device, and prioritising the upload of the acknowledgement data until the preferred rate is reached.
3. The method in accordance with claim 2 , wherein the preferred rate is predetermined.
4. The method in accordance with claim 2, wherein the preferred rate is calculated dynamically.
5. The method in accordance with claim 4, comprising the further step of dynamically calculating the preferred rate as a function of the instantaneous download rate.
6. The method in accordance with claim 4 or claim 5, comprising the further step of dynamically calculating the preferred rate as a function of one of the data packet size and the acknowledgement data packet size.
7. The method in accordance with any one of claims 4 to 6, comprising the further step of utilising the formula Umin = (Ba/Bd) *F*D
to calculate the preferred rate, where Umin is the preferred rate, Ba is the average size of an acknowledgement packet, Bd is the average size of a data packet, F is a predetermined fraction set by a user, and D is the maximum download capacity through the network device .
8. The method in accordance with claim 7, comprising the further step of calculating Ba utilising the formula:
Ba = Bavg/X
where Bavg is the network defined average size of an acknowledgment packet, and X is the number of data packets downloaded for every acknowledgment packet uploaded.
9. The method in accordance with any one of claims 1 to
8, comprising the further step of placing all received data into a queuing structure, whereby acknowledgement data is placed in one queue, and the acknowledgement data queue is prioritised.
10. The method in accordance with any one of claims 1 to
9, whereby the step of determining whether data is acknowledgement data comprises the step of, inspecting the header within the data packet to determine whether the data is acknowledgement data.
11. The method in accordance with any one of claims 1 to 9, whereby the step of determining whether data is acknowledgement data comprises the step of inspecting the size of the data packet to determine whether the data is acknowledgement data.
12. The method in accordance with any one of claims 1 to 11, whereby the data is transmitted utilising the Transmission Control Protocol (TCP) Standard.
13. A system for managing a device connected to an asymmetric network device, comprising a receiving module arranged to receive data from at least one computing device, and a prioritisation module arranged determine whether the data is acknowledgement data, and if so, prioritise the upload of" the data to the asymmetric network device.
14. The system in accordance with claim 13, comprising a rate determination module arranged to determine a preferred rate of acknowledgement data to be uploaded to. the asymmetric network device, and provide the information to prioritisation module to prioritise the upload of acknowledgement data until the preferred rate is reached.
15. The system in accordance with claim 14, wherein the preferred rate is predetermined.
16. The system in accordance with claim 14, wherein the preferred rate is calculated dynamically.
17. The system in accordance with claim 16, wherein the determination module dynamically calculates the preferred rate as a function of the instantaneous download rate.
18. The system in accordance with claim 16 or claim 17, wherein the determination module dynamically calculates the preferred rate as a function of one of the data packet size and the acknowledgement data packet size.
19. The system in accordance with any one of claims 16 to 18, wherein the determination module utilises the formula
Umin = (Ba/Bd)*F*D
to calculate the preferred rate, where Umin is the preferred rate, Ba is the average size of an acknowledgement packet, Bd is the average size of a data packet, F is a predetermined fraction set by a user, and D is the maximum download capacity through the network device.
20. The system in accordance with claim 19, wherein the determination module further calculates Ba utilising the formula:
where Bavg is the network defined average size of an acknowledgment packet, and X is the number of data packets downloaded for every acknowledgment packet uploaded.
21. The system in accordance with any one of claims 13 to 20, further including a queuing module arranged to place all received data into a queuing structure, wherein acknowledgement data is placed in one queue, and the acknowledgement data queue is prioritised by the prioritisation module.
22. The system in accordance with any one of claims 13 to 21, wherein the receiving module determines whether data is acknowledgement data by inspecting the header within the data packet to determine whether the data is acknowledgement data.
23. The system in accordance with any one of claims 13 to 21, wherein the receiving module determines whether data is acknowledgement data by inspecting the size of the data packet to determine whether the data is acknowledgement data.
24. The system in accordance with any one of claims 13 to 23, wherein the data is transmitted utilising the
Transmission Control Protocol (TCP) Standard.
25. A computing program including at least one instruction which, when loaded on a programmable device, causes the programmable device to perform the method steps of any one of claims 1 to 12.
26. A computer readable medium incorporating a computing program in accordance with claim 25.
27. A data signal arranged to carry information including a computer programme in accordance with claim 25.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AU2007903063A AU2007903063A0 (en) | 2007-06-07 | A system and method for improving throughput in a network device | |
AU2007903063 | 2007-06-07 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2008148173A1 true WO2008148173A1 (en) | 2008-12-11 |
Family
ID=40093092
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/AU2008/000826 WO2008148173A1 (en) | 2007-06-07 | 2008-06-10 | A system and method for improving throughput in a network device |
Country Status (1)
Country | Link |
---|---|
WO (1) | WO2008148173A1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8194543B2 (en) | 2008-12-18 | 2012-06-05 | Intel Mobile Communications GmbH | Methods of data traffic shaping, apparatus and wireless device |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5495481A (en) * | 1994-09-30 | 1996-02-27 | Apple Computer, Inc. | Method and apparatus for accelerating arbitration in a serial bus by detection of acknowledge packets |
US6424626B1 (en) * | 1999-10-29 | 2002-07-23 | Hubbell Incorporated | Method and system for discarding and regenerating acknowledgment packets in ADSL communications |
EP1303072A2 (en) * | 2001-10-15 | 2003-04-16 | Texas Instruments Incorporated | Improved ADSL downloading with priority transmit queue |
US20070002863A1 (en) * | 2005-06-14 | 2007-01-04 | Microsoft Corporation | Multi-stream acknowledgement scheduling |
-
2008
- 2008-06-10 WO PCT/AU2008/000826 patent/WO2008148173A1/en active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5495481A (en) * | 1994-09-30 | 1996-02-27 | Apple Computer, Inc. | Method and apparatus for accelerating arbitration in a serial bus by detection of acknowledge packets |
US6424626B1 (en) * | 1999-10-29 | 2002-07-23 | Hubbell Incorporated | Method and system for discarding and regenerating acknowledgment packets in ADSL communications |
EP1303072A2 (en) * | 2001-10-15 | 2003-04-16 | Texas Instruments Incorporated | Improved ADSL downloading with priority transmit queue |
US20070002863A1 (en) * | 2005-06-14 | 2007-01-04 | Microsoft Corporation | Multi-stream acknowledgement scheduling |
Non-Patent Citations (1)
Title |
---|
BALAKRISHNAN ET AL.: "The effects of asymmetry on TCP performance", MOBILE NETWORKS AND APPLICATIONS, September 1999 (1999-09-01), pages 219 - 240, XP000875880 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8194543B2 (en) | 2008-12-18 | 2012-06-05 | Intel Mobile Communications GmbH | Methods of data traffic shaping, apparatus and wireless device |
US8755278B2 (en) | 2008-12-18 | 2014-06-17 | Intel Mobile Communications GmbH | Methods of data traffic shaping, apparatus and wireless device |
DE102009044647B4 (en) * | 2008-12-18 | 2014-10-23 | Intel Mobile Communications GmbH | Traffic flow control method, device and wireless device |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2992652B1 (en) | Managing bandwidth allocation among flows through assignment of drop priority | |
US20220417151A1 (en) | Packet transmission system and method | |
EP1535130B1 (en) | Quality of service management in network gateways | |
EP2997707B1 (en) | Enhancing performance of rapid channel changes and other playback positioning changes in adaptive streaming | |
EP3044918B1 (en) | Network-based adaptive rate limiting | |
US8259566B2 (en) | Adaptive quality of service policy for dynamic networks | |
EP2438716B1 (en) | Congestion-based traffic metering | |
JP7638537B2 (en) | System and method for managing data packet communications - Patents.com | |
WO2005107192A1 (en) | System and method for enhancing network quality of service | |
EP2594043A1 (en) | System, method and computer program for intelligent packet distribution | |
US20070248101A1 (en) | Efficient policer based weighted fair bandwidth method and system | |
KR101837637B1 (en) | Streaming method based on Client-side ACK-regulation and apparatus thereof | |
EP3442182B1 (en) | Joint dropping or marking of data packets for traffic congestion control | |
JP2002532959A (en) | Wireless local loop system and methods useful therefor | |
WO2008148173A1 (en) | A system and method for improving throughput in a network device | |
EP2388978B1 (en) | Methods and devices for determining network link load | |
Yoon et al. | Weighted bandwidth sharing scheme to guarantee the video quality in home networks | |
Fetoh et al. | A Framework for Video Transmission Scheduling Using Concurrent Multipath Transfer | |
Lee et al. | Congestion control scheme for UHD video streaming over the Internet | |
Takeo et al. | Application-level QoS of Web access and streaming services with AF service on DiffServ | |
Jain et al. | Review of Quality of Servie (QoS) Issues in Mobile Ad hoc Networks. |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 08756909 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
32PN | Ep: public notification in the ep bulletin as address of the adressee cannot be established |
Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 112(1) EPC (EPO FORM 1205A DATE 17/03/2010) |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 08756909 Country of ref document: EP Kind code of ref document: A1 |