This application claims the benefit of European patent application No. 11003012.9, filed Apr. 11, 2011, the entirety of which is hereby incorporated by reference.
1. Field of the Invention
The present invention relates to a method and system for automatic selection of detour paths in a wireless mesh network.
2. Description of Related Art
Wireless Mesh Networks (WMNs) are two-tier networks where nomadic or mobile users access the Internet or intra-WMN services via a wireless backbone made of a number of Mesh Routers (MRs) communicating with each other over wireless links. The users can be laptops, cell phones, personal digital assistants, data collection devices and sensors (for example in the field of video-surveillance), and so on. MRs forward packets in a multi-hop manner to reach the intended destination within the WMN. Usually, MRs are in fixed positions, but some degree of mobility is also possible. Wireless mesh networks can be implemented with various technologies including 802.15, 802.11, 802.16 IEEE standards.
Even though nodes are usually in fixed positions, WMN resiliency is significantly affected by time-varying phenomena, like interference from co-located networks, shadowing, and obstruction, which are connected to the wireless channel characteristics. These phenomena may lead to transient wireless link failures that may occur at very short time scales.
Re-Routing techniques, that is techniques adapted to detour data packets into detour paths whenever a problem is detected on a primary path, are known in the art.
Re-Routing techniques can be of the reactive or proactive type. In the first case, detour paths are set-up a posteriori, whenever a failure is detected. In the second case, instead, detour paths are set-up a priori, before failure detection, in order to guarantee smaller response time.
For example, Fast Re-Routing (FRR) proactive techniques have been developed in the art to improve the resilience of wired (IP-based) networks. Multi Protocol Label Switching (MPLS) Fast Re-Route is standardized by the Internet Engineering Task Force (IETF) and is a feature of the RSVP Traffic Engineering (RSVP-TE) protocol. MPLS Fast Re-Route leverages on the availability of a Traffic Engineering Database (TED) containing detailed and up-to-date information of the network topology and resources reserved on each link. This information is usually collected by means of Open Shortest Path First routing protocol with Traffic Engineering extensions.
The Applicant faced the technical problem of providing Re-Routing in a WMN.
The Applicant observed that the above mentioned MPLS Fast Re-Route technique relies on a full knowledge of the network topology.
However, maintenance of a full and continuously up-to-date network topology knowledge requires numerous and frequent exchanges of information between the nodes of the network and a high number of information to be processed by each node.
Said maintenance can be a very hard task to be achieved in a WMN.
Indeed, in a WMN the available bandwidth and the node resources and capabilities are much more limited than in wired networks. Moreover, the case where different nodes have inconsistency in their topology knowledge might be very likely to occur, due to the time-varying characteristics of the wireless links.
The Applicant thus faced the technical problem of implementing proactive re-routing in a WMN by means of an effective procedure which requires very little resources in terms of processing complexity, signaling and information spreading.
The Applicant found that this can be achieved through a method of detour path determination, wherein, for data packets re-routing in a mesh network comprising a plurality of N nodes, with N being an integer greater than 1, arranged according to a network topology, each node having a K-hops neighborhood knowledge of the network topology, with 1≦K<N, primary paths being predefined for routing data packets within the mesh network, each primary path comprising a predefined ordered sequence of nodes,
The present invention also relates to a mesh network, comprising a plurality of N nodes, with N being an integer greater than 1, arranged according to a network topology, wherein each node has a K-hops neighborhood knowledge of the network topology, with 1≦K<N, primary paths are predefined for routing data packets within the mesh network, and each primary path comprises a predefined ordered sequence of nodes, with said N nodes comprising modules adapted to carry out the steps of the method described above.
Further characteristics and advantages of the present invention will become clearer from the following detailed description of some preferred embodiments thereof, made as an example and not for limiting purposes with reference to the attached drawings.
The nodes may be mesh routers (MRs).
Any two nodes that can communicate directly with one another are said to share a link and are called 1-hop neighbors. Nodes having a common neighbor but that are not neighbors themselves are called two-hop neighbors. Generalizing, nodes are said to be k-hop neighbors if there exists a k-hop path between them, i.e., with k−1 nodes in between, and no path shorter than a k-hop one exists between them.
Given a node I, the set of its k-hop neighbors is hereinafter denoted by Nk(I).
In the exemplary WMN 100 of
According to the invention, each node of the WMN 100 has a K-hop neighborhood knowledge, wherein k is an integer, with 1≦K<N. K can be a system parameter. Advantageously, K is much smaller than N. For example, k=1 or 2 and 10≦N≦20.
The K-hop neighborhood knowledge of each node X, hereinafter denoted by Tk(X), can be either full or partial.
The full K-hop neighborhood knowledge means that each node knows the 1-hop neighbors N1(X), for each node X belonging to Ni(I), for 0≦i≦K−1.
An example of node I full K-hop neighborhood knowledge, with K=2, is reported in
Information about the full K-hop neighborhood knowledge is typically available in a WMN from an underlying Medium Access Control (MAC) protocol, at least for K≦2. Indeed, this knowledge is typically needed at the MAC level to coordinate access to the channel in order to avoid or minimize transmission collisions. Examples of technologies for WMNs that embed signaling in the MAC control plane to exchange 2-hop neighborhood information are IEEE 802.11s, IEEE 802.15.5, and IEEE 802.16 mesh mode.
The partial K-hop neighborhood knowledge means that each node only has a partial knowledge of the WMN topology within its K-hop neighborhood. In particular, each node I only knows Ni(I), for 0≦i≦K. Moreover, for each node X belonging to Ni(I), for 0<i≦K, it is assumed that node I knows only the first hop of one i-hop path to reach node X. An example of node I partial K-hop neighborhood knowledge, with K=2, is reported in
In the WMN 10 primary paths are predefined and set up for routing data packets among the nodes.
The primary paths are selected and set up by the WMN control plane. As known in the art, the control plane is the part of the network architecture that is concerned with determining the information needed to define what to do with received packets. The primary path selection mechanism can be performed by executing a conventional WMN distributed routing protocol, or centrally solving some traffic engineering optimization problem.
Forwarding of data packets in the WMN 10 is advantageously performed in the data plane by means of label switching. As known in the art, the data plane is the part of the network architecture concerned with looking up received packets and decide how to handle them based on the information provided by the control plane.
Label switching means a mechanism wherein data packets are forwarded on the basis of their label.
A practical implementation of label switching could be based on MultiProtocol Label Switching (MPLS), which is an Internet Engineering Task Force (IETF) standardized protocol.
According to MPLS, data packets entering the WMN at one node, called ingress, are classified into a Forwarding Equivalence Class (FEC). All data packets with the same FEC follow a same primary path (called Label Switched Path or LSP) to the destination node, called egress. In the simple case, there exists exactly one FEC per each node in the WMN, i.e., classification is by destination address. However, the proposed procedure can also be used without modifications in the more general case of arbitrary FECs, e.g., as resulting from a traffic engineering method. All the nodes of the WMN, including intermediate ones, take per-packet forwarding decisions based on their label Forwarding Information Base (LFIB) structures. Said LFIB structures can be seen as associative tables, where the key is the label of an incoming packet (IN). Other fields in the LFIB structures can be the performed action (ACT), the output label (OUT), and the next 1-hop node for packet forwarding (NXT).
A simple example to show the use of the LFIB structure is illustrated in
Advantageously, in the data plane of WMN 10 label stacking is also implemented. This means that a single packet can carry two (and, in general, even more) labels: an inner label, which refers to a primary path, and an outer label, which is used over a secondary path (and so forth in the case of additional labels).
Label stacking is an efficient technique to enable fast re-routing of packets into a backup (detour) path deviating from an original primary path.
As mentioned above, Fast Re-Route via label stacking is standardized by IETF in MPLS with Traffic Engineering (TE) extensions. With MPLS Fast Re-Route primary and backup LSPs are established for next-hop or next-next-hop MPLS FRR (the former can protect against link failures while the latter can protect against link or router failures). When a failure is detected at the upstream router from the failure, the MPLS forwarding label for the backup LSP is pushed on the MPLS shim header at the upstream router and popped at the downstream router (next-hop or next-next-hop). These labels are pre-calculated and stored in the forwarding tables, so restoration is very fast.
A simple example to show the use of label stacking in WMN 10 in order to enable fast rerouting over a detour path is illustrated in
In order to set up detour path C, E, F, the following additional entries are required (shown in gray in
The additional entries required (shown in gray in
As stated above, as MPLS Fast Re-Route is a feature of the RSVP Traffic Engineering (RSVP-TE) protocol, it leverages on the availability of a Traffic Engineering Database (TED) containing full and up-to-date information of the network topology and resources reserved on each link.
However, in the WMN 10 according to the invention, no TED-based information is available for identifying and setting up detour paths to which re-route data packets whenever a problem is detected on a primary path. As said above, only the k-hop neighborhood topological knowledge is at disposal of each node of the WMN 10.
The nodes of the WMN 10 comprise hardware, software and/or firmware modules adapted to implement the method of the invention, according to which detour paths can be identified and set up a priori only by making use of said limited K-hop neighborhood knowledge of the network topology.
According to the method of the invention, in order to identify and set up a detour path for a primary path PPx (or part thereof), wherein the primary path PPx (or part thereof) has length L (in hops) and comprises a ordered sequence of nodes (e.g., I,B,E,J in the example shown in
The length L (in hops) of the primary path PPX (or part thereof) is equal or greater than 1. When the K-hop neighborhood knowledge of the nodes is full, the length L (in hops) is preferably equal or greater than K.
The identified detour path will have a length L′ (in hops)≦2*k.
The request data packet DDR is elaborated in sequence by each intermediate node between head node I and end node J (e.g., nodes B, E in
In a preferred embodiment of the invention, the request data packet DDR generated by head node I includes the following information:
In the above step a, head node I thus preferably carries out the following steps:
When the request data packet DDR is received by an intermediate node (e.g., B or E), the latter carries out the following steps:
In the above mentioned step b, at the receipt of the request data packet DDR, the end node J preferably performs the following actions:
When the response data packet DDM is received by an intermediate node (e.g., E or B), the latter passes the response data packet DDM back unchanged to the previous 1-hop node, identifying it by looking up in the ordered list of traversed node identifiers by starting from the top of the list and taking out the one immediately following its own identifier.
Similarly, the ordered list of traversed node identifiers enables node I to identify itself as the destination of the response data packet DDM.
In another embodiment of the invention, a node in the WMN 10 which is included in at least one primary path PPx may be adapted to store information concerning the sequence of nodes crossed by said primary path PPx. Such information might include a) the output label (that is, the label in the OUT field of the node's LFIB table) used by the node along the primary path PPx; and b) the list of node identifiers of the next P hops (L≦P≦N) in the primary path PPx starting from the considered node. Such information could for example be provided to the local node by means of suitable modifications of the LSP setup protocol adopted in the network architecture. Under this assumption, in order to identify and setup a detour path for a primary path PPx (or part thereof) of length L (e.g., I,B,E,J in the example shown in
When the request data packet DDR′ is received by a next node (e.g., B, E or J), the latter carries out the following steps:
As mentioned above, the K-hop neighborhood knowledge of node I and node J can be either full or partial.
When the K-hop neighborhood knowledge of node I and node J is full, the above mentioned step c) is advantageously carried out according to the following procedure.
When node I receives the response data packet DDM, it gets to know from the received DDM packet both the K-hops neighbourhood knowledge Tk(J) of node J and the list of nodes along the primary path PPx between I and J, including I and J themselves. In addition, by assumption, node I has a K-hops neighbourhood knowledge Tk(I) of the network topology. The detour path, if any, is then advantageously obtained by computing a constrained path from I to J in the network graph resulting from the union of Tk(I) and Tk(J), after pruning from the graph all intermediate nodes belonging to the primary path PPx.
Specifically, when node I receives the response data packet DDM, it preferably carries out the following steps:
For detour path set up is meant the sequence of operations required to install the identified detour path in the WMN 10, in which packet forwarding and packet re-routing are performed via label switching and label stacking. In particular, the aim of the detour path set up is that of updating the entries of the LFIB structure of each node belonging the identified detour path in order to enable fast re-routing via label stacking (e.g., in a way similar to what shown in
According to an embodiment of the invention schematically shown in
When the K-hop neighborhood knowledge Tk(I) and Tk(J) of node I and node J is partial, also the network topology knowledge around I and J, obtained by node I by merging Tk(I) and Tk(J), will be partial, as schematically shown in
In this case, the above mentioned step c) can advantageously be carried out by means of an iterative procedure.
Due to the fact that the K-hop neighborhood knowledge is partial, in this case the identification of a detour path and its consequent set up is not guaranteed, even if it does exist.
An iterative procedure according to an embodiment of the invention is the following.
Node I computes implicitly a candidate detour path by identifying an intermediate node W through which the detour path has to pass. It then tries to set up the whole detour path by means of a detour path set up procedure. If the set up is successful, the procedure is done. Otherwise, node I iterates the above steps by identifying a new candidate intermediate node and attempting to set up the corresponding detour path, until either no further candidate intermediate node is available, or the detour path is set up.
In particular, the iterative procedure can be implemented by means of an algorithm that searches for a common neighbor between head node I and end node J as a candidate intermediate node W through which the detour path will eventually pass. For example, the search can be performed so that the overall path length between I and J through the common neighbor is minimized. Moreover, a pruning operation is advantageously performed in order to ensure that the common neighbor is not belonging to the primary path PPx. If a candidate node is found, the detour path set up procedure is run in order to attempt to set up the whole detour path.
The detour path set up procedure proceeds iteratively, by means of a Detour Setup Request (DSR′) packet, a Detour Setup Failure (DSF) packet, and a Detour Setup Mapping (DSM′) packet, until it finds a detour path. Essentially, a DSR′ packet is generated by node I and propagated from node I towards intermediate node W and then, if the latter is reached, from node W to node J. Propagation is constrained by not traversing any node belonging to the primary path PPx, which must then be contained in the DSR′ packet. The DSR′ packet will also contain an ordered list of identifiers of the nodes traversed so far, while searching for a detour path. If the DSR′ packet reaches a node Y between I and W (or a node Y between W and J), whose next hop towards W (or J) belongs to the primary path PPx, a DSF packet is returned by node Y to node I, which starts a new iteration.
Otherwise, if node J is finally reached by the DSR′ packet, a DSM′ packet is sent back to node Ito install the detour path. The DSM′ packet is generated by node J and, by using the ordered list of node identifiers as received in the DSR′ packet, it is sent back from node J to node I along the found detour path. Considering that, as stated above, in MPLS labels are assigned by the downstream node, DSM′ packet advantageously contains information adapted to enable each node to set up the LFIB entry corresponding to the new identified detour path.
In the light of the above description it will be evident that the method of the invention allows to achieve the following advantages.
In the WMN 10 according to the invention, label switching/stacking is assumed in the data plane while no specific assumption is made for the routing protocol used in the control plane. The present invention is therefore independent of any underlying routing protocol. This implies the following advantages: i) the ability to target fast reaction times in a scale that cannot be achieved, without compromising network stability, when routing protocols are used, and ii) the versatility of the solution, as it can be adopted in a wide range of WMN architectural deployments where it is not be possible or advisable to modify the existing routing protocol.
As mentioned above, in the WMN 10 according to the invention, information about a full and updated knowledge of the network topology is not required. The only requirement is a k-hop neighborhood knowledge at each node. As mentioned above, this knowledge is typically available from the underlying MAC protocol. Therefore, the fulfillment of this requirement does not imply any additional overhead and/or any additional signaling and information spreading between the nodes of the network.
In addition, the procedure of detour path identification according to the invention, based on the use of said request data packet DDR (DDR′) and response data packet DDM, enables head node I to extend its knowledge of the network topology and to perform the detour path computation in an effective way by requiring a minimum exchange of packets (the two packets DDR or DDR′ and DDM) and a minimum exchange of information (e.g. list of node identifiers, k-hop neighborhood knowledge of node J and possibly hop counter and output label) between nodes.
The present invention thus allows to automatically discover and set up detour paths by means of very little resources in terms of processing complexity, signaling and information spreading. For this reason it is particularly advantageous when used in a wireless mesh network wherein the available bandwidth and the node resources and capabilities are much more limited than in wired networks.
However, the method of the invention can also be used in a wired mesh network.
It is also noted that the expression wireless mesh network can be used to encompass hybrid type networks, comprising both wireless and wired links.
The preceding description and drawings merely explain the invention and the invention is not limited thereto, as those of ordinary skill in the art who have the present disclosure before them will be able to make changes and variations thereto without departing from the scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
11003012 | Apr 2011 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
7839856 | Sinha et al. | Nov 2010 | B2 |
8208371 | Li et al. | Jun 2012 | B2 |
20030028818 | Fujita | Feb 2003 | A1 |
20050099948 | Wakumoto et al. | May 2005 | A1 |
20050259587 | Wakumoto et al. | Nov 2005 | A1 |
20090228575 | Thubert et al. | Sep 2009 | A1 |
Number | Date | Country |
---|---|---|
1404070 | Mar 2004 | EP |
1826961 | Aug 2007 | EP |
2512076 | Oct 2012 | EP |
Entry |
---|
Thomas H. Cormen, et al., Introduction to Algorithms, 2009, Third Ed., pp. 658-664, MIT Press, United States. |
E. W. Dijkstra, A Note on Two Problems in Connexion with Graphs, 1959, Numerisch Mathematik 1, pp. 269-271, Springer, Germany. |
Luciano Lenzini, et al., End-to-End Quality of Service over Heterogenous Networks, 2008, pp. 56-62, Springer-Vertag, Berlin, Germany. |
European Patent Office, Search Report issued in priority EP Application No. 11003012.9, Dated Sep. 19, 2011. |
Number | Date | Country | |
---|---|---|---|
20120257572 A1 | Oct 2012 | US |