In flight TCP window adjustment to improve network performance

Information

  • Patent Application
  • 20080089230
  • Publication Number
    20080089230
  • Date Filed
    October 17, 2006
    18 years ago
  • Date Published
    April 17, 2008
    16 years ago
Abstract
A system and method for reconfiguring a TCP window in a switch of a network system, where the size of the window is determined based on the operating speed of a work station to which data packets in the window are being sent and the size of the switch buffer. The algorithm includes establishing a connection between a server and the station, where the connection includes TCP data packets. The algorithm identifies a TCP window size requested by the station, and identifies the connection speed of the station in the switch. The algorithm then modifies the TCP window size of the connection if the identified TCP window size does not support the connection speed and the size of the buffer. The algorithm also changes the TCP check-sum based on the new TCP window size.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of a network system; and



FIG. 2 is a flow chart diagram showing a process for changing the size of a TCP window in a network switch in the network shown in FIG. 1.





DETAILED DESCRIPTION OF THE EMBODIMENTS


FIG. 1 is a general block diagram of a network system 10 including a server 12 and work stations 14. Files are transferred back and forth between the server 12 and the stations 14. A particular station 14 may request a file from the server 12. The server 12 will send the file to the station 14 through a switch 16 using an identification number to identify the station 14. The transfer of files and other information between the server 12 and the stations 14 may be controlled by a transmission control protocol (TCP). The TCP may be part of a higher level protocol, such as a server message block (SMB) protocol. A buffer 18 stores data packets for transmission as discussed above. A processor 20 within the switch 16 controls the transfer of the signals through the switch 16 using the TCP.


Each TCP data packet received by the switch 16 is monitored, where the processor 20 in the switch 16 looks at each packet to determine transmission characteristics of the packet, particularly where the packet is to be transmitted. Each TCP window includes a header having a 16-bit field that identifies how big the TCP window can be. A TCP window target size identifies the size of the TCP window that can be handled by the connection speed of the station 14 and the size of the buffer 18. If the size of the TCP window is greater than the target size, then the processor 20 replaces the TCP window size identified in the header with a TCP window size equal to the target size identified by the connection speed of the station 14 and the size of the buffer 18.


When a work station 14 requests a TCP file from the server 12, the 16-bit field in the header of the request message identifies the size of the TCP window that is pre-programmed into the station 14, such as by Windows™. The server 12 responds to the file request from the station 14 in a negotiation to transmit the file through the TCP. During this negotiation between the server 12 and the station 14, the number of data packets transmitted between the server 12 and the station 14 is generally small, and does not present a problem for the size of the buffer 18 and the connection speed of the station 14. As the processor 20 is monitoring the TCP packets being transmitted between the server 12 and the station 14, it will determine whether the requested TCP window size for the station 14 can be supported by the connection speed of the station 14 and the size of the buffer 18. If the processor 20 determines that the requested TCP window size can not be supported by the connection speed of the station 14 and the size of the buffer 18, then it will change the 16-bit field in the header to change the TCP window to a size that will be supported by the connection speed of the station 14 and the size of the buffer 18.


Once the server 20 receives the new TCP window size, it will send data packets for that window size, and the likelihood of dropped packets will be reduced, preferably to zero. The processor 20 will continue to monitor the 16-bit field in the header of the TCP data packets as they are transmitted from the server 20 to the station 14 to ensure that the TCP window size is maintained as previously set.


As discussed above, the processor 20 in the switch 16 adjusts the size of the TCP window based on connection speed of the station 14 and the size of the buffer 18. In an alternate embodiment, the processor 20 can set the TCP window size based solely on the size of the buffer 18 and other switch limitations. Particularly, the processor 20 would change every TCP window size to a predetermined window size for every TCP data packet transmission between the server 20 and the station 14. In one non-limiting embodiment, the TCP window size is 8 k bytes.


Each TCP data packet also includes a check-sum that is used to determine whether the data packet is valid. As is well understood to those skilled in the art, an extra digit or digits, called the check-sum digit(s), are sometimes added to the header of a data packet to check for errors after the data packet has been transmitted. In one embodiment, the check-sum exclusive-ORs a group of bits in the header with the next same size group of bits in the header all the way through the header to provide an accumulated value that must match a predetermined value to establish that the data packet is valid. If the switch 16 changes the TCP window size, it should also change the TCP check-sum to validate the new TCP window size. In other words, any time the data packet is modified, the TCP check-sum is also modified.



FIG. 2 is a flow chart diagram 24 showing the operation of the system 10 for changing the TCP window size as discussed above. At box 26, the server 12 and the particular station 14 establish a connection to transmit a TCP file or other information. During the negotiation between the server 12 and the station 14, the processor 20 is looking at the TCP data packets as identified at box 28. During the negotiation between the server 12 and the work station 14, the work station 14 will request a particular TCP window size. That TCP window size will be identified in a field of a header in the data packets being transmitted between the server 12 and the work station 14. During the negotiation, the window size used by the server 12 is typically small. The processor 20 will identify the requested TCP window size by the station 14 in the field in the header of the data packet at box 30. Also, the processor 20 will identify the connection speed of the station 14 at box 32. The processor 20 will reconcile the requested window size, the connection speed of the station 14, and the size of the buffer 18, and will modify the size of the TCP window at diamond 34 if necessary, as discussed above. If the processor 20 does modify the TCP window size at the diamond 34, then it will change the TCP check-sum at box 36, as also discussed above.


In one example, the station 14 is running Windows™ that typically requires a 64 k byte TCP window size. Further, the connection speed to the station 14 may be 100 mega-bits/per second. The processor 20 in the switch 16 may reduce the window size to an 8 k byte window size, which would accommodate about five TCP data packets.


Based on the discussion above, the technique of changing the size of the TCP windows may offer a number of advantages in a local area network (LAN) environment. This is because the distance that the TCP data packets have to travel is relatively short. Fewer advantages may be realized in a wide area network (WAN) environment where large TCP window sizes can provide performance advantages because of the transmission distances. The advantages in a LAN environment include reducing the size of the buffer 18, possibly providing the buffer 18 and the processor 20 on the same chip, and providing an improved packet throughput in speed mismatched situations with essentially no additional cost.


The foregoing discussion discloses and describes merely exemplary embodiments. One skilled in the art will readily recognize from such discussion, and from the accompanying drawings and claims, that various changes, modifications or variations can be made therein without departing from the spirit and scope of the embodiments as defined in the following claims.

Claims
  • 1. A method for changing transmission control protocol (TCP) window sizes in data transmissions, said method comprising: establishing a connection between a server and a work station, said connection being transmitted through a switch, said connection transmitting TCP data packets;identifying a TCP window size requested by the station in the switch;identifying the connection speed of the station in the switch; andmodifying the TCP window size of the connection in the switch if the identified TCP window size does not support the connection speed.
  • 2. The method according to claim 1 further comprising changing a TCP check-sum in the data packets based on the modified TCP window size.
  • 3. The method according to claim 1 wherein modifying the TCP window size includes modifying the TCP window size when the server and the station are establishing the connection to transmit a file.
  • 4. The method according to claim 1 wherein identifying a TCP window size includes identifying the TCP window size in a header field of a data packet transmitted from the station.
  • 5. The method according to claim 1 wherein modifying the TCP window size also includes determining the size of a buffer in the switch.
  • 6. The method according to claim 1 wherein the modified window size is 8 k bytes.
  • 7. A method for changing transmission control protocol (TCP) window sizes in data transmissions, said method comprising: establishing a connection between a server and a work station, said connection being transmitted through a switch, said connection transmitting TCP data packets;identifying a TCP window size requested by the station in the switch; andchanging the TCP window size of the connection to a predetermined window size in the switch if the identified TCP window size does not match the predetermined window size.
  • 8. The method according to claim 7 further comprising changing a TCP check-sum in the data packets based on the modified TCP window size.
  • 9. The method according to claim 7 wherein modifying the TCP window size includes modifying the TCP window size when the server and the station are establishing the connection to transmit a file.
  • 10. The method according to claim 7 wherein identifying a TCP window size includes identifying the TCP window size in a header field of a data packet transmitted from the station.
  • 11. The method according to claim 7 wherein the modified window size is 8 k bytes.
  • 12. A network comprising: a server;a plurality of work stations; anda switch for controlling the transmission of transmission control protocol (TCP) data packets between the server and the plurality of stations, wherein the stations request a connection between the server and the station, said connection including TCP data packets, said switch identifying a TCP window size requested by the station, identifying the connection speed of the station, and modifying the TCP window size of the connection if the identified TCP window size does not support the connection speed.
  • 13. The network according to claim 12 wherein the switch further changes a TCP check-sum based on the modified TCP window size.
  • 14. The network according to claim 12 wherein the switch modifies the TCP window size when the server and the station are establishing a connection to transmit a file.
  • 15. The network according to claim 12 wherein the switch also modifies the TCP window size based on the size of a buffer in the switch.
  • 16. The network according to claim 12 wherein the modified TCP window size is 8 k bites.
  • 17. A network comprising: a server;a plurality of work stations; anda switch for controlling the transmission of transmission control (TCP) data packets between the server and the plurality of stations, wherein the stations request a connection between the server and the station, said connection including TCP data packets, said switch identifying a TCP window size requested by the station and changing the TCP window size to a predetermined window size if the requested TCP window size does not match the predetermined TCP window size.
  • 18. The network according to claim 17 wherein the switch further changes a TCP check-sum based on the modified TCP window size.
  • 19. The network according to claim 17 wherein the switch modifies the TCP window size when the server and the station are establishing a connection to transmit a file.
  • 20. The network according to claim 17 wherein the predetermined window size is 8 k bytes.