SYSTEM AND METHOD FOR RELIABLE PACKET DATA TRANSPORT IN A COMPUTER NETWORK
A system and method for reliably transmitting a request from a client application (50) running on a client system (13) to a server application (52) running on a server system (15) and receiving a reply to the request, in which functions that provide parameters governing the reliable transport mechanism and message forming and parsing services are provided by the application processes to and called from application-layer protocol stacks (58, 60).
Latest Wi-LAN Inc. Patents:
This application is a continuation of U.S. patent application Ser. No. 10/520,949, filed Dec. 6, 2005, which is a National Stage of Application No. PCT/CA2003/001000, filed Jul. 15, 2003, which claims priority to CA 2,393,502, filed Jul. 15, 2002, the entire contents of which is incorporated by reference herein. The present invention relates to systems and methods for providing for reliable transport of messages over computer networks. More specifically, the present invention relates to a system and method for providing reliable transport of messages over a computer network that includes an unreliable data link such as a wireless link in a wireless network.
BACKGROUND OF THE INVENTIONTo understand the context of the present invention it may be helpful to the reader to have a concrete, but very simple exemplary computer network, such as that shown in
Likewise, the server host computer 14 includes a CPU 26, memory 28 and an operating system 30. CPU 26 runs the operating system 30 of the server host computer 14 as well as server-side network applications. In addition, the server host computer 14 interfaces with the communications network 22 through a communications interface 32.
The elements of a simple computer network described above are known to those of ordinary skill in the art and will not be described further herein.
A client-side network application must rely on the computer network's transport system to communicate requests (sometimes referred to as “remote procedure calls”or “RPCs”) to a server-side network application. Typically, a software interface, usually referred to as a “socket”, is provided by an operating system 20, 30 for a network application to gain access to the transport system. On the client side, a socket is provided into which a client application can send requests to be transported to the server application. Similarly, on the server side, a socket is provided from which the server application can receive requests sent by the client application and into which the server application can send replies that need to be transported to the client application. Typically, if the computer network's transportation system is based upon the Internet Protocol (“IP”), network applications that need reliable transport use either the Transmission Control Protocol (“TCP”) or include their own procedures to provide reliable transport using the User Datagram Protocol (“UDP”). In the latter case, this means that each time a network application is written for or ported to a new network configuration, significant effort is generally required to provide optimal reliable transport.
For example, a client application may need to send requests to a server application through a transport system that includes a wireless link. The transport system may have a high degree of error correction built in and may include a dedicated channel for some requests that the client applications may wish to send to some server applications. In such a situation, the reliable transport mechanisms built into TCP are not optimal for requests transmitted to all server applications over the wireless link. Because lost requests are very likely to be due to data loss in the wireless link rather than collisions or buffer overflow due to congestion, for urgent requests (e.g., for signaling that a user has picked up a telephone handset in an voice over Internet application) that will pass through the wireless link it may be preferable to retransmit an apparently lost request with a relatively long (in computer terms), but constant, delay between retransmissions and with a small hard limit on the number of retransmissions before an error is reported. However, for requests that do not pass through the wireless link or are less urgent, but which must be delivered, it may be preferable to have an initially shorter delay between retransmissions, a retransmission delay that increases linearly, and a very large number of retransmissions before an error is reported. In other cases, a protocol that handles retransmission in the manner in which TCP handles retransmissions may be desirable. Moreover, conditions in the network may change with interference in the wireless link or loading of the wire-line portion of the network, even if the network is dedicated to the network application (i.e., is not a public network like the Internet) and the radio spectrum used for the wireless is dedicated to the network.
Implementing a network application that can reliably handle remote procedure calls has in the past been done by either living with the limitations of TCP or building reliable transport into the network application and using UDP. For example, application-layer protocols such as Media Gateway Control Protocol (“MGCP”) or Session Initiation Protocol (“SIP”) include specifications for reliable transport that can be implemented in network applications that use remote procedure calls for signaling so that the network application itself provides reliable data transport. However, doing this adds additional complexity to the network application and means that the network application must be modified or at least tuned whenever changes occur in the network such that remote procedure calls are transported over paths having new characteristics or whenever remote procedure calls are to be made that have different requirements for timing and reliability. It would be preferable if characteristics of reliable transport mechanism provided for a specific client application that must make remote procedure calls to a specific server application could be changed without modifying the application.
For example, in Voice-Over-Internet-Protocol (“VOIP”) applications, TCP and UDP are not optimal if a wireless link is involved. Such applications, if they are to provide carrier-grade voice communication, need to reliably establish a communication channel as soon as possible after a subscriber picks up a telephone handset. While such applications can tolerate some degree of media data loss in the digitized voice signal once a connection is established, signaling messages must be highly reliable if subscriber expectations raised by past experience with the Public Switched Telephone Network (“PSTN”) are to be satisfied. Network applications such as VOIP applications are typically implemented in accordance with application-layer protocols such as MGCP and SIP in which reliable transport aspects are intermingled with the application-specific aspects of the protocol. Such applications directly use the services of a transport layer that implements the UDP or possibly the TCP over an IP network.
There is a need for a method and system that provides an application layer that can be adapted or adapt itself to network applications and transport conditions without revising the underlying code in either the network application or the transport layer.
SUMMARY OF THE INVENTIONThe inventor, in considering how the task that a network applications programmer faces in writing or porting applications to a new network operating system could be simplified without sacrificing flexibility, concluded it would be preferable to separate as much as possible of the reliable transport mechanism from the network application while retaining UDP as an underlying transport layer. One way to accomplish simplification for the programmer is that typified by TCP; in TCP the reliable transport mechanism is built into the transport layer with little that the application programmer can do to change its characteristics to suit network conditions.
Although a new transport layer protocol to replace TCP might be an answer, the inventor realized that to make the reliable transport mechanism flexible (in way that TCP is not), it would be preferable to provide the programmer with a plurality of reliable transport “personalities”. While such personalities could be built into a transport layer protocol supplanting TCP, the inventor considered that it would be preferable to split the reliable transport mechanism into (1) a new application-layer protocol stack that would provide sockets to the application and use the services provided by UDP and (2) a set of personality functions that would be compiled and linked with the application, but called by the new protocol stack to perform reliable transport-related tasks. Each set of functions would constitute one discrete personality of the reliable transport mechanism.
An application programmer in writing a network application would make calls to the new protocol stack when opening a socket and sending and receiving data. The calls that the application would make would be the same regardless of the personality selected, so that the application programmer could change the desired personality by simply re-linking the application with a different set of personality functions. The application, when opening a socket, would simply provide the new protocol stack with a set of pointers to the functions for the desired personality. Alternatively, more than one set of compiled personality functions might be linked to the application and an application might then open sockets with sets of pointers to different sets of functions for communication with different server applications.
The new protocol stack, in providing reliable transport, calls the personality functions where necessary to determine parameters needed for providing reliable transport. The personality functions provide the reliable transport protocol with flexibility. For example, if no reply is received to a request, a personality function might be called and return the timeout interval that the new protocol stack should wait before retransmitting a message. The function could calculate a time based by various back-off strategies, it could return a predetermined timeout interval, or it could adaptively calculate a timeout interval based upon current conditions.
An application programmer would be provided with the new protocol stack, the specifications for making calls to the protocol stack, and a library of sets of personality functions. The application programmer could select one or more sets of personality functions to use or could, if necessary, write a custom set of personality functions for use with the network application.
As currently implemented, the personality functions are generally used by the new protocol stack to (1) parse messages received from the transport layer, (2) add headers or trailers to requests or replies to form messages for the protocol stack to send to the transport layer, and (3) provide retransmit and reply cache timer intervals for use by the new protocol stack. For example, the following are done by the personality functions in one embodiment of the invention: setting up a connection; wrapping a payload (the request or reply provided to the stack by the application process) in a header to form a message to be sent to the transport layer; determining a time-out interval for the i-th retransmission of a message; determining a total timeout interval allowed for all retransmissions of a message; and parsing the messages received from the transport layer to determine the type of message (request, reply, provisional reply, or acknowledgement) for the stack.
Generally, personality functions could be used to determine any parameter of a reliable transport mechanism, handle creation and parsing of headers, and modify the data being transported. For transmissions sent between network applications that expect data to be encoded differently, personality functions could modify the payload or add additional data to the message.
Three examples of personalities are: a personality for over-the-air requests that provides frequent retransmissions with a hard limit on how many retransmissions are made before an error is reported; a personality for over-the-backhaul requests that provides exponential back-off assuming that losses could be due to congestion; and a personality for billing requests that provides retransmissions for a very long time before giving up.
Preferred embodiments of the present invention will now be described, by way of example only, with reference to the attached Figures, wherein:
Below the blocks in
In a preferred embodiment of the invention a new protocol referred to here as the “ART Protocol” is implemented in the application layer 54. On the client side the ART protocol is represented by a client-side ART protocol stack 58 and on the server side the ART protocol is represented by a server-side ART protocol stack 60, both within the application layer 54. As is common is this art, software implementing a protocol is referred to as a “stack” and processes temporarily created by such software to handle communication with a particular remote host are referred to as “sockets”. Typically stacks 58, 60 would be identical; each would create sockets for handling transmission of requests or replies to requests when called by an application, such as client application 50 and server application 52, that wishes to send requests or replies to requests to an application elsewhere in the computer network 10.
The transport layer 56 and lower protocol layers 61 are conventional in the embodiment shown in
Generally, as illustrated schematically in
As shown in
The reliable transport provided by the ART protocol is illustrated generally by examples in
The request message 42 then proceeds through the communications network 22 and is received from the server-side transport layer protocol stack 59 by the server-side ART protocol stack 60. An ART socket created by the server-side ART protocol stack 60 handles the request message 42 as follows: (4) the payload (the request 40 itself) in the request message 42 is delivered to the server application 52; (5) when a reply is received from the server application process 52, a reply cache timer interval 74 is started; (6) a reply message 76 is formed having the reply from the server application process 52 as a payload and a header 43 including a type code 46 that indicates that it contains a reply and a sequence number 48 that is the same as sequence number of the request message 42; (7) a copy of the reply message 76 is stored in a reply cache by the server-side ART protocol stack 60; and (8) the reply message 76 is handed over to the server-side transport layer protocol stack 59 for transmission to the client-side ART protocol stack 58.
When the reply message 76 is received by the client-side ART protocol stack 58, then: (9) the payload (the reply from the server application process 52) is delivered to the client application 50; (10) an acknowledgement message 80 is formed with a header including a type code 46 indicating that it is an acknowledgement message and the sequence number of the request message 42; and (11) the acknowledgement message 80 is handed over to the transport layer protocol stack 57 for transmission to the server-side ART protocol stack 60.
When the acknowledgement message 80 is received by the server-side ART protocol stack 60, then the cached reply message 76 in the reply cache is deleted and a record of the sequence number 48 is stored. When the reply cache timer interval 74 expires, the stored record of the sequence number 48 of the request message 42 is also deleted.
In the exchanges of messages illustrated in
As will be apparent from the above discussion of
In addition to providing flexible and easy selection of timer parameters, the use of personalities can allow the structure of messages sent and received by an ART protocol stack to be changed by changing the personality. In particular, if a personality provides message creating and parsing functions for use by the ART protocol stack, then the structure of the ART header could be different for different personalities, without changing the application or the ART protocol stack. For example, a personality could provide a header that includes space for 32-bit sequence number. Further, by providing appropriate message creating and parsing personality functions a personality could re-encode or supplement data contained in request or reply so that the client-side of one network application could communicate with the server-side of a different network application even though the two network applications use incompatible data encoding and message structures.
More specifically, the following are the calls that a client application 50 can make to the client-side ART stack 58 in a present embodiment of the invention: ART_open, to open a client ART socket; ART_set_tos, to set the Type of Service (ToS) for the underlying IP protocol; ART_connect, to connect the client ART socket to a server ART socket; ART_request_reply, in synchronous operation, to form and send a request message 42 including the request 40 provided by the client application 50, wait for a reply message 76, and return the reply to the client application 50; ART_send_request, in asynchronous operation, to form and send a request message 42 using the request 40 provided by the client application 50 and return the sequence number 48 of the request message 42 to the client application 50 without waiting for a corresponding reply message; ART_recv_reply, in asynchronous operation, to wait for a reply message 42 to the request message 40 having a specific sequence number 48 or any request message and return the reply to the client application 50; and ART_close, to close the client ART socket.
The following are the calls that a server application 52 can make to the server-side ART stack 60 in the present embodiment of the invention: ART_open, to open an server ART socket; ART_set_tos, to set the Type of Service (ToS) for the underlying IP protocol; ART_recv_request, to wait for a request message and return the request to the calling server application 52; ART_send_provisional, to send a provisional reply message; ART_send_reply, to send a reply message and cache the reply message; and ART_close, to close a server ART socket.
A call to open an ART socket (ART_open) must include a structure that contains the pointers to the personality functions. The following are the personality functions that are called by the client-side ART protocol stack 58: open( ), a function that creates data structures needed for a new socket, returns a starting sequence number, a minimum and maximum sequence number, header and trailer sizes, and the number of retransmissions of a request before an error is reported; connect( ), a function that sets up the connection to the server ART socket created by the server-side ART protocol stack 60, including, if necessary, handshaking; wrap_request( ), a function to form a request message 42 by adding a header 43 to a request 40 provided by the client application 50; retransmit_timer( ), a function that returns a retransmission timer interval 70 for the i-th retransmission when called by the client-side ART stack 58 upon sending a request message 42 to the transport layer 56 and when the retransmission timer interval 70 before a reply message is received; parse( ), a function to parse a message received by the client-side ART stack 58 to extract the sequence number 48 and type code 46 of message from an ART header 43, extract any payload in the message, and if the type indicates that the message is a provisional reply, then change the retransmission timer interval 70 to delay its expiration; rtd_update( ), a function that is called when a reply message is received by client-side ART stack 58 to update with the round trip time any data kept by the personality functions for use in determining timer settings; ack_reply( ), a function to send an acknowledgement when a reply message has been received and returned to the client process; and close( ), a function that destroys any data structures created for a specified ART socket.
The following are the personality functions that are called by the server-side ART protocol stack 60: open( ), to create data structures needed for a new socket; parse( ), to parse a message received by the server-side ART protocol stack 60 to extract the sequence number and type of message from the header, and extract any payload in the message; wrap_reply( ), to form a reply message by adding a header to a reply provided by the server application or to form a provisional reply message; reply_cache _timer( ), that returns a cache timer interval 74 when called by the server-side ART stack upon receipt of a request message from the transport layer; and close( ), to destroy any data structures created for a specified socket.
ART protocol stacks also include the following utility functions (“personality utility functions”) that may be called by the personality functions: ART_get_priv( ), to get a private personality state data maintained for a particular socket; ART_timer_request( ), to maintain a private timer for a personality; ART_timer_cancel( ), to cancel a private timer kept by a personality; ART_csend( ), to send a message to a client-side ART stack in situations in which a message needs to be sent without receiving a call to do so from the server application; ART_ssend( ), to send a message to a server-side ART stack in situations in which a message needs to be sent without receiving a call to do so from the client application; ART_defer_retransmission( ), to modify the retransmission interval 70 when the parse function has determined that a provisional reply has been received; and ART_reply_cache_clear( ), to clear the payload of a cached reply message when the parse function has determined that an acknowledgement has been received.
As well as being embodied in a method for providing reliable transport, the invention may be embodied in the host computers in a computer network such as computer network 10 illustrated in
The following describes in more detail the actions taken by the client-side ART protocol stack 58 and the server-side ART protocol stack 60 in a current embodiment in reliably transporting a request from a client application to a server application.
Client-Side ART Protocol StackWhen a command is received from a client application to open a client socket: call the open personality function to have the personality allocate any per-connection storage it may need to keep data.
When a command is received from the client application to connect the client socket to a server application: call the connect personality function to obtain an initial sequence number, a range of allowable sequence numbers, a maximum number of retransmissions, and header and trailer sizes, and to allocate resources to needed to support the client socket.
When a command is received from the client application to transmit a request to the server application: determine the next sequence number; call the wrap request personality function to wrap the request in a request message having a header containing the sequence number and a message type code indicating that the request message contains a request; call the retransmit timer personality function to obtain a retransmit timer duration for setting the retransmit timer for the request; start the retransmit timer; send the request message to the transport layer for transmission to the server application; and if the command to transmit the request did not block inside the ART stack until a reply was received or all retransmit times expired, then return the sequence number to the client application.
When a message is received from the transport layer: call the parse personality function to obtain the message type, sequence number of the message, and the payload, if any, and if the message type and sequence number indicates that the message is a provisional reply to the request, to modify the retransmit timer to delay its expiration; if the message type returned by the parse personality function indicates that the message contained a reply as a payload, then if the sequence number returned matches an outstanding request, then if the command to transmit the request specified that the reply be returned to the client application upon its receipt from the transport layer, or the client application, since sending the command to transmit the request, has sent a command to return the reply upon its receipt from the transport layer, then return the reply to the client application, but otherwise store the reply.
When a command is received from the client application to return a reply that is received to the request and the reply has been received and stored: return the reply to the client application.
After the reply is returned to the client application: call the acknowledgement reply personality function, which may send a message to the transport layer for transmission to the server application acknowledging the return of the reply to the client application, the message containing the sequence number and an indication that the message is an acknowledgement to the reply message.
If no message having a header containing the sequence number and a type code indicating that the message contains a reply has been received before the retransmit timer has expired, then repeatedly: call the retransmit timer personality function to obtain a new retransmit timer setting for setting the retransmit timer; set and start the retransmit timer; and send the request message to the transport layer for transmission to the server application, until the retransmit timer has expired the maximum number of times or until a message having a header containing the sequence number and a type code indicating that the message contains a reply is received from the transport layer,
but if the retransmit timer has expired the maximum number of times and no such message has been received, then: report a transmission error to the client application and destroying any subsequent messages having a header containing the sequence number until the sequence number is assigned to a new request message.
When a command is received from the client application to close the client socket, call the close personality function to free up any resources allocated to support the client socket. Server-Side ART Protocol Stack
When a command is received from the server application to open a server socket: call the open personality function to allocate resources needed to support the server socket.
When a message is received from the client application: call the parse personality function to obtain the message type, the sequence number of the message, and the request, if the message type indicates that the message contained a request, and then if a request is returned by the parse personality function, return the request to the server application if a command was previously received from the server application to receive a request from the client application, but otherwise store the request for future retrieval by the server application.
If, after delivery of the request to the server application, a command is received from the server application to send a provisional reply, then: call the wrap personality function to form a provisional reply message having a sequence number and a message type code indicating that the message is a provisional reply to the request message, and then send the provisional reply message to the transport layer for transmission to the client application.
When a command is received from the server application to transmit a reply to the client application: call the wrap reply personality function to wrap the reply in a header containing the sequence number and a message type code indicating that the request message contains a reply, call the reply cache timer personality function to obtain a reply cache timer interval for setting a reply cache timer that counts down from the setting, start the reply cache timer, send the resulting message to the transport layer for transmission to the client application, and cache a copy of the reply message.
When a message is received from the client application subsequent to the first message containing the request: call the parse personality function to obtain the message type and sequence number of the message, and to delete the payload from the cached reply message if the message contains an indication that the message is an acknowledgement to a cached reply message; and if the message type indicates that the message contains a request and a cached reply message has the same sequence number, then resend the cached reply message to the transport layer for transmission to the client application.
When the reply cache timer interval expires: delete the cached reply message.
When a command is received from the server application to close the server socket: call the close personality function to free up any resources allocated by the personality functions.
The above-described embodiments of the invention is intended to be examples of the present invention, and alterations and modifications may be effected thereto by those of skill in the art, without departing from the scope of the invention which is defined solely by the claims appended hereto.
Claims
1. A method, at a client computer, for reliably transmitting requests for exchange of messages between a client application running on the client computer and a server application running on a server computer, comprising:
- maintaining a plurality of personality functions;
- selecting a path between the client application and the server application;
- selecting a first set of personality functions pertinent to one or more communication links of the path, based on the requirements of the one or more communication links and the client application requirements; and
- linking the client application with the first set of personality functions.
2. A method as claimed in claim 1, wherein the personality functions of the set of the personality functions are called by the client application to perform reliable transport-related tasks.
3. A method as claimed in claim 2, wherein a personality function determines one or more parameters for a reliable transport-related task.
4. A method as claimed in claim 1, wherein a personality function performs one of:
- parsing messages received from the transport layer;
- adding headers or trailers to requests or replies to form messages for the protocol stack to send to the transport layer, or
- providing retransmit and reply cache timer intervals for use by the server application.
5. A method as claimed in claim 1, wherein a personality function performs one of: handling creation and parsing of headers, or modifying the data being transported.
6. A method as claimed in claim 1, wherein a personality function modifies the payload or adds additional data to a message for transmissions sent between network applications that expect data to be encoded differently.
7. A method as claimed in claim 1, wherein a personality function performs one of:
- setting up a connection;
- wrapping a payload in a header to form a message to be sent to the transport layer;
- determining a time-out interval for the i-th retransmission of a message;
- determining a total timeout interval allowed for all retransmissions of a message; and
- parsing the messages received from the transport layer to determine the type of message for the client application.
8. A method as claimed in claim 1 wherein a message is one of a request, a reply, a provisional reply, or an acknowledgement.
9. A method as claimed in claim 1, wherein the plurality of personality functions includes at least a personality for over-the-air requests, a personality for over-the-backhaul requests and a personality for billing requests.
10. A method as claimed in claim 9, wherein the personality for over-the-air requests provides frequent retransmissions with a hard limit on how many retransmissions are made before an error is reported.
11. A method as claimed in claim 9, wherein the personality for over-the-backhaul requests provides exponential back-off assuming that losses could be due to congestion.
12. A method as claimed in claim 9, wherein the personality for billing requests provides retransmissions for a very long time before giving up.
13. A method as claimed in claim 3, wherein the one or more parameters includes a time-out period for the i-th transmission of a request to be made before an error is reported.
14. A method as claimed in claim 3, wherein the one or more parameters includes a total allowed number of transmissions of the request message to be made before an error is reported.
15. A method as claimed in claim 3, wherein the one or more parameters includes a time-out period for a reply cache timer.
16. A method as claimed in claim 1, wherein the plurality of personality functions includes a function that parses a message and returns a reply message which includes a type and sequence number of that message.
17. A method as claimed in claim 16, wherein the reply message further comprises a payload if the message includes a payload, the payload.
18. A method as claimed in claim 1, wherein, if a reply message received by the client application from the server application contains a sequence number of a request message and a type code that indicates that it is a provisional reply message to the request message, then a current time-out period for retransmission is modified to delay its expiration.
19. A method as claimed in claim 1, further comprising:
- wrapping a request in a payload field of a message;
- starting a retransmission timer established based on the selected set of personality functions; and
- transmitting the message to the server computer along the path.
20. A method as claimed in claim 1, further comprising:
- selecting an alternative path between the client application and the server application;
- selecting a second set of personality functions based on the requirements of communication links of the alternative path and the client application requirements, and
- linking the client application with the second set of personality functions.
Type: Application
Filed: Jan 23, 2014
Publication Date: Jul 17, 2014
Applicant: Wi-LAN Inc. (Ottawa)
Inventor: Mark Frazer (Toronto)
Application Number: 14/162,341