The present invention generally relates to multicast data. The invention relates more specifically to a method and apparatus for constructing a repair path for multicast data.
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 elements including links (communication paths such as telephone or optical lines) and nodes (for example, routers directing the packet along one or more of a plurality of links connected to it) according to one of various routing protocols.
One class of routing protocol is the link state protocol. 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. The results of the SPF are stored in a routing information base (RIB) and based on these results a forwarding information base (FIB) or forwarding table is updated to control forwarding of packets appropriately. When there is a network change an LSP representing the change is flooded through the network by each node adjacent the change, each node receiving the LSP sending it to each adjacent node.
As a result, when a data packet for a destination node arrives at a node the node identifies the optimum route to that destination and forwards the packet via the correct interface to the next node (“NEXT_HOP”) along that route. The next node repeats this step and so forth.
Such protocols can support both unicast, i.e. single point (source) to single point (destination) data traffic and multicast traffic. Multicast traffic comprises point to multipoint traffic (P2 MP) and multipoint to multipoint traffic (MP2 MP). For example IP (internet protocol) multicast is well known to the skilled reader and is described in document “Internet Protocol Multicast” which is available at the time of writing on the file “IP multi.htm” in the directory “univercd/cc/td/doc/cisintwk/ito_doc” of the domain cisco.com on the World Wide Web.
Multicast allows data packets to be forwarded to multiple destinations (or “receivers”) without unnecessary duplication, reducing the amount of data traffic accordingly. All hosts wishing to become a receiver for a multicast group perform a “join” operation to join the multicast group. A multicast tree such as a shortest path tree is then created providing routes to all receivers in the group. The multicast group in a P2 MP group is denoted (S,G) where S is the address of the source or broadcasting host and G is an IP multicast address taken from a reserved address space. As a result routers receiving a packet from the source S to the multicast address G send the packet down each interface providing a next hop along the route to any receiver on the tree.
In the case of MP2 MP multicasts, a shared group is denoted (*,G) allowing multiple sources to send to multiple receivers. The multicast tree is constructed as a shared tree including a shared root or rendez-vous point (RP) which can be determined in any appropriate manner, for example using a “Steiner tree” as will be familiar to the skilled reader. All of the sources register into and send multicast data for the group to the RP which then sends the data down the shared tree to all receivers. In either case the multicast tree is dynamically modified as hosts join, and pruned as hosts leave. For example, if a path changes, a router will send a prune up the old path immediately cutting off the supply of packets, and simultaneously switch the input interface to the new path, sending a join up that path.
During forwarding of multicast data at a router, when a packet is received at the router with a multicast address as destination address, the router consults the multicast forwarding table and sends the packet to the correct next hop via the corresponding interface. As a result, even if the path from the next hop subsequently branches to multiple receivers, only a single multicast packet needs to be sent to the next hop. If, at the router, more than one next hop is required, that is to say the multicast tree branches at the router, then the packet is copied and sent on each relevant output interface.
In order to avoid looping each router ensures that data is only sent downstream away from the source and towards the receiver as upstream-directed traffic would loop back, which is impermissible in multicast. In order to achieve this the router carries out a reverse path forwarding (RPF) check to ensure that the incoming packet has arrived on the appropriate input interface. If the check fails then the packet is dropped. The router uses the unicast forwarding table to identify the appropriate upstream and downstream interfaces in the tree as part of the RPF and only forwards packets arriving from the upstream direction.
Multicast methods which make use of existing forwarding information in this manner belong to the family of “protocol independent multicast” (PIM) methods as they are independent of the specific routing protocol adopted at each router.
Referring to
In addition to IP multicast, schemes such as multi-protocol label switching (MPLS) multicast are well known. MPLS is a protocol that is well known to the skilled reader and which is described in document “Multi Protocol Label Switching Architecture” which is available at the time of writing on the file “rfc3031.txt” in the directory “rfc” of the domain “ietf.org” on the World Wide Web. According to MPLS, a complete path for a source-destination pair is established, and values required for forwarding a packet between adjacent routers in the path together with headers or “labels” are pre-pended to the packet. The labels are used to direct the packet to the correct interface and next hop. The labels precede the IP or other header allowing smaller outer headers.
The path for the source-destination pair, termed a Label Switched Path (LSP) can be established according to various different approaches. One such approach is Label Distribution Protocol (LDP) in which each router in the path sends its label to the next hop router on the path as determined from its IP routing table. Alternatively Resource Reservation Protocol (RSVP-TE) can be invoked in which case, for example, a network administrator can engineer a path, providing strict source routing. In the case of MPLS multicast, therefore, for example, a multicast tree is constructed for example from a P2 MP or MP2 MP LSP.
In the case of failure of network components such as a node or link multicast traffic can be affected until the network converges on the new topology. A solution to this problem is known from MPLS multicast and is described in “Multicast Fast Reroute” which is available at the time of writing on the file “mpls” in the directory “˜mngroup/projects” of the domain cs.virginia.edu on the World Wide Web. According to the solution presented therein backup LSPs are precomputed either manually or using an algorithm minimizing the number of routers disconnected from the routing tree for a link failure.
However effective and rapid solutions are required for both link and node protection in, and also embracing IP multicast schemes. Furthermore, during convergence, the interruption to multicast traffic can be proportional to the number of multicast trees on the network. In particular there is a need to switch between old and new input interfaces in the case where the topology change affects which router acts as the preceding router before a given multicast router. In existing systems, when the prune and join messages are sent to update the forwarding decision, during transition across the network, traffic arriving at the old input interface is lost and so there is a delay in receiving traffic until all traffic is coming in on the new input interface.
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 method and apparatus for constructing a repair path for multicast data 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 Repair Path for Multicast Data
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 for constructing a repair path for multicast data around a non-available component in a data communications network having as components nodes and links therebetween. The method comprises the step performed at a repairing node, of receiving from a notifying node in a network, a notification identifying the notifying node and components through which the notifying node can be reached. The method further comprises the steps of deriving, from the notification, a network repair address for use in the event of non-availability of a component identified in the notification; and constructing a repair path for multicast data for the repair address.
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
In overview a method for constructing a repair path for multicast data can be understood with reference to
Nodes A, B, D and E are all part of a multicast tree denoted by the dotted links 200, 202, 204. A repair strategy is implemented at node A acting as a repairing node for providing a repair path around a non-available component comprising either adjacent link 112 or node B. In the case of failure of link 112 then node A forwards the packet to node B along a repair path 206. In the case of failure of node B, node A forwards packets along repair paths to some or all of its neighbors, nodes C, D and E along respective repair routes 208, 210, 212.
The manner in which the repair paths themselves are selected can be, for example, by assigning a “notvia” address to each component as described in more detail below. Alternatively repair paths can be constructed by deriving from the network topology a first set of nodes reachable from node A without traversing node B, deriving a second set of nodes from which node B (in the case of link repair) or a neighbor of node B (in the case of node repair) is reachable without traversing the link or node B as appropriate, and constructing a repair path to node B or its neighbor via an intermediate node in the intersection in the first and second sets. Then the packet itself may be tunneled to the intermediate node or forwarded using a scheme such as MPLS as appropriate.
In the case of node repair, i.e. repair around non-available node B, then node A may simply repair to each of node B's neighbors, nodes C, D and E or it may repair only to those neighbors within a multicast tree: in the example shown, nodes D and E. Of course in the case of multiple multicast groups, multiple different subsets of the neighbor nodes may be accommodated.
In a further alternative approach a repair multicast group can be formed comprising the neighbor nodes of node B, and an appropriate MP2 MP multicast tree (or multiple P2 MP multicast trees) constructed accordingly. For all approaches, therefore, when a multicast packet is received at node A with next hop node B it will be forwarded according to the appropriate strategy to the target node: node B in the case of link repair or nodes C, D and/or E in the case of node repair, after which they re-enter the multicast tree. Each node can pre-compute the repair strategy for each of its neighbors and/or compute a repair multicast tree excluding itself but including each of its neighbors as appropriate.
Various mechanisms are provided for ensuring that a multicast packet arriving from a repair path is RPF-checked as though it has arrived on the correct incoming interface. Furthermore methods are proposed for managing the RPF switch in routers between old and new interfaces following a topology change.
3.0 Method of Constructing a Repair Path for Multicast Data
In one implementation link or node protection around a failed component using a repair path can be implemented using “notvia” addresses as described in co-pending patent application Ser. No. 10/064,275, filed 22 Feb. 2005 entitled “Method and Apparatus for Constructing a Repair Path around a Non-Available Component in a Data Communications Network” of Michael Shand et al (“Shand et al”), the entire contents of which are incorporated by reference for all purposes as if fully set forth herein. According to Shand et al, in addition to the standard addresses assigned to each node, each interface in the network is assigned an additional repair address, the “notvia address”. The semantics of a notvia address are that a packet addressed to a notvia address must be delivered to the router with that address, not via the neighboring router on the interface to which that address is assigned. All participating nodes calculate their paths to the notvia address using the same repair topology as a result of which, when the failure is detected, a repairing node encapsulates the packet to the notvia address of the node interface on the far side of the failure. The nodes on the repair path then know to which node they must deliver the packet, and which network component they must avoid. Accordingly the packet can be forwarded using normal IP forwarding without the requirement for extensions to the forwarding code and only one level of encapsulation is needed.
According to an alternative approach, link or node protection around a failed component is achieved by constructing a pre-computed repair path and identifying an intermediate node as discussed above. The manner in which the repair path is identified can be understood with reference to
In the case of normal routing node R will forward packets to node W via node S, node T and a path designated generally 58. However referring to
According to the method described herein the repair path is constructed according to the approach described in co-pending patent application Ser. No. 10/340,371, filed 9 Jan. 2003, entitled “Method and Apparatus for Constructing a Backup Route in a Data Communications Network” of Kevin Miles et al., (“Miles et al.”), the entire contents of which are incorporated by reference for all purposes as if fully set forth herein and discussed in more detail below. According to the solution put forward in Miles et al, a repairing node (node R) pre-computes a first set of nodes comprising the set of all nodes reachable according to its protocol other than nodes reachable by traversing an adjacent component V. This is termed here node R's “P-space” PR reference numeral 60 and the operation is carried out for each adjacent component. The repairing node also pre-computes a second set of nodes comprising the set of all nodes from which a target node (node C) is reachable without traversing the failed component V. This is termed here node T's “Q-space”, QT, reference numeral 62. The method then determines whether any intermediate nodes exist in the intersection between the first and second sets of nodes PR, QT or a one-hop extension thereof. When the repairing node detects failure of an adjacent component it tunnels packets for the target node T to a tunnel end point comprising a node in the intersection of the first and second sets of nodes calculated for that failed component.
In particular
As the scheme provides protection both for link and node failure some mechanism is required to accommodate both possibilities. In a first approach, node failure is assumed in all cases unless the node is a single point of failure, i.e. provides the only path to one or more network destinations, in which case link repair is attempted. A further mechanism is described in co-pending patent application Ser. No. 10/346,051, filed 15 Jan. 2003, entitled “Method and Apparatus for Determining a Data Communication Network Repair Strategy” of Stewart Bryant et al (“Bryant et al”), the entire contents of which are incorporated by reference for all purposes as if fully set forth herein. In particular, according to the approach described in Bryant et al a repairing node detects a failure along an interface which may arise from failure of the adjacent link or the adjacent node.
For example referring to
In either case, single or multiple tunnels can be used to implement the repair paths or forwarding paradigms such as MPLS can be adopted as described in co-pending patent application Ser. No. 10/976,076 filed 27 Oct. 2004, entitled “Method and Apparatus for Forwarding Data in a Data Communications Network” of George Swallow et al (Swallow et al”), the entire contents of which are incorporated by reference for all purposes as if fully set forth herein. With reference once again to
The manner in which the repair paths are implemented, using the approaches described above, for multicast traffic is described below with reference to
Referring once again to the network shown in
In block 400 the failure is identified and in block 402 an incoming multicast packet is received with node B as next hop. In block 404 the repairing node assigns the packet to the appropriate repair path—in this instance the link repair path 206 pre-computed as described above. In block 406 node A forwards the packet along the repair path. In the case that the notvia address is used, this approach has the advantage in multicast repair that incoming packets can be easily associated with the expected incoming interface for the purposes of the RPF check since the notvia address indicates the incoming interface.
Where, alternatively, the packet is tunneled then node B acts as a repair enabling node and needs to know that anything received on the multicast repair tunnel should be treated as if it had arrived from the broken link as a result of which the RPF check will allow the packet to be forwarded further downstream in a multicast tree. This can be carried out, for example, by appropriate configuration at node B to recognize that packets coming in from a repair link should be treated accordingly. This may be either automatically implemented for all packets arriving on the repair path or may be triggered upon recognition at node B of failure of the link 112. An additional tunnel is required to the target node B, to ensure the packet arrives there, and the RPF check can be managed in this manner alternatively.
An alternative recognition method may be adopted in the case of MPLS implemented repair along the pre-computed repair path. In that case the label stack includes, in addition to a A's label for P and P's label for Q, the label that Q uses to reach B and a further label signaled by B to A. This label is then recognized at B such that the incoming packet is received and processed as though it had come in by the correct interface, that is the broken link, such that it is propagated as a multicast into the downstream multicast tree. The label can be signaled in any appropriate manner, for example via the PIM hello option.
In an alternative configuration a backup path can be built using RSVP-TE or any other protocol using explicit paths.
In block 408, once the network has converged on the new topology the repairing node tears down the repair path for example after a period greater than or equal to the maximum expected convergence period and switches to the normal forwarding path in the new topology as discussed in more detail below.
According to another approach, however, it is possible for the switch to be triggered by a signal received from node B indicating that it has converged on the new topology. For example the message can comprise a PIM prune message from B to A with sufficient information for A to know that this is to prune the backup tunnel towards node B or, as appropriate, the label signaled by node B to node A for repair.
In the case of link failure, repair paths need only be computed for protection of links to nodes within the multicast tree.
If the link repair fails as described above with reference to Bryant et al or a requirement for node repair is otherwise known then a first approach to node protection is described with reference to
In block 500 the failure is identified and in block 502 the incoming multicast packet with the failed node as next hop is received. In block 504 the packet is unicast along the repair path for each of the neighbors of node B, that is path 208, 210, 212 to each of nodes C, D and E respectively, where the repair paths are pre-computed as described above. Once again the packets can be sent to the notvia addresses, tunneled or, where multiple tunnels are not desirable, an MPLS label stack can be added in the same manner as for link repair, as described above. In this case each of the neighbors of node B, nodes C, D and E, must signal the relevant label to node A when acting as repair enabling nodes.
In block 508 the repairing node switches to the new path once convergence has taken place in the same manner as described above with reference to link repair.
The node repair failure approach of
Accordingly an alternative node repair strategy performed at a repairing node is described with reference to
Node A, the repairing node, must know the members of the or each multicast group in order to forward the packets along the relevant repair paths. This can be achieved by signaling at each relevant neighbor, for example, or by learning from each (S, G) JOIN message the set of routers that require the traffic.
This approach can be implemented with reference to
In addition, each of the repair enabling nodes D and E must be able to recognize repaired packets as though they have come in on the correct incoming interface for example by implementing the approach described with reference to the link repair strategy described above. Alternatively, once again, “notvia” addresses can be used as discussed above.
In block 606, therefore, the multicast packets are forwarded on the relevant repair paths and on block 608 the repairing node switches to the new topology after conversion in the manner described above.
In an alternative approach to using repair paths derived by examining the intersection between P and Q space or by using notvia addresses, a repair multicast tree may instead by implemented as shown in
In block 700 a repair multicast tree is pre-computed.
It will be seen that each node can invoke a repair tree around itself, therefore. Furthermore the tree can include all of its neighbors or a sub-set of neighbors which are in a multicast tree themselves. Where there are multiple multicast trees it is possible alternatively simply to include all neighbors in a single repair tree which will then accommodate repair of multicast data for any tree for which node B fails. However this will lead to dropping of packets at non-multicast nodes.
It will further be seen that instead of an MP2 MP tree, multiple P2 MP trees can be constructed at each of nodes A, D, E as source node if desired.
In block 702, an incoming multicast packet is received at a repairing node, for example node A. Then, in block 704, the incoming packet is assigned to the multicast repair tree and forwarded on the multicast repair tree in block 706. Then, in block 708, the repairing node switches to the new topology at an appropriate instant in the same manner as described above with reference to link protection.
As a result a single-label MPLS MP2 MP tree can be constructed between all or appropriate neighbors of the non-available node. Then any neighbor that would have wanted to send traffic to the non-available node will send the traffic into the MP2 MP tree and other neighbors will RPF these packets as if they had come from B, and drop or forward them, as appropriate according to normal RPF operation. As a result the approach is signal free and relies on forwarding path intelligence rather than signaling path intelligence.
According to a further aspect a method of managing the switch of RPF check following a topology change is discussed with reference to
In particular in block 900 a multicast router, that is, a router in the multicast tree enabled to recognize and forward multicast packets appropriately, receives notification of a network change which can be, for example, a component failure, a link cost change or introduction of a new component comprising a node or link. Notification can be received, for example via interior gateway protocol (IGP) in the form of a link-state packet. In block 902 the router establishes whether the notification represents “good news” or “bad news”. For example if notification comprises a component failure resulting in change of the input interface and closure of the previous path then this is treated as “bad news” and in block 904 an immediate transition to the correct new input interface implemented in order that the RPF check immediately begins to accept traffic only coming in on the correct new input interface.
In the case that the notification relates to a network change such as a link cost change or link addition or a repaired link failure which changes the input interface but does not fail the old path completely then this is treated as “good news” and, in block 906, traffic arising on the existing, old interface is allowed to continue. Simultaneously, in block 908 a timer Ti is started in block 908 and in block 910 a join message is sent on the new interface to enable construction of the new multicast tree taking account of the network topology change.
In block 912, upon time out of the timer Ti, the router switches to the new interface and flips the RPF accordingly such that data coming in on the old interface is now dropped and sends a prune on the old interface in block 914. Accordingly the timer period must be set for an appropriate period allowing convergence of the network on the changed topology which ensures that data “in transit” during convergence and arriving on the old interface is forwarded correctly. Furthermore, the period must be set such that the new interface is not configured while an upstream router is not sending to the new interface which would result in packet loss.
Accordingly, the RPF switch is ordered such that downstream nodes in the tree always update after upstream nodes. This can be implemented in any appropriate manner, for example by invoking an ordered update regime of the type described in co-pending patent application Ser. No. 10/685,622, filed 14 Oct. 2003 entitled “Method and Apparatus for Generating Routing Information in a Data Communications Network” of Stefano Previdi et al (“Previdi et al”) the entire contents of which are incorporated by reference for all purposes as if fully set forth herein. According to the approach set out in Previdi et al a router identifies an “affected set” of nodes affected by the network change for example by running a reverse SPF routed at the next hop node to the affected component. The furthest node upstream of the router and which is affected by the change is identified and a delay period then calculated it based on the number of hops there between. As a result a longer delay will be instigated at nodes further downstream such that the RPF switch will propagate downstream through the multicast tree in order, avoiding packet loss. It is found that the ordered invocation is effective whatever the nature of the “good news” detected.
As a result a simple time-based system is provided without requiring external events to trigger specific steps. However in an alternative approach the system can be data driven, for example when traffic is detected on the new input interface the switch can be made which also allows effective ordering of the transition but at the cost of packet inspection.
It will further be noted that if repair paths have been implemented in the manner described above with reference to
The manner in which the method described herein is implemented may be in software, firmware, hardware or any combination thereof and with any appropriate code changes as will be apparent to the skilled reader without the need for detailed description here. The approach can be adopted in relation to any service provider providing a reliable multicast including, but not limited to broadcast video via IP multicast.
4.0 Implementation Mechanisms—Hardware Overview
Computer system 140 includes a bus 142 or other communication mechanism for communicating information, and a processor 144 coupled with bus 142 for processing information. Computer system 140 also includes a main memory 146, such as a random access memory (RAM), flash memory, or other dynamic storage device, coupled to bus 142 for storing information and instructions to be executed by processor 144. Main memory 146 may also be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 144. Computer system 140 further includes a read only memory (ROM) 148 or other static storage device coupled to bus 142 for storing static information and instructions for processor 144. A storage device 150, such as a magnetic disk, flash memory or optical disk, is provided and coupled to bus 142 for storing information and instructions.
A communication interface 158 may be coupled to bus 142 for communicating information and command selections to processor 144. Interface 158 is a conventional serial interface such as an RS-232 or RS-422 interface. An external terminal 152 or other computer system connects to the computer system 140 and provides commands to it using the interface 158. Firmware or software running in the computer system 140 provides a terminal interface or character-based command interface so that external commands can be given to the computer system.
A switching system 156 is coupled to bus 142 and has an input interface and a respective output interface (commonly designated 159) to external network elements. The external network elements may include a plurality of additional routers 160 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 156 switches information traffic arriving on the input interface to output interface 159 according to pre-determined protocols and conventions that are well known. For example, switching system 156, in cooperation with processor 144, 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 140 implements as a router acting as a repairing or repair enabling node, the above described method of constructing or enabling a repair path. The implementation is provided by computer system 140 in response to processor 144 executing one or more sequences of one or more instructions contained in main memory 146. Such instructions may be read into main memory 146 from another computer-readable medium, such as storage device 150. Execution of the sequences of instructions contained in main memory 146 causes processor 144 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 146. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the method. Thus, embodiments 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 144 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, and volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 150. Volatile media includes dynamic memory, such as main memory 146.
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, 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 144 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 140 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 142 can receive the data carried in the infrared signal and place the data on bus 142. Bus 142 carries the data to main memory 146, from which processor 144 retrieves and executes the instructions. The instructions received by main memory 146 may optionally be stored on storage device 150 either before or after execution by processor 144.
Interface 159 also provides a two-way data communication coupling to a network link that is connected to a local network. For example, the interface 159 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 159 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 159 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 159, which carry the digital data to and from computer system 140, are exemplary forms of carrier waves transporting the information.
Computer system 140 can send messages and receive data, including program code, through the network(s), network link and interface 159. In the Internet example, a server might transmit a requested code for an application program through the Internet, ISP, local network and communication interface 158. One such downloaded application provides for the method as described herein.
The received code may be executed by processor 144 as it is received, and/or stored in storage device 150, or other non-volatile storage for later execution. In this manner, computer system 140 may obtain application code in the form of a carrier wave.
5.0 Extensions and Alternatives
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.
Any appropriate routing protocol and mechanism and forwarding paradigm can be adopted to implement the invention. The method steps set out can be carried out in any appropriate order and aspects from the examples and embodiments described juxtaposed or interchanged as appropriate. For example the method can be implemented using link state protocols such as intermediate system-intermediate system (IS-IS) or open shortest path first (OSPF), or routing vector protocols and any forwarding paradigm, for example MPLS. The method can be applied in any network of any topology and in relation to any component change in the network for example a link or node failure, or the introduction or removal of a network component by an administrator.
The method can be applied in relation to any multicast scheme including PIM-DS and BIDIR and indeed different multicast/forwarding schemes can be used for normal multicast and the repair schemes. The approach can be implemented in relation to any number of multicast groups.
Number | Name | Date | Kind |
---|---|---|---|
4956835 | Grover et al. | Sep 1990 | A |
5128926 | Perlman et al. | Jul 1992 | A |
5243592 | Perlman et al. | Sep 1993 | A |
5430727 | Callon | Jul 1995 | A |
5825772 | Dobbins et al. | Oct 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 |
6098107 | Narvaez-Guarnieri et al. | Aug 2000 | A |
6111257 | Shand et al. | Aug 2000 | A |
6128750 | Espy et al. | Oct 2000 | A |
6148410 | Basket 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 |
6295275 | Croslin | Sep 2001 | B1 |
6321271 | Kodialam et al. | Nov 2001 | B1 |
6343122 | Andersson | Jan 2002 | B1 |
6349091 | Li | Feb 2002 | B1 |
6356546 | Beshai | Mar 2002 | B1 |
6363319 | Hsu | Mar 2002 | B1 |
6389764 | Stubler et al. | May 2002 | B1 |
6473421 | Tappan | Oct 2002 | B1 |
6507577 | Mauger et al. | Jan 2003 | B1 |
6578086 | Regan et al. | Jun 2003 | B1 |
6654361 | Dommety et al. | Nov 2003 | B1 |
6690671 | Anbiah et al. | Feb 2004 | B1 |
6697325 | Cain | Feb 2004 | B1 |
6697333 | Bawa | 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 |
6724722 | Wang | Apr 2004 | B1 |
6744727 | Liu et al. | Jun 2004 | B2 |
6778531 | Kodialam et al. | Aug 2004 | B1 |
6829215 | Tornar | Dec 2004 | B2 |
6928484 | Huai et al. | Aug 2005 | B1 |
6944131 | Beshai et al. | Sep 2005 | B2 |
6950870 | Beaulieu | Sep 2005 | B2 |
6982951 | Doverspike et al. | Jan 2006 | B2 |
6987727 | Fredette et al. | Jan 2006 | B2 |
6990068 | Saleh et al. | Jan 2006 | B1 |
6993593 | Iwata | Jan 2006 | B2 |
6996065 | Kodialam et al. | Feb 2006 | B2 |
7058016 | Harper | Jun 2006 | B1 |
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 |
7242664 | Einstein et al. | Jul 2007 | B2 |
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 |
7420989 | Liu et al. | Sep 2008 | B2 |
7490165 | Katukam et al. | Feb 2009 | B1 |
7500013 | Dziong et al. | Mar 2009 | B2 |
7519009 | Fleischman | Apr 2009 | B2 |
20020021671 | Quinlan | Feb 2002 | A1 |
20020037010 | Yamauchi | Mar 2002 | A1 |
20020062388 | Ogier et al. | May 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 |
20020171886 | Wu et al. | Nov 2002 | A1 |
20020172157 | Rhodes | Nov 2002 | A1 |
20030007500 | Rombeaut et al. | Jan 2003 | A1 |
20030063613 | Carpini et al. | Apr 2003 | A1 |
20030079040 | Jain et al. | Apr 2003 | A1 |
20030110287 | Mattson | Jun 2003 | A1 |
20030117950 | Huang | Jun 2003 | A1 |
20030123457 | Koppol | Jul 2003 | A1 |
20030161338 | Ng | 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 |
20030233595 | Charny et al. | Dec 2003 | A1 |
20040001497 | Sharma | Jan 2004 | A1 |
20040001508 | Zheng et al. | Jan 2004 | A1 |
20040038671 | Trayford et al. | Feb 2004 | A1 |
20040071089 | Bauer et al. | Apr 2004 | A1 |
20040085894 | Wang et al. | May 2004 | A1 |
20040088429 | Luo | May 2004 | A1 |
20040151181 | Chu et al. | Aug 2004 | A1 |
20040190454 | Higasiyama | Sep 2004 | A1 |
20040205239 | Doshi et al. | Oct 2004 | A1 |
20050007950 | Liu | Jan 2005 | A1 |
20050013241 | Beller et al. | Jan 2005 | A1 |
20050031339 | Qiao et al. | Feb 2005 | A1 |
20050038909 | Yoshiba et al. | Feb 2005 | A1 |
20050068968 | Ovadia et al. | Mar 2005 | A1 |
20050071709 | Rosenstock et al. | Mar 2005 | A1 |
20050073958 | Atlas et al. | Apr 2005 | A1 |
20050097219 | Goguen et al. | May 2005 | A1 |
20050201273 | Shimizu | Sep 2005 | A1 |
20050201371 | Lauer | Sep 2005 | A1 |
20050265228 | Fredette et al. | Dec 2005 | A1 |
20060018253 | Windisch et al. | Jan 2006 | A1 |
20060031482 | Mohan et al. | Feb 2006 | A1 |
20060050630 | Kobayashi et al. | Mar 2006 | A1 |
20060092941 | Kusama | May 2006 | A1 |
20060140190 | Lee | Jun 2006 | A1 |
20060193252 | Naseh et al. | Aug 2006 | A1 |
20060221962 | Previdi et al. | Oct 2006 | A1 |
20060291446 | Caldwell et al. | Dec 2006 | A1 |
20070005784 | Hares et al. | Jan 2007 | A1 |
20070011284 | Le Roux et al. | Jan 2007 | A1 |
20070011351 | Bruno et al. | Jan 2007 | A1 |
20070038767 | Miles et al. | Feb 2007 | A1 |
20070091793 | Filsfils et al. | Apr 2007 | A1 |
20070091794 | Filsfils et al. | Apr 2007 | A1 |
20070091795 | Bonaventure et al. | Apr 2007 | A1 |
20070291790 | Ue et al. | Dec 2007 | A1 |
20080025203 | Tallet | Jan 2008 | A1 |
20080062986 | Shand et al. | Mar 2008 | A1 |
20080089227 | Guichard et al. | Apr 2008 | A1 |
20080192627 | Lichtwald | Aug 2008 | A1 |
20080219153 | Shand et al. | Sep 2008 | A1 |
20080317055 | Zetterlund et al. | Dec 2008 | A1 |
20090129771 | Saniee et al. | May 2009 | A1 |
Number | Date | Country |
---|---|---|
1440159 | Sep 2003 | CN |
WO 0178278 | Oct 2001 | WO |
WO 0206918 | Jan 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20070019646 A1 | Jan 2007 | US |