The present invention relates to management of traffic forwarding in packet networks, and in particular to methods of preventing loops in multicast routes mapped through a packet network.
Ethernet is increasingly popular as a transport network for high speed Wide Area Network (WAN) communications. Various techniques have been developed to enable the deployment of Ethernet transport networks with a mesh topology. This enables the provisioning of diverse paths for traffic protection, and has proven to be popular with network operators and carriers. However, Ethernet requires that traffic forwarding through the network must be controlled to prevent loops.
Spanning Tree Protocol (STP) is frequently used to compute traffic forwarding paths through a mesh network, in such a manner that loops are prevented. In effect, STP converts the mesh network topology into a tree topology. If a network failure (such as a node or link failure) occurs, the tree must be re-computed to re-establish connectivity. In order to prevent network instability and formation of loops during the tree recomputation, all traffic through the tree is terminated until the new tree has been computed, and forwarding state implementing the new tree installed in each node. In large mesh networks, this can require several seconds.
Faster recovery times can be obtained by localizing failures to a particular branch. With this arrangement, the branch of the tree that is directly affected by the detected failure is “pruned”, and a new branch recomputed, starting from the root of the pruned branch. This has an advantage in that only traffic to the nodes directly affected by the network failure is interrupted, while traffic is permitted to flow through the rest of the network. However, in this case, the failure recovery time is dependent on the location of the failure, and the topology of the tree, and so can be unpredictable.
Another approach is to compute two (or more) topologically diverse trees from each node, to every other node. With this arrangement, each node is the “root” of a pair of trees, one of which can be designated as a working tree, and the other as a protection tree. If a network failure affecting the working tree is detected, a failure indication message is propagated to the root node, which can then “switch” traffic to the protection tree. In this case, the failure recovery time is principally dependent on the time required for the failure indication message to propagate to the root node, which can be relatively fast. However, this method requires the computation of a very large number of trees within the network, and it can be very difficult to guarantee topological diversity between the working and protection trees.
For Ethernet transport networks, it would be desirable to obtain failure recovery times comparable to those obtained in physical layer transport technologies such as Synchronous Optical Network/Synchronous Digital Hierarchy SONET/SDH, that is; 50 mSec, or less. In theory, techniques based on the pre-computation of working and protection paths are capable of achieving this level of protection switching performance. However, this performance comes at a cost of great complexity. A simpler solution is desired.
ITU-T SG 15/Q9 recommendation G.8032 (February, 2008) describes protection switching in an Ethernet ring. Referring to
As described in ITU-T recommendation G.8032, a failure of either a link 6 or a node 4 of the ring 2 will be detected by the two nodes nearest the point of failure. Both of these nodes will install a channel block on the port facing the fault and will send a Failure Indication Message (FIM) to their adjacent nodes in the ring. These FIMs will be propagated, in opposite directions, around the ring. Upon receipt of the initial FIM, each node flushes its forwarding database (FDB), and forwards the FIM to the next node on the ring. In addition, the RPL-Owner will remove the channel block 8. This effectively enables connectivity within the ring to be re-established using conventional Ethernet flooding and MAC learning functionality. A convenient aspect of this approach is that the conventional Ethernet flooding behaviour forwards traffic into the ring as the primary mechanism for MAC learning and path computation. As a result, traffic flow within the ring is restored almost immediately after the FDB in each node 4 has been flushed, so that the failure recovery time of the network 2 is dominated by the speed at with the FIMs propagate around the ring. Failure recovery times of 50 msec or less can readily be obtained in practical WANs. However, ITU/T recommendation G.8032 is based on a ring network topology. No comparable scheme is available for implementation in a mesh network.
Thus, an aspect of the present invention provides a method of routing traffic through a packet network having a mesh physical topography. At least two types of network primitive are defined, each type of network primitive providing a respective model of traffic forwarding through at least two neighbour nodes of the network. A network model encompassing at least a portion of the network is constructed using a set of two or more interconnected network primitives. The network model has nodes and links corresponding to respective nodes and lines of the network. Respective forwarding information is computed for each node of the network model. For each node of the network model, the respective computed forwarding information is installed in a forwarding database of the corresponding node of the network, such that traffic is forwarded by each node of the network in accordance with the respective computed forwarding information.
An advantage of the present invention is that, ring protection schemes such as those defined in ITU/T recommendation G.8032 can be implemented in a mesh network, thereby enabling high speed robust failure recovery within the network.
Further features and advantages of the present invention will become apparent from the following detailed description, taken in combination with the appended drawings, in which:
a-2b schematically illustrate respective network primitives in accordance with an aspect of the present invention;
a-3d schematically illustrate modeling of a representative mesh network using the network primitives of
a-4c schematically illustrate failure recovery in the network of
It will be noted that throughout the appended drawings, like features are identified by like reference numerals.
The present invention provides a method of supporting high speed protection switching in an Ethernet network having a mesh topology. Embodiments of the invention are described below, by way of example only, with reference to
The present invention provides a pair of network primitives, comprising a ring and a sub-ring. Both of these network primitives are layer-2 (or higher) constructs, so that a set of network primitives can be used to model a network having a different physical topology, such as a mesh.
As may be seen in
Referring to
As may be appreciated, allocation of physical network resources to each network primitive can be done in a variety of ways. For example, in an Ethernet network, each network primitive may be assigned a respective Virtual Local Area Network Identifier (VLAN-ID), or, alternatively, a respective Bearer VLAN-ID (B-VID). This arrangement enables known techniques to be used to compute and install Forwarding Database (FDB) entries for each node implementing a given network primitive. A connection between two network primitives can be implemented by way of a translation function at the point (node) at which the two network primitives are connected.
For example, consider a network in which each network primitive is defined using a respective VLAN-ID, and a packet flow (which may, for example, be identified by the source and destination addresses) traverses a node between two interconnected network primitives. In this case, packets received by the node will have the VLAN-ID of the first network primitive. The translation function will then replace this VLAN-ID with the corresponding ID of the second network primitive, so that conventional packet forwarding techniques will operate to transmit the packet through the second network primitive.
It can be shown that any network having a physical mesh topology can be modeled using ring and sub-ring network primitives which are interconnected in accordance with the following rules: a network primitive can be connected to any number of other network primitives of either type; the end-nodes of a sub-ring network primitive may be connected to a common network primitive or different network primitives, as desired; connections between network primitives occur exclusively at nodes, thus a network primitive cannot be connected to another network primitive via a shared link.
For example,
As shown in
As may be seen in
In this respect, it will be noted that the placement (and effect) of a channel block 8 pertains only to the network primitive within which the channel block 8 is defined. For example, in
Within the network model (
Referring again to
Referring to
Referring to
In the foregoing examples, network primitives are defined which encompass, and model, the entire physical network. However, it will be appreciated that this is not essential. May alternative variations are possible, all within the scope of the present invention. In general, there can be as many different network primitives as there are identifiers used to identify them. A set of interconnected network primitives can be defined to model an entire mesh network, or a desired portion of it. Multiple such sets of interconnected network primitives can be defined, each of which models a respective portion of the network. These sets may, or may not over lap, as desired. For example, it is frequently desirable to define point-to-point (e-line) connections between Source and Destination Addresses (nodes) in the network. As described above, some protection-switching strategies use two or more of such point-to-point paths, and try to ensure topologically diversity between the two paths. Instead, a chain of ring and sub-ring network primitives can be defined between the two nodes, as shown in
As mentioned above, in some embodiments, each network primitive may be identified using a respective VLAN-ID. In the scenario of
As may also be seen in
The embodiment(s) of the invention described above is(are) intended to be exemplary only. The scope of the invention is therefore intended to be limited solely by the scope of the appended claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CA2009/000584 | 5/1/2009 | WO | 00 | 10/17/2011 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2010/124355 | 11/4/2010 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6370110 | Eslambolchi | Apr 2002 | B1 |
7729337 | Saleh et al. | Jun 2010 | B2 |
20020036988 | Cardwell et al. | Mar 2002 | A1 |
20020167899 | Thompson et al. | Nov 2002 | A1 |
20030031123 | Gilmour et al. | Feb 2003 | A1 |
20030067867 | Weis | Apr 2003 | A1 |
20030223357 | Lee | Dec 2003 | A1 |
20040054807 | Harvey et al. | Mar 2004 | A1 |
20050094577 | Ashwood-Smith | May 2005 | A1 |
20050198524 | Benvenuti et al. | Sep 2005 | A1 |
20060098671 | Shachnai et al. | May 2006 | A1 |
20070076719 | Allan et al. | Apr 2007 | A1 |
20070083907 | Serbest et al. | Apr 2007 | A1 |
20070237072 | Scholl | Oct 2007 | A1 |
20070280251 | Wang et al. | Dec 2007 | A1 |
20080095047 | Skalecki et al. | Apr 2008 | A1 |
20090059800 | Mohan | Mar 2009 | A1 |
Number | Date | Country |
---|---|---|
2249824 | Apr 2000 | CA |
WO2005083913 | Sep 2005 | WO |
Entry |
---|
“Recommendation ITU-T G.8032/Y.1344—Amendment 1”, Apr. 2009, pp. 1-20. |
Recommendation ITU-T G.8032/Y.1344 was approved on Jun. 22, 2008 by ITU-T Study Group 15 (2005-2008) under Recommendation ITU-T A.8 procedure. pp 1-46. |
Number | Date | Country | |
---|---|---|---|
20120033666 A1 | Feb 2012 | US |