This disclosure relates generally to networks and, more particularly, to methods and apparatus to determine an alternate route in a network.
Alternative routing techniques are used in modern data networks to route a data packet to a destination using an alternate (e.g., backup) route when, for example, a link along a primary route to the destination becomes unavailable. For example, multiprotocol label switching (MPLS) networks can employ fast rerouting (FRR) techniques to route a data packet along an alternate route towards a destination. One such FRR technique involves configuring the network nodes (e.g., which may be routers, such as provider (P) routers, provider edge (PE) routers, etc.) to have both primary and backup routes (e.g., tunnels) between the possible sources and destinations in the network. Another such FRR technique involves using the routing protocol (such as an interior gateway protocol (IGP), which is a class of routing protocols) for determining the primary route from a network node to a destination to also attempt to find another (e.g., loop free alternative (LFA)) route to the destination.
Methods and apparatus to determine an alternate in a network are disclosed herein. An example method disclosed herein to route a data packet to a destination in a network includes a current node (e.g., router) in the network determining that a primary route for routing the data packet to the destination is unavailable (e.g., by determining that the next hop link has failed), or that the data packet is already being routed along an alternate route to the destination (e.g., due to a previous node detecting unavailability of the primary route). The example method then includes identifying a set of neighbor nodes of the current node, and determining multiplicity values for this set of neighbor nodes. As described in greater detail below, a multiplicity value for a respective node in the set of neighbor nodes represents a number of times the data packet has been routed to the respective neighbor node (e.g., along an alternate route towards the destination). The example method further includes selecting, based on the multiplicity values, one neighbor node from the set of neighbor nodes to which to send the data packet to route the data packet to the destination.
In some examples, the multiplicity values for the set of neighbor nodes are determined by processing labels included in a routing label stack of the data packet, as described in greater detail below. Also, in some examples a neighbor node having the minimum multiplicity among the set of neighbor nodes is selected to be the neighbor node to which the data packet is sent to continue routing the data packet to the destination. If multiple neighbor nodes have the same minimum multiplicity value, routing costs can be further used to select the neighbor node to which the data packet is to be sent, as described in greater detail below.
Turning to the figures, a block diagram of an example network 100 supporting alternative routing is illustrated in
The example network 100 of
The links 125-140 could be implemented using any type of communication interface or connection (e.g., which may be physical, logical, etc., and/or any combination thereof), and can support any type of routing protocol. Also, the links 125-140 each have an associated distance, or routing cost. In some examples, the link distances/routing costs are determined using a routing protocol, such as an interior gateway protocol (IGP). Example IGPs include, but are not limited to, the open shortest path first (OSPF) protocol, the intermediate system to intermediate system (IS-IS) protocol, etc. In the illustrated example, each of the links 125-140 has the same distance (or routing cost), which is denoted by the letter “C” in
In the illustrated example of
When the link 125 is determined to be unavailable, the source node 105 can use an alternate route 150 (also referred to an alternate tunnel 150, a backup tunnel 150, etc.) to enable a data packet to still be routed from the source node 105 to the destination node 110. For example, one or more routing tables in the source node 105 may be configured with the alternate route 150 as a backup for routing data packets from the source node 105 to the destination node 110. For a network having N nodes, the complexity of configuring primary and alternate routes at each of the nodes is on the order of N2, denoted O (N2), because every node could potentially be a source and a destination of data packets. As such, configuring the nodes 105-120 with primary and alternate routes for use during alternative routing can be computationally difficult and may not scale as the number of nodes 105-120 increases.
For example, in
Dist(N, D)<Dist(N, S)+Dist(S, D). Equation 1
In Equation 1, Dist(N, D) is the distance (or routing cost) from the neighbor node 215 to the destination node 210, Dist(N, S) is the distance (or routing cost) from the neighbor node 215 to the source node 205, and Dist(S, D) is the distance (or routing cost) from the source node 205 to the destination node 210.
In the illustrated example
An example network 300 supporting multiplicity-based alternative routing in accordance with the example methods and apparatus described herein is illustrated in
However, unlike the network 100 of
Instead, the network 300 employs multiplicity-based alternative routing in which routing decisions are based on multiplicity values representing the number of times a given data packet has been routed to (e.g., has visited) different nodes along an alternate route from, for example, the source node 305 to the destination node 310. In some examples, multiplicity-based alternative routing as performed in the network 300 also uses distances, or routing costs, along with the multiplicity values when making alternative routing decisions. In the illustrated example of
An example alternate routing processor 400 that may be used to implement one or more of the alternate routing processors 400A-D of
The alternate routing processor 400 of
In some examples, the alternate routing processor 400 of
The alternate routing processor 400 of
The alternate routing processor 400 of
Turning to
Beginning with
Accordingly, in
Accordingly, in
While an example manner of implementing the alternate routing processors 400A-D of
Flowcharts and pseudocode representative of example machine readable instructions that may be executed to implement the example network 300, one or more of the example nodes 305-320, one or more of the example alternate routing processors 400 and/or 400A-D, the example data interface 405, the example multiplicity determiner 410, the example routing cost calculator 415, the example neighbor selector 420 and/or the example controller 425 are shown in
As mentioned above, the example processes of
Example machine readable instructions 600 that may be executed to implement the example alternate routing processor 400 of
Before proceeding with a description of the example machine readable instructions 600 and the pseudocode of Table 1, the mathematical notation used in the pseudocode is developed as follows. Let G=(N, A) be a connected graph (e.g., representing a network, such as the network 300) with node set G (e.g., corresponding to the nodes 305-320) and arc set A (e.g., corresponding to the links 325-340). For a node x ε N, let N (x) be the set of neighbors of x, where a neighbor of x is a node that is one arc (e.g., one link) away from x. Each arc (i, j) ε A has a cost c(i, j) (e.g., which may the same or different in the two directions i to j, or j to i). In some examples, c(i, j) is restricted to be a positive integer. (For example, such an integer valued restriction can be met by approximating, to the desired accuracy, each arc cost by an improper fraction, and then multiplying the fractions by the least common multiple of the fraction denominators.) For each arc i, j ε A, let c*(i, j) be the cost of the shortest path (e.g., route) in the graph (e.g., network) G between nodes i and j. Let s be a given source node, and d be a given destination node.
Turning to
At block 615, the controller 425 determines whether the routing label stack of the received data packet includes one or more backup labels. As described above, in some examples backup labels are assigned to the nodes in a network to uniquely identify the nodes and to indicate that a data packet is already being routed along an alternate route to a destination. If no backup labels are included in the label stack (block 615), the data packet is not currently undergoing alternative routing and at block 620 the controller 425 determines whether a primary (or other particular) route (e.g., as computed by an IGP) towards the destination is unavailable. If the primary route is not unavailable (or, in other words, if the primary route is available) (block 620), then no alternative routing is to be performed. Execution of the example machine readable instructions 600 ends.
However, if the primary route is unavailable (block 620), then at block 625 the controller 425 can initialize a backup label stack to be included with the data packet received at block 605 as it is routed to the destination. At block 625, the controller 425 also initializes the multiplicity values for the set of neighbor nodes of the current node. For example, at block 625 the controller 425 can invoke the pseudocode of Table 1 to perform alternative routing, and perform line 1 at which: (i) the label stack L is initialized (e.g., L=Ø); (ii) the multiplicity values for the set of neighbor nodes are set to zero (e.g., Δ(n)=0 for n ε N); and (iii) the current node (x) is set to be the source node (s) (e.g., corresponding to the source node 305) from which alternative routing is to begin.
Returning to block 615, if backup labels are in the label stack, the data packet is currently undergoing alternative routing and at block 630 the controller 425 determines whether a number of nodes already visited by the received data packet along the alternate route exceeds a threshold. If the number of visited nodes exceeds the threshold (block 630), the controller 425 determines that an alternate route does not exist (or is too long or incurs too much delay to be of use) and, thus, execution of the example machine readable instructions 600 ends.
However, if the number of visited nodes does not exceed the threshold (block 630), or initialization of the alternative routing process is complete (block 625), at block 635 the multiplicity determiner 410 determines the multiplicity values for the neighbor nodes of the current node and identifies or otherwise determines a set of neighbor nodes having, for example, a minimum multiplicity value (or some other multiplicity value). For example, the processing at block 635 can correspond to the processing at line 3 of the pseudocode of Table 1. In line 3 of Table 1, Y (a set of neighbor nodes) is set equal to those nodes (y) in the neighbors set N (x) having the minimum multiplicity value (e.g., such that Δ(y)=minn ε NΔ(n)).
At block 640, the controller 425 determines whether the set of neighbor nodes having the minimum multiplicity value includes multiple neighbor nodes. If the set of neighbor nodes (Y) includes multiple neighbor nodes (block 640), at block 645 the controller 425 invokes the routing cost calculator 415 to determine routing costs for routing the data packet received at block 605 to the destination via each one of the neighbor nodes included in the set of neighbor nodes determined at block 635 as having the minimum multiplicity value. For example, the processing at block 645 can correspond to the processing at line 4 of the pseudocode of Table 1 at which the routing cost for a particular neighbor node (y) in the set of neighbor nodes with minimum multiplicity is determined by summing (i) the routing cost c(x, y) for routing the data packet from the current node (x) to a particular neighbor node (y); and (ii) the routing cost c*(y, d) for routing the data packet from the particular neighbor node (y) to the destination node (d). In some examples, the routing costs c(x, y) and c*(y, d) are determined in accordance with an IGP, such as OSPF, IS-IS, etc.
At block 650, the neighbor selector 420 selects the neighbor node with, for example, the minimum routing cost (or some or routing cost) from the set of neighbor nodes with minimum multiplicity. In other words, at block 650 the neighbor selector 420 can select the neighbor node having both the minimum multiplicity value and the minimum routing cost. For example, the processing at block 645 can correspond to the processing at line 4 of the pseudocode of Table 1 at which the node (y) having the smallest cost from among the set of neighbor nodes (Y) is picked.
After the neighbor node is selected at block 650, or if the set of neighbor nodes with minimum multiplicity does not include multiple nodes (block 640) and, thus, has only one node which is selected by default, processing proceeds to block 655. At block 655, the controller 425 increases the multiplicity value of the current node (e.g., to indicate that the received data packet has visited the current node). In some examples, the controller 425 can add another backup label corresponding to the current node to the label stack of the data packet to increase the current node's multiplicity value. Additionally or alternatively, in some examples the controller 425 can modify (e.g., increment) a field of the current node's backup label that represents the multiplicity value of the current node. At block 660, the data packet, with its updated label stack, is sent to the selected neighbor node for routing to the destination. In some examples, the processing at blocks 655 and 660 corresponds to the processing at line 5 of the pseudocode of Table 1 at which the multiplicity value (Δ(x)) of the current node (x) is incremented by one (Δ(x)←Δ(x)+1), the backup label for the current node (x) is added to the label stack (L←L ∪ {x}), and the data packet and label stack (L) are sent from the current node (x) to the selected neighbor node (y).
At block 665, the controller 425 of the next neighbor node that receives the data packet (e.g., the selected neighbor node to which the data packet was sent at block 660) determines whether the destination has been reached. If the destination has not been reached (block 665), processing returns to block 605 and blocks subsequent thereto at which the alternate routing processor 400 of the next network node continues to perform alternative routing of the data packet. For example, the processing at block 665 can correspond to the processing at lines 2 and 6 of the pseudocode of Table 1. However, if the destination has been reached (block 665), execution of the example machine readable instructions ends.
Both example label stacks 700 and 750 can yield equivalent results. For example, the label stacks 700 and 750 in the illustrated examples both indicate that the multiplicity of node A is 2, the multiplicity of node B is 2, the multiplicity of node C is 1, and the multiplicity of node D is 1. However, in some examples, the label stack 700 can be more compact and, thus, use less memory and transmission bandwidth than the label stack 750. Also, in some examples the label stack 750 can be easier to process, resulting in less processor utilization, and also provide an ordered history of the routing of the data packet along the alternate route.
It can be shown that the Route (s, d) procedure represented by the example pseudocode of Table 1 will converge to an alternate route from the source node (s) to the destination node (d) if any alternate route exists. Assuming that each cost c(i, j) is a positive integer, the convergence proof for the Route (s, d) procedure uses the following definition. For each non-negative integer k, define:
Nk={n ε N|c*(n,d)=k}.
Note that N0={d} and Nk may be empty for one or more values of k. For example, if each arc cost c(i,j)≧2, then N1=Ø. Define P to be the route (sequence of nodes) generated by procedure Route (s, d). Note that P may contain cycles (e.g., loops).
Lemma. If P never reaches d, then for k≧1 the route P, once leaving s, never reaches a node in Nk.
Proof. The proof is by induction. Assume P never reaches d, and consider k=1. Clearly P never reaches a node in N1 if it is empty, so assume N1≠Ø. Suppose P reaches some node x ε N1. If P reaches N1 multiple times, let x be the first such node. Then, d is a neighbor of x (e.g., they are separated by a single arc of cost=1) and Δ(d)=0. If z is any other neighbor of x such that Δ(z)=0, then c(x, z)+c*(z, d)>c*(x, d)=1, since c(x, z)>0 and c*(z, d)≧1. By lines 3 and 4 of the pseudocode of Table 1 for Route (s, t), node x will forward the packet to d, which contradicts the assumption that P never reaches d. Thus P never reaches a node in N1.
Suppose the Lemma holds for 1≦k≦p (that is, suppose P never visits a node in Nk for 1≦k≦p) and consider NP+1. Clearly P never reaches a node in Np+1 if it is empty, so assume Np+1≠Ø. Suppose that P, after leaving s, reaches some node x ε Np+1. If P reaches Np+1 multiple times, let x be the first such node. Then c*(x, d)=p+1.
Define Y1={y ε N(x)|Δ(y)=0 and c*(y, d)≦p} and Y2={y ε N(x)|Δ(y)=0 and c*(y, d)≧p+1}. It can be shown that Y1≠Ø. To see this, let Q be any route from x to d with cost p+1, and let z be the next node on this route. Then c(x, z)+c*(z, d)=p+1. Since c(x, z) is a positive integer, then z ε Nr for some r such that 0≦r≦p. If z=d, then Δ(z)=0, since by assumption P never reaches d. If z≠d, then Δ(z)=0, since by the induction hypothesis, P never reaches a node in Nr for 1≦r≦p. Thus z ε Y1, which establishes that Y1≠Ø.
Let
Theorem. The route generated by procedure Route(s, d) terminates at d.
Proof. The procedure Route (s, d) terminates if it reaches d, so it suffices to prove that P reaches d. Suppose to the contrary that P never reaches d. Let y be the neighbor of s, selected by Route(s, t), to which the source s forwards the packet. Defining c=c* (y, d), then y ε Nc. However, by the Lemma, P never reaches a node in Nc, which is a contradiction. Hence P must reach d, thereby establishing the convergence theorem for Route (s, d) of Table 1.
The system 800 of the instant example includes a processor 812 such as a general purpose programmable processor. The processor 812 includes a local memory 814, and executes coded instructions 816 present in the local memory 814 and/or in another memory device. The processor 812 may execute, among other things, the machine readable instructions represented in
The processor 812 is in communication with a main memory including a volatile memory 818 and a non-volatile memory 820 via a bus 822. The volatile memory 818 may be implemented by Static Random Access Memory (SRAM), Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. The non-volatile memory 820 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 818, 820 is typically controlled by a memory controller (not shown).
The processing system 800 also includes an interface circuit 824. The interface circuit 824 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a third generation input/output (3GIO) interface.
One or more input devices 826 are connected to the interface circuit 824. The input device(s) 826 permit a user to enter data and commands into the processor 812. The input device(s) can be implemented by, for example, a keyboard, a mouse, a touchscreen, a track-pad, a trackball, an isopoint and/or a voice recognition system.
One or more output devices 828 are also connected to the interface circuit 824. The output devices 828 can be implemented, for example, by display devices (e.g., a liquid crystal display, a cathode ray tube display (CRT)), by a printer and/or by speakers. The interface circuit 824, thus, typically includes a graphics driver card.
The interface circuit 824 also includes a communication device such as a modem or network interface card to facilitate exchange of data with external computers via a network (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
The processing system 800 also includes one or more mass storage devices 830 for storing machine readable instructions and data. Examples of such mass storage devices 830 include floppy disk drives, hard drive disks, compact disk drives and digital versatile disk (DVD) drives.
The coded instructions 832 of
At least some of the above described example methods and/or apparatus are implemented by one or more software and/or firmware programs running on a computer processor. However, dedicated hardware implementations including, but not limited to, application specific integrated circuits, programmable logic arrays and other hardware devices can likewise be constructed to implement some or all of the example methods and/or apparatus described herein, either in whole or in part. Furthermore, alternative software implementations including, but not limited to, distributed processing or component/object distributed processing, parallel processing, or virtual machine processing can also be constructed to implement the example methods and/or apparatus described herein.
To the extent the above specification describes example components and functions with reference to particular standards and protocols, it is understood that the scope of this patent is not limited to such standards and protocols. For instance, each of the standards for Internet and other packet switched network transmission (e.g., Transmission Control Protocol (TCP)/Internet Protocol (IP), User Datagram Protocol (UDP)/IP, HyperText Markup Language (HTML), HyperText Transfer Protocol (HTTP)) represent examples of the current state of the art. Such standards are periodically superseded by faster or more efficient equivalents having the same general functionality. Accordingly, replacement standards and protocols having the same functions are equivalents which are contemplated by this patent and are intended to be included within the scope of the accompanying claims.
Additionally, although this patent discloses example systems including software or firmware executed on hardware, it should be noted that such systems are merely illustrative and should not be considered as limiting. For example, it is contemplated that any or all of these hardware and software components could be embodied exclusively in hardware, exclusively in software, exclusively in firmware or in some combination of hardware, firmware and/or software. Accordingly, while the above specification described example systems, methods and articles of manufacture, the examples are not the only way to implement such systems, methods and articles of manufacture. Therefore, although certain example methods, apparatus and articles of manufacture have been described herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the claims either literally or under the doctrine of equivalents.
This patent arises from a continuation of U.S. patent application Ser. No. 12/967,968 (now U.S. Pat. No. 8,514,859), entitled “METHODS AND APPARATUS TO DETERMINE AN ALTERNATE ROUTE IN A NETWORK” and filed on Dec. 14, 2010.U.S. patent application Ser. No. 12/967,968 is hereby incorporated by reference in its entirety, and priority to the above-referenced application is hereby claimed.
Number | Name | Date | Kind |
---|---|---|---|
5034945 | Kimoto et al. | Jul 1991 | A |
5883891 | Williams et al. | Mar 1999 | A |
6704283 | Stiller et al. | Mar 2004 | B1 |
7010471 | Rosenberg | Mar 2006 | B2 |
7359988 | Kim et al. | Apr 2008 | B2 |
7471668 | Qin et al. | Dec 2008 | B2 |
7477640 | Oguchi et al. | Jan 2009 | B2 |
7502314 | Shimizu | Mar 2009 | B2 |
7532629 | Ebata | May 2009 | B2 |
7535838 | Mitchell et al. | May 2009 | B1 |
8059562 | Iyer et al. | Nov 2011 | B2 |
8175079 | Alapuranen et al. | May 2012 | B2 |
8213432 | Takemura et al. | Jul 2012 | B2 |
8391255 | Ribiere et al. | Mar 2013 | B2 |
20040236762 | Chaudhuri et al. | Nov 2004 | A1 |
20060142913 | Coffee et al. | Jun 2006 | A1 |
20060176901 | Terai et al. | Aug 2006 | A1 |
20080037560 | Jia et al. | Feb 2008 | A1 |
20080192764 | Arefi et al. | Aug 2008 | A1 |
20080310340 | Isozu | Dec 2008 | A1 |
20080316920 | Chun et al. | Dec 2008 | A1 |
20100189113 | Csaszar et al. | Jul 2010 | A1 |
20100278140 | Smith et al. | Nov 2010 | A1 |
20110305169 | Karuppiah et al. | Dec 2011 | A1 |
20120147883 | Uttaro et al. | Jun 2012 | A1 |
Entry |
---|
Atlas et al., “Basic Specification for IP Fast Reroute: Loop-Free Alternates,” RFC: 5286, IETF Trust, Network Working Group, Standards Track, Sep. 2008 (32 pages). |
Filsfils, Clarence et al., “LFA Applicability in SP Networks,” IETF Trust, Network Working Group, Internet-Draft, draft-ieft-rtgwg-lfa-applicability-OO, Aug. 2010 (29 pages). |
Gonfa, Lemma Hundessa, “Fast Rerouting Mechanism,” Chapter 3 in “Enhanced Fast Rerouting Mechanisms for Protected Traffic in MPLS Networks,” Thesis, Universitat Politecnica de Catalunya, Mar. 4, 2003 (16 pages). |
Previdi, Stefano, “IP Fast ReRoute Technologies,” 2008 Cisco Systems, Inc. (60 pages). |
Shand et al., “IP Fast Reroute Framework,” RFC: 5714, IETF Trust, Network Working Group, Standards Track, Jan. 2010 (16 pages). |
USPTO, “Notice of Allowance,” issued in connection with U.S. Appl. No. 12/967,968, dated Apr. 23, 2013 (10 pages). |
Number | Date | Country | |
---|---|---|---|
20130329737 A1 | Dec 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12967968 | Dec 2010 | US |
Child | 13965986 | US |