The present invention relates to telecommunications in general, and, more particularly, to quality of service in network paths that do not provide quality-of-service guarantees.
The service provided by a network path is characterized by its “quality of service,” which, for the purposes of this specification, is defined as a function of the bandwidth, error rate, and latency from one node to another.
For the purposes of this specification, the “bandwidth” from one node to another is defined as an indication of the amount of information per unit time that can be transported from the first node to the second. Typically, bandwidth is measured in bits or bytes per second. For the purposes of this specification, the “error rate” from one node to another is defined as an indication of the amount of information that is corrupted as it travels from the first node to the second. Typically, error rate is measured in bit errors per bit or packets lost per packet. For the purposes of this specification, the “latency” from one node to another is defined as an indication of how much time is required to transport information from one node to another. Typically, latency is measured in seconds.
Some applications—for example, e-mail—are generally insensitive to the quality of service provided by the network path but some other applications—particularly telephony and streaming audio and video—are generally very sensitive. While some network paths provide quality-of-service guarantees, many others, including most of those through the Internet, do not. The result is that the provisioning of applications like telephony through the Internet can be problematic.
The need exists, therefore, for an invention that improves the quality of service of a network path.
The present invention is a technique that attempts to provide an improvement in the quality of service of a network path without some of the costs and disadvantages for doing so in the prior art. The illustrative embodiment of the present invention seeks to improve the quality of service of a network path by periodically or sporadically evaluating alternative routes through the network and by sending one or more packets through routes that exhibit, or are believed will exhibit, an acceptable quality of service. Some embodiments of the present invention are particularly well-suited for applications that are sensitive to quality of service issues, such as the provisioning of telephony and streaming audio and video over the Internet.
Typically, neither the source node nor any other node in a packet's path controls its route after it has left the node. Each node usually just passes the packet off to the next node in the network based on the packet's destination address and the node's routing table.
In contrast, the source node in accordance with the illustrative embodiment of the present invention exercises the capability to either:
When the source node has the option sending the packet either:
It should be noted that some embodiments of the present invention can function without changing either the network router's routing tables or how the routers function. Furthermore, the source node can either have an address in the address space of the network or not, and if it does not, it can be either associated with a node having an address in the address space of the network or not (i.e., it can be implemented as a “bump in a wire” which is invisible to the nodes in the network). And still furthermore, in some embodiments of the present invention, a richochet node can be any node in a network, and need have only one link to the network.
The illustrative embodiment comprises: evaluating the quality of service of a first indirect network path from a first node to a second node through a third node, wherein the first network path fails to provide a quality-of-service guarantee; and when the quality of service of the first indirect network path is satisfactory, transmitting a first packet from the first node to the third node, wherein the third node is explicitly instructed to forward the first packet to the second node.
Network 201 comprises a plurality of nodes and their physical interconnections, arranged in the topology shown. It will be clear to those skilled in the art, however, after reading this specification, how to make and use alternative embodiments of the present invention with networks that comprise any number of nodes and have any topology. In particular, it will be clear to those skilled in the art, after reading this specification, how to make and use embodiments of the present invention with the Internet.
Each node in network 201 is capable of receiving a packet and of forwarding that packet to another node, in well-known fashion, based on the destination address in the packet. For example, when node 11 receives a packet from source node 211, which packet contains node 26 as its destination address, node 11 must decide which of its adjacent nodes—nodes 7, 15, and 19—to forward the packet to.
Each node in network 201 decides which adjacent node to give each packet to based on: (1) the destination address in the packet, and (2) a routing table in the node. Table 1 depicts a routing table for node 11 in accordance with the illustrative embodiment of the present invention.
When all of the resources in the network are functioning and there is little network congestion, each node forwards a packet to the preferred next node listed in the routing table. For example, when node 11 receives a packet with the destination address 26, the preferred next node is node 15.
In contrast, when the preferred next node is not functioning or there is congestion at the preferred next node, the routing node can alternatively route the packet to the first alternative next node. For example, the first alternative next node at node 11 for a packet with the destination address 26 is node 7. And when the first alternative node is not functioning or there is congestion at the first alternative next node, the routing node can route the packet to the second alternative next node. The second alternative next node at node 11 for a packet with the destination address 26 is node 19.
When all of the resources in a network are functioning and there is little congestion, each node forwards a packet to the node listed as the entry for the preferred next node and the packet progresses from one preferred next node to the next and the next and so on until it reaches its destination node. For the purposes of this specification, the “primary nominal path” is defined as the chain of preferred next nodes from a source node to a destination node.
When any of the nodes in the primary nominal path are not functioning or are experiencing congestion, a node in the primary nominal path can divert the packet from the primary nominal path onto an “alternative nominal path.” For the purposes of this specification, an “alternative nominal path” is defined as a chain of preferred and alternative next nodes from a source node to a destination node.
Because any one of the nodes in the primary nominal path can divert the packet off of the primary nominal path and onto an alternative nominal path, each primary nominal path usually has associated with it a plurality of alternative nominal paths. For example,
Once the packet has been forwarded onto an alternative nominal path, however, any node in the alternative nominal path can again divert the packet onto yet another alternative nominal path. In some networks, every node in a network is either in (1) the primary nominal path or (2) at least one alternative nominal path. In some other networks, however, there are nodes that are not in either (1) the primary nominal path or (2) any of the alternative nominal paths. The difference depends on:
The resources of a network have the topology of a graph, and the primary and alternative nominal paths have the topology of a subgraph. This significance of this is that the network itself, in the prior art and without the advantage of the present invention, provides a degree of robustness—with respect to bandwidth, error rate, and latency—within the subgraph of nominal paths, but not generally enough for some applications. In contrast, the illustrative embodiment uses both nominal and extranominal path nodes to increase the likelihood that the quality of service goals for the packet are achieved.
For the purposes of this specification, the term “indirect” path is defined as a path from a source node to a destination node with a specified intermediate node, regardless of whether or not the intermediate node is a nominal path node or not. Some, but not all, indirect paths are nominal paths. Conversely, and for the purposes of this specification, the term “direct” path is defined as a path from a source node to a destination node without a specified intermediate node. All direct paths are nominal paths.
At task 701, source node 211 transmits a first packet to destination node 222 through a direct path in well-known fashion.
At task 702, source node 211 evaluates the quality of service of a path from source node 211 to destination node 222 through the direct path. As is well known to those skilled in the art, the quality of service of the direct path is measured by:
At task 703, source node 211 evaluates the quality of service of a first indirect network path from source node 211 to destination node 222 through node 3. In this case, node 3 is an extranominal node, but it will be clear to those skilled in the art how to make and use alternative embodiments of the present invention in which node 3 is a nominal path node.
Source node 211 can evaluate the quality of service of a network path by, for example, having source node 211 transmit a time-stamped test packet to node 3 with an instruction to node 3 to forward the packet to destination node 222 with an instruction to destination node 222 to time stamp the test packet again and return the results to source node 211.
As an alternative, both legs of the path through node 3—from source node 211 to node 3 and from node 3 to destination node 222—can be evaluated independently. For example, source node 211 can transmit a time-stamped test packet to node 3 with an instruction to node 3 to time stamp the test packet again and return the results to the source node. This would inform source node 211 of the quality of service between it and node 3.
Concurrently, node 3 could transmit a time-stamped test packet to destination node 222 with an instruction to time stamp the test packet again and to return the results to node 3. This would inform node 3 of the quality of service between it and destination node 222. Node 3 could then transmit the measured quality of service parameters between it and destination node 222 to source node 211. Source node 211 could combine the information it received from node 3 with the information it has to determine the quality of service of both legs of the path from it to destination node 222 through node 3. It will be clear to those skilled in the art, after reading this specification, how to make and use embodiments of the present invention that perform task 701.
At task 704, when the quality of service of the first indirect network path is more advantageous than that of the direct path, source node 211 transmits a second packet from source node 211 to node 3, wherein node 3 is explicitly instructed to forward the second packet to destination node 222. It is well known to those skilled in the art how to instruct node 3 to forward the packet to destination node 222. For example, the packet could itself carry re-direct instruction or, as an alternative, source node 211 could transmits a signaling packet to node 3 to direct it to forward packets from it to destination node 222.
At task 705, source node 211 evaluates the quality of service of a second indirect path from source node 211 to destination node 222 through node 32. In this case, node 32 is a nominal path node, but it will be clear to those skilled in the art, after reading this specification, how to make and use alternative embodiments of the present invention in which node 32 is an extranominal path node. Source node 211 can evaluate the quality of the path from source node 211 to destination node 222 through node 32 in the same or a different manner than it does in task 703.
At task 706, when the quality of service of the second indirect path (through node 32) is more advantageous than the quality of service of the first indirect path (through node 3) or the direct path, source node 211 transmits a third packet from source node 211 to node 32, wherein node 32 is explicitly instructed to forward the second packet to destination node 222. It is well known to those skilled in the art how to instruct node 32 to forward the packet to destination node 222.
At task 707, source node 211 re-evaluates the quality of service of a path from source node 211 to destination node 222 through the direct path.
At task 708, when the quality of service of the direct network path is more advantageous than that of either the first or second indirect paths, source node 211 transmits a fourth packet from source node 211 to destination node 222 through the direct path.
It is to be understood that the above-described embodiments are merely illustrative of the present invention and that many variations of the above-described embodiments can be devised by those skilled in the art without departing from the scope of the invention. It is therefore intended that such variations be included within the scope of the following claims and their equivalents.
This application claims the benefit of U.S. Provisional Application 60/659,500, filed Mar. 8, 2005, which is also incorporated by reference.
Number | Date | Country | |
---|---|---|---|
60659500 | Mar 2005 | US |