The present invention generally relates to routing of data in a network. The invention relates more specifically to a method and apparatus for constructing a backup route in a data communication network.
The approaches described in this section could be pursued, but are not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, the approaches described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.
In computer networks such as the Internet, packets of data are sent from a source to a destination via a network of links (communication paths such as telephone or optical lines) and nodes (usually routers directing the packet along one or more of a plurality of links connected to it) according to one of various routing protocols.
De-activation of a network component, i.e. a link or a node, either by component failure or by planned downtime needs to be managed in order to avoid the risk of packet loss. In known systems, such de-activations cause routing transitions to take place, during which, distributed routing algorithms may open up an alternative route. However such transitions can be slow, of the order of seconds before convergence and in the interim data can be lost. Although packet loss is commonly dealt with by higher level protocols that re-send packets, the inherent delays can adversely affect time critical functions such as voice and pseudo-wire traffic.
Various solutions have been proposed for providing backup routes.
For example in Multi-Protocol Label Switching (MPLS) fast re-route, pre-configured backup paths are provided for destinations, as described in the document entitled “MPLS Traffic Engineering Fast Reroute—Link Protection” available at the time of this writing in the file ‘frr.pdf’ in directory “univercd/cc/td/doc/product/software/ios120/120newft/120limit/120st/120st16” of the domain “cisco.com” on the World Wide Web. However MPLS backup paths rely on source routing.
Various other proposals based on link state routing rely on “downstream paths” according to which a node determines whether an alternative path to a destination node is available which will not simply loop a packet back to it (i.e. the packets will travel “downstream”). Examples of such proposals are the Internet Draft of Kini, Yang, dated May 2002 entitled “Traffic Restoration in Links State Protocols using Neighbor's Shortest Path” available at the time of this writing in the file ‘draft-kini-traf-restore-nsp-00.txt’ in directory “internet-drafts” of the domain “ietf.org” on the World Wide Web. A further example is Srinivas Vutukury, “Multi-Path Routing Mechanisms for Traffic Engineering and Quality of Service in the Internet”PhD Thesis, computer Science, University of California, Santa Cruz, March 2001. However such solutions will not work if no downstream path is available.
Zhang Yang and Jon Crowcroft in the paper “Shortest Path First with Emergency Exits” ACM SIGCOMM Computer Communication Review Volume 209, Issue 4 (September 1990) propose a solution according to which, for a given destination node an alternative path (AP) is created to the shortest path (SP) for a specified node to the destination using a downstream path (i.e. a path which will get a packet closer to its destination than the current node) identified by calculating whether any of the specified node's neighbor nodes can reach the destination without looping back to the specified node. If, for any destination in the network, an AP is not available, then the specified node sends a message to each of its neighbors to assess whether any of their neighbors can provide a downstream path to the destination. If not then the message is propagated out once again until an “exit” to the destination node is identified, providing a “reverse alternative path” (RAP). The specified node maintains a table, for every destination, of the SP and AP and, where an AP is not available an RAP.
Various problems arise with this approach. First of all because it relies on a signaling protocol in order to establish whether an RAP is available, the process is time-and bandwidth-consuming. Furthermore in order to forward a packet to an exit in an RAP the source has to force it upstream, potentially over a number of hops which requires source routing. As a result an additional protocol is overlaid on the link state protocol and the processing burden of the specified node is also increased.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
a is a representation of a network that illustrates an overview of a method for constructing a backup route;
b is a flow diagram illustrating a high level view of a method for constructing a backup route;
a is a network diagram illustrating considerations relevant to constructing a backup route;
b is a variant network diagram to that of
A method and apparatus for constructing a backup route is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
Embodiments are described herein according to the following outline:
1.0 General Overview
2.0 Structural and Functional Overview
3.0 Method of Constructing a Backup Route
4.0 Implementation Mechanisms—Hardware Overview
5.0 Extensions and Alternatives
1.0 General Overview
The needs identified in the foregoing Background, and other needs and objects that will become apparent for the following description, are achieved in the present invention, which comprises, in one aspect, a method of constructing a backup route in a data communications network having as components nodes and links. The backup route is calculated from a repairing node storing a network topology around an adjacent component which can be, for example, an adjacent link or an adjacent node joined by an adjacent link. In one embodiment, there is derived from the stored topology a first set of nodes reachable from the repairing node without traversing the adjacent component. There is then derived a second set of nodes from which a neighbor node of the adjacent component is reachable without traversing the adjacent component. A backup route is then constructed around the adjacent component via an intermediate node. The intermediate node is in the intersection of the first and second sets.
As a result the method allows a backup route to be constructed such that, as long as the packet reaches the intermediate node, it will progress towards its destination using normal forwarding and without traversing the component that has failed or otherwise been deactivated. Furthermore there is no need to send queries to other nodes in order to determine the route as the first and second sets of nodes are derived at the first node.
In other aspects, the invention encompasses a computer apparatus and a computer-readable medium configured to carry out the foregoing steps.
2.0 Structural and Functional Overview
The method can be further understood with reference to the embodiment shown in
Node A computes a first set of nodes comprising the set (which can be termed the “P-space 18”) of all nodes reachable according to its routing protocol from node A, other than nodes reachable by traversing the link 16. Node A then computes a second set of nodes comprising the set of all nodes from which node B is reachable without traversing the link 16 represented by space 20 (the “Q-space”). In one embodiment the P-space and Q-space are pre-computed. The method then determines whether any intermediate nodes exist in the intersection between P-space and Q-space and in the example shown it will be seen that there is one such node, node X designated 22. As a result, in the event of the failure of the link 16 packets of data can be sent from node A via a link designated 24 (which may of course be a succession of links and nodes) as far as the intermediate node X and then via a further link designated generally 26 to the target node B, which again may be a series of links and nodes. The links 24 and 26 can be viewed together as a “virtual” link forming a repair path in the event that link 16 fails or an alternative route is otherwise required.
The labels “P-space” and “Q-space” are arbitrary and used for convenience, and other embodiments may use any other label for the respective sets of nodes.
b is a flow diagram illustrating a high level view of a method of constructing a backup route. In block 140 a P space is computed. In block 142 a Q space is computed. In block 144 an intermediate node in the intersection between P space and Q space is identified and in block 146 a repair path is constructed. As a result the path A×B shown in
Because the P space and the Q space are derived based on the inherent routing protocol, no additional routing protocol is required on implementation of the method. In one embodiment, routing in the network 10 is governed by a link state protocol, the nature of which is discussed generally below, but it can use any appropriate protocol which, like the link state protocol, ensures that all nodes have all relevant data in order to derive a set of reachable nodes for other nodes on the network. In the present embodiment, all nodes pre-compute backup routes for all adjacent components as a result of which, as soon as a node detects de-activation of an adjacent component or otherwise needs an alternative route, that route is immediately available. As a result packet loss is minimized. Because the link state protocol is effectively undisturbed according to this method the fact that a repair path has been used is transparent to the remainder of the network. In the example discussed, backup routes are computed around an adjacent node, for example by constructing a Q-space for each neighbor node (as target node) of the adjacent node in block 142.
Where appropriate the method avoids packets being sent to the intermediate node X looping back to A along virtual link 24 by tunneling the packet to node X. In that case the intermediate node X comprises the tunnel end point.
In a further optimization the P-space 18 is extended in block 140 to include additional nodes within one hop of the nodes in the P-space. In that case the packet can be tunneled to the adjacent node in normal P-space with the instruction that the packet should be forwarded to the additional node, for example using “directed forwarding”In a further optimization the P-space is extended in block 140 by including in it all nodes reachable by neighbors of A without traversing the link 16. The method in this embodiment and its optimizations are discussed in more detail below.
3.0 Method of Constructing a Backup Route
The method described herein can be implemented according to any appropriate routing protocol whereby a node in a network has sufficient information to predict the forwarding behavior of other nodes in a stable network. Generally, link state protocols such as Intermediate System to Intermediate System (IS-IS) or Open Shortest Path First (OSPF) are appropriate protocols. Link state protocols of this type will be well understood by the skilled reader and are not described in detail here, but a brief summary is provided to highlight the aspects relevant to the method described herein.
The link state protocol relies on a routing algorithm resident at each node. Each node on the network advertises, throughout the network, links to neighboring nodes and provides a cost associated with each link which can be based on any appropriate metric such as link bandwidth or delay and is typically expressed as an integer value. A link may have an asymmetric cost, that is, the cost in the direction AB along a link may be different from the cost in a direction BA. Based on the advertised information in the form of a link state packet (LSP) each node constructs a link state database (LSDB) which is a map of the entire network topology and from that constructs generally a single optimum route to each available node based on an appropriate algorithm such as, for example a shortest path first (SPF) algorithm. As a result a “spanning tree” is constructed, rooted at the node and showing an optimum path including intermediate nodes to each available destination node. Because each node has a common LSDB (other than when advertised changes are propagating around the network) any node is able to compute the spanning tree rooted at any other node as well as the “reverse spanning tree”sometimes termed a “sink tree” showing the optimum route for each node from which the node is reachable.
As a result when a packet for a destination node arrives at a node (which we term here the “first node”), the first node identifies the optimum route to that destination and forwards the packet to the next node along that route. The next node repeats this step and so forth.
It will be noted, therefore, that each node decides, irrespective of the node from which it received a packet, the next node to which the packet should be forwarded. In some instances this can give rise to a “loop”. In particular this can occur when the databases (and corresponding forwarding information) are temporarily de-synchronized during a routing transition, that is, where because of a change on the network, a new LSP is propagated. As an example, if node A sends a packet to node Z via node B, comprising the optimum route according to its SPF, a situation can arise where node B, according to its SPF determines that the best route to node Z is via node A and sends the packet back. This can continue indefinitely although usually the packet will have a maximum hop count after which it will be discarded. Such a loop can be a direct loop between two nodes or an indirect loop around a circuit of nodes.
In some circumstances it is desirable to have more control over the route that a packet takes in which case “tunneling” can be used. According to this scheme if a node A receives a packet destined for node Z and for some reason it is desired that the packet should travel via node Y, under normal circumstances node A would have no control over this (unless Y was an adjacent node), as the route is dependent on the SPF at node A and any intermediate nodes as well. However node A can “tunnel” the packet to node Y by encapsulating the received packet within a packet having destination node Y and sending it to node Y which acts as the tunnel end point. When the packet is received at node Y it is decapsulated and Y then forwards the original packet to node Z according to its standard SPF. An alternative is to use IP source routing in which case the packet is converted to a loose source route packet replacing destination with next-hop, and then specifying the intermediate nodes and real destination. The route can be further controlled, under appropriate protocols, by multiple tunneling whereby a packet destined for a first node is encapsulated in a packet destined for a second node which in turn is encapsulated in a packet for a third node and so forth. However, this is a less attractive option as the maximum payload decreases with each encapsulation and multiple encapsulation is less easily built in the forwarding hardware at high speed. A further alternative is directed forwarding whereby the encapsulating packet includes a specific instruction as to which neighboring node of the end point the encapsulated packet should be sent, which comprises the “release point”
The manner in which a backup route is constructed in a link state protocol system can now be understood with regard to the following examples.
Referring firstly to
It will be seen that if the link 36 or node B fails then node A must send packets to node D via nodes W, X, Y, Z. However if the packet is sent under normal circumstances to node W then node W will, not knowing that the link 36 has failed, compute that the lowest cost route to node D is back via node A (three intermediate links hence a cost 3 as against a cost of 4 via X, Y, Z, D). However if node A is able to “force” the packet as far as node X then node X will see the repair path as the cheaper route as opposed to sending back via A. As a result it is necessary to tunnel the packet from node A to node X. In fact either of the nodes Y or Z would also form appropriate end points. However it would not be appropriate to tunnel the packet directly from node A to node D. This is because when the packet was intercepted at node W it would identify the cheaper route to node D as in fact going once again via nodes A and B.
The problem becomes more complex in the situation shown in
The method described in overview above provides efficient determination of the repair path required and automatically determines any endpoint or release point required as will be seen from the following example.
It is now necessary to compute the Q-space 20. This computation is dependent on whether a potential node failure or a potential link failure is being considered. If it is a potential link failure then it is enough to ensure that a repair path is constructed around the link to the node the other side of it (node B as target node) after which traffic could be expected to be forwarded normally. However if node B failed then clearly this approach would not work. In that case it would be necessary to construct a repair path to each neighbor of the failed node (other than the node A itself of course) on the basis that the failed node would have forwarded traffic to its neighboring nodes in any event, and the neighboring nodes would then normally forward packets irrespective of how the packet reached them. It will be seen the worst case scenario is node failure rather than link failure and so this scenario is addressed here.
The first set of nodes reachable from node A (P-space) as shown in
As a result the respective release points from A to each of B's neighbor nodes can be obtained from the intersection of the respective P-space and Q-space sets as follows:
Whichever failure type is addressed at block 166, at block 176 the intermediate node is identified. In block 178 it is then assessed whether the intermediate node is in the extended P space. If it is then at block 180 the repair path is constructed using tunneling and directed forwarding to the intermediate node. If the intermediate node is not in extended P-space then the repair path is constructed at block 182 using tunneling to the intermediate node as discussed above.
In block 164 the P-space for node A can be extended very simply by calculating the P-space for the neighbors to node A, namely nodes F and W which again can be calculated at node A from its LSDB. Because A will inevitably forward packets to one of these neighbors in the event that link 36 or node B fails, the set of reachable nodes and hence potentially, release points can be simply extended in this manner. It can be shown that the P-space can be derived individually for each neighboring node or by running an SPF algorithm rooted at A but decreasing the cost of nodes reachable over the neighboring node by an amount comprising the cost of the direct link between the nodes less the sum of the shortest cost link in each direction (bearing in mind that the direct link may not be the lowest cost link, and that there may be asymmetry). As a result individual SPFs rooted at each node do not need to be run.
As indicated, the preceding discussion is based on a worst case scenario that a node fails but it will be appreciated that it is possible to apply the method to an environment where link-failure is compensated in block 166 and subsequent blocks 172 and 174. In that case, referring once again to
A link failure repair strategy can be adopted where it is established that, using a node failure repair strategy, it would not have been possible to identify a repair path to certain target nodes. This is effective when the presumed failed node constitutes a single point of failure such that the target nodes are unreachable other than via the presumed failed node. In that case by forwarding packets to the “failed” node this is their only prospect of arriving at the “unreachable” nodes.
However this approach can give rise to problems in some instances and a further optimisation is discussed here to mitigate such problems. In particular problems can arise if a link repair strategy is adopted but certain target nodes are unreachable for other reason than a single point of failure. This alternative reason may be that severe link cost asymmetries prevent a repair path from being available adopting the method discussed above or that there is interference caused by a repairing node including another neighbour of the failed node in its repair path in some circumstances.
Accordingly, if it is established that a repair path is not available for some neighbours of the failed node (referred to as the set of unavailable nodes {X}) a check is performed to establish why. An SPF is run rooted at A and with B removed. If all members of {X} are unreachable then B is a single point of failure and a link repair strategy can be run for packets to those nodes, as the worst case scenario is that the node really has failed in which case the members of {X} remain unreachable even after convergence.
However if any member of {X} is reachable then a repair path must be unavailable because of asymmetry or interference. In that case if a link failure repair strategy is adopted and the node has in fact failed then the strategy is worse as traffic to some otherwise reachable destinations would be forwarded along a link repair path that may not work. Here, therefore all repairs for the component are abandoned.
Accordingly the repairing node can determine whether a link failure repair strategy should be adopted.
Although it would be possible to calculate repair paths on-the-fly, in the embodiment discussed here repair paths are pre-computed in order that they can be implemented promptly upon failure detection. As a result each node contains the pre-computed repair paths for the failure of each adjacent component—in the example discussed, for each adjacent node (but not destination nodes beyond that as it is enough to route the packet round the failure after which normal forwarding will take over). When the failure of an adjacent component is detected by the node the appropriate repair path or paths are put in place. Where necessary an incoming packet is then directed along the appropriate route. Each of these steps will now be discussed in more detail.
As discussed above, repair paths are identified by examining the intersection of a P-space and a Q-space at block 178 in
For each neighbor that still requires a repair path, the possible paths are derived as discussed above. If a complete set of repair paths is not possible around a given adjacent component then none are constructed as, if an incomplete set of repair paths were constructed, packets could be lost. In cases where the tunnel endpoint is a neighbor of the repairing node then normal forwarding to the endpoint can be adopted unless directed forwarding is required from the tunnel endpoint to the release point (in which case the tunneling mechanism is required).
If multiple repair paths are available (i.e. more than one pair of tunnel endpoint and release point is identified in the intersection of P-space and Q-space) then the optimum repair path is selected on a least cost basis, based on the cost to the release point (or tunnel endpoint if these are coincident). In the present example, the cost is the cost of the path that packets will actually traverse via the release point including the cost of a new link over which directed forwarding is performed as this represents a lower computational burden and may be more representative than, say, the cost to the target via the repair path. However the selection process can be optimized by stopping running the Q-space reverse SPF as soon as a node in the (extended) P-space is identified. Although this may not find the shortest route this is outweighed by the reduced computational burden. A yet further optimization is to ensure that no downstream path (i.e. intermediate nodes comprising a neighbor of the repairing node) is excluded. This is achieved by stopping running the reverse SPF algorithm at the earlier of:
having reached all neighbors of the repairing node via the failed link (in which case there can be no downstream path as these neighbors will hence not occur in Q-space) and having identified another release point; and
having reached a neighbor of the repairing node not via the failed link. Of course any appropriate manner of identifying the optimum repair path can be adopted.
Once the least cost repair path is assigned, there may still be multiple repair paths, one for each neighbor of the adjacent component which is a repair path target. To identify which repair path should be used it is necessary to assess the final destination of an incoming packet to the repairing node. This is achieved by recording which neighbor node of the adjacent component would be used to reach each destination via the adjacent component in normal operation and assigning the traffic to the repair path generated with the appropriate neighbor as target.
It will be seen that actual implementation of the backup path method is simple and will be apparent to the skilled person.
In an optimization, in optional block 192 repair paths are pre-calculated for presumed node failures as well as, if it can be identified that the failed node would be a single point of failure for any neighbor node, and no neighbor nodes would be unreachable for other reasons, link failure repair paths to the “failed node” as discussed above for those nodes. If it is established that certain unreachable nodes are unavailable other than because the failed node is a single point of failure then a non-repair path strategy is adopted for the node rather than a partial repair strategy as discussed above.
In block 194, when a component fails, an adjacent node (the repairing node) detects this. The manner in which failure is detected will be well known to the skilled person and will be dependent upon the specific nature of the source node and the adjacent component. In block 196, as soon as failure is detected the pre-computed repair path is adopted for traffic which would otherwise traverse the adjacent component. Dependent upon the final destination of incoming traffic, the appropriate repair path is then selected for that traffic. The method can equally be applied in case of planned downtime of a component in which case appropriate notification to the node ensures no packet loss, or where appropriate protocols are in place, in cases where traffic is redirected to other paths because of adjacent component overload.
The mechanism by which the repair paths are stored and implemented will be well known to the skilled person such that a detailed description is not required here. Repair paths are calculated in the existing routing code as a natural extension of the computation as carried out in any event. Various databases and tables storing the routing and forwarding information can be updated in any appropriate manner, for example varying appropriate data fields or pointers in database entries or by storing repair paths along with normal entries. The above discussion assumes that each node is capable of acting as a tunnel termination point and performing directed forwarding or an equivalent mechanism which may not be the case for all routers. To the extent that a node is available to carry out the appropriate functions this can be advertised by modifying the appropriate fields in the advertisement and where this is not present, it can be inferred that the router sending an advertisement does not support tunnel termination. This can be a further factor in selecting a desired intermediate node.
4.0 Implementation Mechanisms—Hardware Overview
Computer system 80 includes a bus 82 or other communication mechanism for communicating information, and a processor 84 coupled with bus 82 for processing information. Computer system 80 also includes a main memory 86, such as a random access memory (RAM), flash memory, or other dynamic storage device, coupled to bus 82 for storing information and instructions to be executed by processor 84. Main memory 86 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 84. Computer system 80 further includes a read only memory (ROM) 88 or other static storage device coupled to bus 82 for storing static information and instructions for processor 84. A storage device 90, such as a magnetic disk, flash memory or optical disk, is provided and coupled to bus 82 for storing information and instructions.
A communication interface 98 may be coupled to bus 82 for communicating information and command selections to processor 84. Interface 98 is a conventional serial interface such as an RS-232 or RS-422 interface. An external terminal 92 or other computer system connects to the computer system 80 and provides commands to it using the interface 98. Firmware or software running in the computer system 80 provides a terminal interface or character-based command interface so that external commands can be given to the computer system.
A switching system 96 is coupled to bus 82 and has an input interface and a respective output interface (commonly designated 99) to external network elements. The external network elements may include a plurality of additional routers 120 or a local network coupled to one or more hosts or routers, or a global network such as the Internet having one or more servers. The switching system 96 switches information traffic arriving on the input interface to output interface 99 according to pre-determined protocols and conventions that are well known. For example, switching system 96, in cooperation with processor 84, can determine a destination of a packet of data arriving on the input interface and send it to the correct destination using the output interface. The destinations may include a host, server, other end stations, or other routing and switching devices in a local network or Internet.
The computer system 80 implements as a router acting as a repairing node the above described method of constructing a backup route where a link 99 or the router 120 connected to it comprises the adjacent component. According to one embodiment of the invention, the implementation is provided by computer system 80 in response to processor 84 executing one or more sequences of one or more instructions contained in main memory 86. Such instructions may be read into main memory 86 from another computer-readable medium, such as storage device 90. Execution of the sequences of instructions contained in main memory 86 causes processor 84 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the sequences of instructions contained in main memory 86. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor 84 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 90. Volatile media includes dynamic memory, such as main memory 86. Transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 82. Transmission media can also take the form of wireless links such as acoustic or electromagnetic waves, such as those generated during radio wave and infrared data communications.
Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read.
Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor 84 for execution. For example, the instructions may initially be carried on a magnetic disk of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to computer system 80 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector coupled to bus 82 can receive the data carried in the infrared signal and place the data on bus 82. Bus 82 carries the data to main memory 86, from which processor 84 retrieves and executes the instructions. The instructions received by main memory 86 may optionally be stored on storage device 90 either before or after execution by processor 84.
Interface 99 also provides a two-way data communication coupling to a network link that is connected to a local network. For example, the interface 99 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, the interface 99 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, the interface 99 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
The network link typically provides data communication through one or more networks to other data devices. For example, the network link may provide a connection through a local network to a host computer or to data equipment operated by an Internet Service Provider (ISP). The ISP in turn provides data communication services through the world wide packet data communication network now commonly referred to as the “Internet”The local network and the Internet both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on the network link and through the interface 99, which carry the digital data to and from computer system 80, are exemplary forms of carrier waves transporting the information.
Computer system 80 can send messages and receive data, including program code, through the network(s), network link and interface 99. In the Internet example, a server might transmit a requested code for an application program through the Internet, ISP, local network and communication interface 98. In accordance with the invention, one such downloaded application provides for the method as described herein.
The received code may be executed by processor 94 as it is received, and/or stored in storage device 90, or other non-volatile storage for later execution. In this manner, computer system 80 may obtain application code in the form of a carrier wave.
5.0 Extensions and Alternatives
Although the computation of the repair path is discussed as taking place at the repair node it can equally occur at a remote node which then downloads repair paths to all repairing nodes. Although tunneling and directed forwarding are discussed as technique for forwarding packets to the intermediate node, any appropriate packet routing mechanism can be adopted as long as it is supported by the relevant nodes, for example loose or strict source routing. The method steps set out can be carried out in any appropriate order, for example P and Q space can be constructed in any order or indeed simulataneously and aspects from the examples and embodiments described juxtaposed or interchanged as appropriate.
In the foregoing specification, the invention has been described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
4827411 | Arrowood et al. | May 1989 | A |
4956835 | Grover et al. | Sep 1990 | A |
4987536 | Humblet | Jan 1991 | A |
5128926 | Perlman et al. | Jul 1992 | A |
5243592 | Perlman et al. | Sep 1993 | A |
5253248 | Dravida et al. | Oct 1993 | A |
5265092 | Soloway et al. | Nov 1993 | A |
5455865 | Perlman | Oct 1995 | A |
5627822 | Edmaier et al. | May 1997 | A |
5652751 | Sharony | Jul 1997 | A |
5754543 | Seid | May 1998 | A |
5825772 | Dobbins et al. | Oct 1998 | A |
5854899 | Callon et al. | Dec 1998 | A |
5959968 | Chin et al. | Sep 1999 | A |
5999286 | Venkatesan | Dec 1999 | A |
6002674 | Takei et al. | Dec 1999 | A |
6018576 | Croslin | Jan 2000 | A |
6032194 | Gai et al. | Feb 2000 | A |
6044075 | Le Boudec et al. | Mar 2000 | A |
6061650 | Malkin et al. | May 2000 | A |
6084864 | Liron | Jul 2000 | A |
6098107 | Narvaez-Guarnieri et al. | Aug 2000 | A |
6111257 | Shand et al. | Aug 2000 | A |
6128750 | Espy et al. | Oct 2000 | A |
6148410 | Baskey et al. | Nov 2000 | A |
6185598 | Farber et al. | Feb 2001 | B1 |
6243754 | Guerin et al. | Jun 2001 | B1 |
6246669 | Chevalier et al. | Jun 2001 | B1 |
6256295 | Callon | Jul 2001 | B1 |
6260072 | Rodriguez-Moral | Jul 2001 | B1 |
6278687 | Hunneyball | Aug 2001 | B1 |
6295275 | Croslin | Sep 2001 | B1 |
6321271 | Kodialam et al. | Nov 2001 | B1 |
6343122 | Andersson | Jan 2002 | B1 |
6347078 | Narvaez-Guarnieri et al. | Feb 2002 | B1 |
6349091 | Li | Feb 2002 | B1 |
6356546 | Beshai | Mar 2002 | B1 |
6377542 | Asprey | Apr 2002 | B1 |
6389764 | Stubler et al. | May 2002 | B1 |
6415427 | Nitta et al. | Jul 2002 | B2 |
6449279 | Beiser et al. | Sep 2002 | B1 |
6473421 | Tappan | Oct 2002 | B1 |
6507577 | Mauger et al. | Jan 2003 | B1 |
6535481 | Andersson et al. | Mar 2003 | B1 |
6578084 | Moberg et al. | Jun 2003 | B1 |
6578086 | Regan et al. | Jun 2003 | B1 |
6590868 | Shen | Jul 2003 | B2 |
6636498 | Leung | Oct 2003 | B1 |
6668282 | Booth et al. | Dec 2003 | B1 |
6690671 | Anbiah et al. | Feb 2004 | B1 |
6697325 | Cain | Feb 2004 | B1 |
6697333 | Bawa et al. | Feb 2004 | B1 |
6704320 | Narvaez et al. | Mar 2004 | B1 |
6711125 | Walrand et al. | Mar 2004 | B1 |
6714551 | Le-Ngoc | Mar 2004 | B1 |
6718382 | Li et al. | Apr 2004 | B1 |
6744727 | Liu et al. | Jun 2004 | B2 |
6765896 | Ahmed et al. | Jul 2004 | B1 |
6778531 | Kodialam et al. | Aug 2004 | B1 |
6829215 | Tornar | Dec 2004 | B2 |
6882627 | Pieda et al. | Apr 2005 | B2 |
6895441 | Shabtay et al. | May 2005 | B1 |
6922765 | Jacobs | Jul 2005 | B2 |
6928484 | Huai et al. | Aug 2005 | B1 |
6944131 | Beshai et al. | Sep 2005 | B2 |
6973057 | Forslow | Dec 2005 | B1 |
6982951 | Doverspike et al. | Jan 2006 | B2 |
6990068 | Saleh et al. | Jan 2006 | B1 |
6993593 | Iwata | Jan 2006 | B2 |
6996065 | Kodialam et al. | Feb 2006 | B2 |
7016313 | Harper | Mar 2006 | B1 |
7058016 | Harper | Jun 2006 | B1 |
7065059 | Zinln | Jun 2006 | B1 |
7093097 | Herr et al. | Aug 2006 | B2 |
7099286 | Swallow | Aug 2006 | B1 |
7113481 | Elie-Dit-Cosaque et al. | Sep 2006 | B2 |
7158486 | Rhodes | Jan 2007 | B2 |
7177295 | Sholander et al. | Feb 2007 | B1 |
7209434 | Kano et al. | Apr 2007 | B2 |
7242664 | Einstein et al. | Jul 2007 | B2 |
7248579 | Friedman | Jul 2007 | B1 |
7260645 | Bays | Aug 2007 | B2 |
7274654 | Yang et al. | Sep 2007 | B2 |
7274658 | Bornstein et al. | Sep 2007 | B2 |
7349427 | Canning et al. | Mar 2008 | B1 |
7490165 | Katukam et al. | Feb 2009 | B1 |
7500013 | Dziong et al. | Mar 2009 | B2 |
20020004843 | Andersson et al. | Jan 2002 | A1 |
20020012318 | Moriya et al. | Jan 2002 | A1 |
20020021671 | Quinlan | Feb 2002 | A1 |
20020037010 | Yamauchi | Mar 2002 | A1 |
20020069292 | Gaddis et al. | Jun 2002 | A1 |
20020093954 | Weil et al. | Jul 2002 | A1 |
20020112072 | Jain | Aug 2002 | A1 |
20020116669 | Jain | Aug 2002 | A1 |
20020131362 | Callon | Sep 2002 | A1 |
20020136223 | Ho | Sep 2002 | A1 |
20020147800 | Gai et al. | Oct 2002 | A1 |
20020171886 | Wu et al. | Nov 2002 | A1 |
20020172157 | Rhodes | Nov 2002 | A1 |
20020191545 | Pieda et al. | Dec 2002 | A1 |
20030053414 | Akahane et al. | Mar 2003 | A1 |
20030063613 | Carpini et al. | Apr 2003 | A1 |
20030079040 | Jain et al. | Apr 2003 | A1 |
20030103449 | Barsheshet et al. | Jun 2003 | A1 |
20030147352 | Ishibashi et al. | Aug 2003 | A1 |
20030193958 | Narayanan | Oct 2003 | A1 |
20030193959 | Lui et al. | Oct 2003 | A1 |
20030202473 | Patrick et al. | Oct 2003 | A1 |
20030210705 | Seddigh et al. | Nov 2003 | A1 |
20040001497 | Sharma | Jan 2004 | A1 |
20040001508 | Zheng et al. | Jan 2004 | A1 |
20040004955 | Lewis | Jan 2004 | A1 |
20040071089 | Bauer et al. | Apr 2004 | A1 |
20040085894 | Wang et al. | May 2004 | A1 |
20040088389 | Shah | May 2004 | A1 |
20040107287 | Ananda et al. | Jun 2004 | A1 |
20040117251 | Shand | Jun 2004 | A1 |
20040151181 | Chu et al. | Aug 2004 | A1 |
20040185777 | Bryson | Sep 2004 | A1 |
20040190454 | Higasiyama | Sep 2004 | A1 |
20040223497 | Sanderson et al. | Nov 2004 | A1 |
20050007950 | Liu | Jan 2005 | A1 |
20050031339 | Qiao et al. | Feb 2005 | A1 |
20050038909 | Yoshiba et al. | Feb 2005 | A1 |
20050050220 | Rouyer et al. | Mar 2005 | A1 |
20050071709 | Rosenstock et al. | Mar 2005 | A1 |
20050088965 | Atlas et al. | Apr 2005 | A1 |
20050097219 | Goguen et al. | May 2005 | A1 |
20050111351 | Shen | May 2005 | A1 |
20050152289 | Nagata et al. | Jul 2005 | A1 |
20050201273 | Shimizu | Sep 2005 | A1 |
20050201371 | Lauer | Sep 2005 | A1 |
20050226400 | Farber et al. | Oct 2005 | A1 |
20060007929 | Desai et al. | Jan 2006 | A1 |
20060018253 | Windisch et al. | Jan 2006 | A1 |
20060031482 | Mohan et al. | Feb 2006 | A1 |
20060050630 | Kobayashi et al. | Mar 2006 | A1 |
20060080421 | Hu | Apr 2006 | A1 |
20060092941 | Kusama | May 2006 | A1 |
20060182117 | Chen et al. | Aug 2006 | A1 |
20060221962 | Previdi et al. | Oct 2006 | A1 |
20060291446 | Caldwell et al. | Dec 2006 | A1 |
20070011284 | le Roux et al. | Jan 2007 | A1 |
20070011351 | Bruno et al. | Jan 2007 | A1 |
20070038767 | Miles et al. | Feb 2007 | A1 |
20070038891 | Graham | Feb 2007 | A1 |
20070124453 | Slaughter et al. | May 2007 | A1 |
Number | Date | Country |
---|---|---|
1440159 | Sep 2003 | CN |
WO 0206918 | Jan 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20070038767 A1 | Feb 2007 | US |