The present application is related to commonly assigned U.S. patent application Ser. No. 09/546,052, entitled “Radio Network Routing Apparatus,” and filed Apr. 10, 2000, the disclosure of which is hereby incorporated herein by reference in its entirety.
The present invention relates generally to digital communications networks and, more particularly, to systems and methods for seamlessly integrating a multi-hop, multi-access packet radio network with its own private routing system (a MANET, or Mobile Ad-hoc NETwork) into an overall Open Shortest Path First (OSPF) routing environment by constructing a virtual model of the packet radio network to be used by OSPF for routing purposes.
Conventional wired communications networks, such as, for example, the Internet, use various algorithms for disseminating routing data necessary for routing packets from a source node to a destination node. Each node of the network that handles packets has sufficient knowledge of the network topology such that it can choose the right output interface through which to forward received packets. Link state routing algorithms, such as the OSPF algorithm, permit the construction of a network topology such that any given node in the network may make packet-forwarding decisions. OSPF is defined by Internet RFC 2328, STD 54, and related documents, published by the Internet Society. OSPF is also defined by Internet RFC 2740, and related documents, also published by the Internet Society.
OSPF has conventionally been implemented in wired point-to-point or multi-access (Ethernet like) networks. It may also be highly desirable to implement OSPF over a multi-hop, multi-access packet radio network with its own private, internal routing system, so as to permit seamless integration of such a network into an OSPF environment, and to achieve strict compatibility between that packet radio network and standard COTS (Commercial Off-The-Shelf) routers outside that network. This can be achieved either by implementing OSPF at a higher layer over the multi-hop, multi-access packet radio network on top of that network's private, internal routing system, or by implementing both routing systems in parallel at the same network layer. In such a scheme, OSPF would be responsible for routing between the packet radio network and external hosts or networks, while the packet radio network's internal routing system would handle routing of packets within the network. Similar schemes are commonly used to implement OSPF over, for example, an X.25 packet switched network or an ATM packet network, and are well-known to practitioners of the art.
However, a number of difficulties may arise if OSPF is implemented over a multi-hop, multi-access packet radio network with its own private, internal routing system. Although the private, internal routing system of such a network may enable it to appear to OSPF much like a wired network, the properties and characteristics of such radio networks are nevertheless very different from those of wired point-to-point or multi-access networks. Like an Ethernet, such radio networks link together a large number of routers; and also like an Ethernet, such networks typically provide a suite of unicast, multicast, and netwide broadcast services. However, unlike an Ethernet, such networks possess internal structure of their own. Both unicast and multicast packets may need to be relayed across the network by multiple lower-layer hops in accordance with the network's private routing scheme, and replicated many times in the process. Consequently, the cost of transport across the network is not the same for every node, but instead depends upon the location of the entrance and exit point. The traffic load on such a network may, therefore, depend just as critically upon appropriate choices of entrance and exit point, as upon efficient routing within the network.
Even worse, the structure of the radio network may fluctuate and, hence, these costs may be constantly changing due to radio mobility, interference, fading, and other causes. Furthermore, the capacity and reliability of such networks is typically much lower than for an Ethernet, and delays much longer; capacity is limited by the available radio bandwidth, reliability is reduced by increased risks of collisions, interface, noise, and fading, and by the possibility of transient routing inconsistencies at the lower layer; and delay is increased by the multi-hop relaying at the intranet layer.
Furthermore, the need to replicate packets within such a network for either unicast or multicast forwarding may introduce or exacerbate problems involved in scaling to networks with large numbers of nodes, especially large numbers of OSPF routers. This is especially unfortunate, as certain applications may require thousands of OSPF routers on such a network.
Therefore, there exists a need for systems and methods that can resolve some of the inherent problems that exist with implementing OSPF in a multi-hop, multi-access packet radio network.
Systems and methods consistent with the present invention address this need, and others, by modifying the basic OSPF algorithm to optimize it for use over a multi-hop, multi-access packet radio network while maintaining full compatibility with standard OSPF over other, adjacent networks, including wired networks. The modified OSPF algorithm, consistent with the invention, resolves the scaling problems and other issues that may be encountered if standard OSPF is employed over a multi-hop, multi-access packet radio network with its own, private internal routing system. One optimization of the modified OSPF algorithm is for routers belonging to the multi-hop, multi-access packet radio network to generate a virtual OSPF network model for the purpose of IP layer routing by OSPF that presents to OSPF routers an approximation of the true topology of the multi-hop, multi-access network as known by its private routing system in a form that can be efficiently distributed by OSPF and processed by OSPF routers. This virtual model hides most effects of intranet-layer mobility (i.e., changes in the connectivity graph) while exposing enough information about the intranet-layer topology to permit reasonable choices of entry and exit point to and from the multi-hop, multi-access packet radio network, and, thereby, minimizes the OSPF routing overhead by minimizing the rate of routing updates. This virtual model also minimizes OSPF routing overhead by minimizing the size of OSPF route advertisements and by minimizing the network degree of the virtual model.
In the virtual model, consistent with the present invention, a multi-hop, multi-access radio network may be represented as a set of multi-access links, with each being identified by its own designated router. This representation has very low average network degree (only a little greater than 2) and, hence, minimizes the size of route advertisements. Routers, consistent with the invention, may affiliate with the designated router in the same OSPF area to which they are closest. Adjacent multi-access links may be connected by connecting routers that belong to both links and/or by point-to-point links between routers in each multi-access link. A router belonging to a single multi-access link may be assumed to be able to communicate with every other router belonging to the same multi-access link at the same cost. The cost of routing a packet between routers belonging to different multi-access links may be the sum of the costs of the multi-access links traversed, and any connecting point-to-point links.
As an alternative to the above, each of the multi-access links just described may be replaced by a set of point-to-point links, arranged as a star with the router, that would have been the designated router of the multi-access link as its hub. Routers may affiliate with the hub router in the same OSPF area to which they are closest. Adjacent point-to-point stars may be connected by connecting routers that belong to both stars and/or by additional point-to-point links between routers in each star. A router belonging to a single star may be assumed to communicate with any other router belonging to the same star at a cost that is the sum of the costs of the point-to-point link from that router to the hub and from the hub to the second router. The cost of routing a packet between routers belonging to different stars may be the sum of the costs of the stars traversed, and any connecting point-to-point links. As will be appreciated, this representation is topologically almost equivalent to that of the preceeding paragraph, differing only in the specific manner of its representation by OSPF link state advertisements. In particular, it shares with the aforesaid representation the property of minimizing the average network degree, and hence routing overhead.
The virtual network model, consistent with the principles of the invention, may also include “mobile leaf routers” that may act as gateways to “mobile leaf networks,” represented as separate OSPF areas or AS-external routes. These mobile leaf routers may affiliate with the standard area router closest to them. The standard area router with which a mobile leaf router affiliates appears in the virtual network model as if it were the area border router and/or AS border router advertising the mobile leaf router along with the mobile leaf networks behind it. The standard area router with which a mobile leaf router affiliates is known as its “parent” router.
Routing, consistent with the principles of the invention, may be provided within the multi-hop, multi-access network that maintains consistency with conventional OSPF shortest-path routing across this, and adjacent wired networks, while exploiting the greater detail known to the private, internal routing protocol of the multi-hop, multi-access radio network. Routing, consistent with the invention, may include advertising of the virtual network model to all OSPF routers in the routing domain in accordance with standard OSPF practices, including even those routers not aware of the special optimizations for the multi-hop, multi-access network, so that all IP routing decisions are based upon the virtual model. Routing may further include modifying the OSPF forwarding table computation on routers within the multi-hop, multi-access network itself, so that instead of choosing the IP next hop in accordance with the usual OSPF procedures the desired exit point from the multi-hop, multi-access network is chosen instead. This exit point may be the true final exit point from the network, or it may be any intermediate point at which it is desirable or necessary for IP routing to regain control (such as at an OSPF Area or AS boundary, including the parent routers of mobile leaf routers).
Routing between the entry point to the multi-hop, multi-access network and the exit point from that network may then be performed by the private routing system internal to the multi-hop, multi-access network, rather than by OSPF. This internal, private routing system takes responsibility for routing a packet within the multi-hop, multi-access radio network, with the exit point as computed by the modified OSPF algorithm becoming the destination for use by the internal, private routing system. The actual route traversed by a data packet through the multi-hop, multi-access network may thus differ from the virtual route computed by OSPF from the virtual model. However, since all OSPF routing computations are performed using the same virtual model of the network on all routers, and since the chosen exit point always lies on the same route as the next hop as would have been computed by standard OSPF procedures and is always as close or closer to the destination than the standard next hop would have been, no risk of routing loops or dead zones is introduced by this modified routing algorithm and a valid routing algorithm is obtained.
In accordance with one aspect consistent with the principles of the invention, a method for integrating a sub-network comprising multiple routers with its own private, internal routing system into a network using another, public, global routing system is provided. The method includes acquiring information as to the internal topology of the sub-network and constructing a virtual model of the sub-network in terms of constructs comprehensible to the public, global routing system of the network. The method further includes employing that virtual model together with the sub-network's private, internal routing system for the purpose of routing within the sub-network and distributing the virtual model to other routers in the network for the purpose of routing in that network.
In accordance with another aspect consistent with the principles of the invention, a method of reducing routing overhead on a network containing a sub-network consisting of a plurality of routers is provided. The method includes employing a public routing protocol on the network and employing a separate, private routing protocol internal to the sub-network. The method further includes acquiring information as to an internal topology of the sub-network and constructing a virtual model of the sub-network in terms of constructs comprehensible to the public, global routing protocol. The method also includes employing the virtual model together with the sub-network's private, internal routing protocol for the purpose of routing within the sub-network and distributing the virtual model to other routers in the network for the purpose of routing in that network.
In accordance with yet another aspect consistent with the principles of the invention, a method of constructing a virtual model of a sub-network with its own private routing protocol, wherein the sub-network comprises multiple routers, is provided. The method includes determining a network graph identifying actual connectivity among the plurality of routers and representing the sub-network as a set of links. The method further includes constructing a virtual model of the network from the actual connectivity of the network graph, wherein connectivity of the virtual model may be different than the actual connectivity of the network graph.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate exemplary embodiments of the invention and, together with the description, explain the invention. In the drawings,
The following detailed description of the invention refers to the accompanying drawings. The same reference numbers in different drawings may identify the same or similar elements. Also, the following detailed description does not limit the invention. Instead, the scope of the invention is defined by the appended claims and their equivalents.
Systems and methods, consistent with the present invention, modify the basic OSPF algorithm (e.g., coined “Radio OSPF” herein) to optimize it for use over a multi-hop, multi-access packet radio network that has its own internal, private routing system. The modified OSPF algorithm, consistent with the present invention, utilizes a virtual network model for the purpose of IP layer routing that presents an approximation of the true topology of the multi-hop, multi-access packet network as known from its internal, private routing system. This virtual model hides most effects of intranet-layer mobility (i.e., changes in the connectivity graph) while exposing enough information about the intranet-layer topology to permit reasonable choices of entry and exit point to and from the multi-hop, multi-access packet radio network.
Sub-network 105 may include multiple routers 115-1 through 115-M and 120-1 through 120-N for routing data through sub-network 105. Routers 115-1 through 115-M and 120-1 through 120-N may be interconnected via various links. Mobile leaf routers 115-1 through 115-M may route data between sub-network 105 and mobile leaf sub-networks 110-1 and 110-M, respectively. Routers 115-1 through 115-M and 120-1 through 120-N may be stationary, semi-stationary, or mobile network nodes. Mobile leaf networks 110-1 through 110-M may include networks, such as, for example, local area networks, that are mobile, i.e., whose connectivity to network 105 may change over time.
Sub-network 105 may provide its own, internal routing protocol layer for routing within sub-network 105. As shown in the protocol diagram of
Network 100 may be divided into multiple OSPF areas, thus, introducing an element of hierarchical routing. For example, sub-network 105 of
Typically, it may not be necessary for every router to be part of a standard OSPF area. Those routers which interconnect sub-network 105 with external networks in such a way that sub-network 105 may be intended to serve as an alternative transit network to those external networks, or the external network(s) may be intended to serve as an alternative transit network to sub-network 105, may need to be configured into a OSPF standard area.
Those routers which need not be part of a standard OSPF area may often be configured as “mobile leaf” routers instead. Mobile leaf routers, together with the networks 110 behind them, constitute “mobile leaf” areas. Mobile leaf areas may optimize the commonly occurring situation in which a router serves as a single gateway to a set of wired networks. Each mobile leaf area may include this router, known as a “mobile leaf router,” together with a set of networks behind it. The mobile leaf router may form an access point between the mobile leaf networks behind it, and sub-network 105. Mobile leaf areas may be mobile, that is, the area including the mobile leaf router and the networks behind it may move around as a whole. As an area moves, its mobile leaf router may dynamically affiliate with one or another standard area router that becomes its border router. Thus, unlike standard OSPF areas whose border routers are manually configured, the border router for a mobile leaf area may be selected dynamically and may change as the mobile leaf router changes its location. These dynamically selected area border routers may be referred to hereinafter as “parent” routers.
A standard area may serve a different role in routing data as compared to mobile leaf areas. A standard area may need to be connected, but mobile leaf areas may not need to be. If a standard area partitions, it cannot be healed by routes through mobile leaf areas. However, if a mobile leaf area with two or more mobile leaf routers partitions, it can be healed by routes through a standard area.
It will be appreciated that the number of routers and mobile leaf networks illustrated in
As illustrated, router 115/120 may include multiple input interfaces 405-1 through 405-R, a switch fabric 410, and multiple output interfaces 415-1-415-S. Each input interface 405 of router 115/120 may further include routing tables and forwarding tables (not shown). Through the routing tables, each input interface 405 may consolidate routing information learned from the routing protocols of the network. From this routing information, the routing protocol process may determine the active route to network destinations, and install these routes in the forwarding tables. Each input interface 405 may consult a respective forwarding table when determining a next destination for incoming packets. This consultation may involve a two-step process. For instance, certain input interface 405 may first consult a forwarding table constructed by OSPF to determine the desired exit point from network 105, and then a second forwarding table constructed by the private internal routing protocol of network 105 to determine the actual next destination.
In response to consulting a respective forwarding table, each input interface 405 may either set up switch fabric 410 to deliver a packet to its appropriate output interface 415, or attach information to the packet (e.g., output interface number) to allow switch fabric 410 to deliver the packet to the appropriate output interface 415. Each output interface 415 may queue packets received from switch fabric 410 and transmit the packets on to a “next hop.”
Each standard area router 120 may then construct an area-specific connectivity graph [act 510]. The area-specific connectivity graph may be constructed from the overall connectivity graph for sub-network 105 by eliminating routers that do not belong to the same area and compensating for that by adding additional links and/or adjusting costs of existing links. A router may determine which other routers belong to its area, based upon the IP address of the other router's interface onto sub-network 105, as each area may be assigned a distinct address range. Mobile leaf routers may be identified in the same way, and do not belong to any standard area.
Router 120 may construct all or part of a network graph 300 [act 515], based upon information contained in the connectivity graph acquired from the private routing algorithm of network 105 and information distributed by OSPF among OSPF routers. This network may represent an approximation to the connectivity graph for network 105, restructured so as to permit efficient representation via OSPF of the actual connectivity graph. The network graph 300 may include a set of links that the router may advertise in its own router links advertisements. The set of links chosen may define the network graph 300 that further defines a virtual model of network 105 that may be employed for routing computations. This model may include a set of virtual multi-access networks, each headed by a “designated router”, and point-to-point links connecting these virtual multi-access networks. Designated routers may be elected, from standard area routers within a standard area, by a distributed algorithm based in part upon the information contained in the connectivity graph.
A determination may be made whether one or more specified events have occurred [act 520]. The specified events may include, for example, changes to the connectivity graph that may occur when simulated HELLO messages are monitored. If one or more specified events have occurred, the exemplary process may return to act 505 to re-fresh the advertised network graph. For example, if changes to the connectivity graph are noted, then router 120 may re-initiate acts 505-515. If one or more of the specified events have not occurred, then a determination may be whether it is time for a periodic re-fresh [act 525]. For example, acts 505-515 may be re-initiated on a periodic basis (i.e., a periodic “refresh”). If it is not time for a periodic re-fresh, the exemplary process may return to act 520. If it is time for a periodic re-fresh, then the exemplary process may return to act 505.
The exemplary process may begin with the receipt of simulated HELLO messages [act 605]. Simulated HELLO messages may be generated by a private routing protocol internal to network and may include, for example, data specifying the type of node represented by the simulated HELLO, the lower layer address of the node's interface onto sub-network 105, and a cost of the remote node from router 120. A private routing protocol may generate a simulated HELLO message representing each router 120 in sub-network 105 every HELLOINTERVAL seconds, where HELLOINTERVAL is a parameter that specifies an exact periodic interval for sending the HELLO messages. HELLOINTERVAL need not be the same for every router so represented and may change dynamically. Alternatively, the private routing protocol may generate a simulated HELLO message representing a router 120 in sub-network 105 in response to some event, such as receipt of a routing update through the private routing protocol.
A lower layer address contained in each received simulated HELLO message may be translated into a corresponding Internet Protocol (IP) address [act 610]. This translation may be performed by a mechanism, such as, for example, Ethernet ARP. OSPF Router IDs may then be determined [act 615]. The OSPF Router ID associated with each router 120 in sub-network 105 may be determined from OSPF link-state advertisement packets, database description packets, link-state request packets, or other OSPF protocol packets received at a respective router 120. Inactive, area-external nodes, and mobile leaf routers may be eliminated from the connectivity graph [act 620]. Routers identified by a flag in their simulated HELLO messages as being not active may be eliminated from the connectivity graph. Additionally, routers belonging to a different area, and mobile leaf routers, may be eliminated from the connectivity graph (i.e., a network graph that includes vertexes at each router and edges between each vertex). Routers may be eliminated from the connectivity graph by first considering a set of all the vertices adjacent to the vertex to be eliminated. The vertex to be eliminated and all edges leading to it may be deleted from the graph. Then, new edges may be inserted connecting all vertices to which the deleted vertex had previously been adjacent, and assigned costs equal to the sum of the costs along the two edges that it replaces. This process may be repeated until all such vertices have been eliminated.
The exemplary process may begin with the identification of which routers belong to router 120's local area(s) by their IF addresses [act 705]. Each area may correspond to a distinct address range, which may be defined by a static configuration table. A standard area router may look up the IP address of another router's interface on sub-network 105 to determine the area to which it is assigned. Likewise, all mobile leaf routers may be assigned to a distinct address range. A given router may also belong to two or more areas. In such a case, it may have two or more IP addresses assigned to its interface onto sub-network 105, one in each area. Routers not belonging to the local area(s) may be eliminated from the connectivity graph to construct an area-specific connectivity graph [act 710]. Routers may be eliminated from the connectivity graph by first considering a set of all the vertices adjacent to the vertex to be eliminated (i.e., the vertex corresponding to the router to be eliminated). The vertex to be eliminated and all edges leading to it may be deleted from the graph. Then, new edges may be inserted connecting all vertices to which the deleted vertex had previously been adjacent, and assigned costs equal to the sum of the costs along the two edges that it replaces. This process may be repeated until all such vertices have been eliminated.
The virtual model constructed by the exemplary process of
The exemplary process may begin with a determination whether router 120 is eligible to become a designated router (DR) [act 805]. A designated router may serve to define a multi-access network advertised as part of the virtual model. There may be one or more designated routers for a single sub-network 105. The designated router used to represent a multi-access network in the virtual model need not be the same as any designated router that may play a privileged role in the flooding of OSPF link-state advertisements. Only standard area routers may be eligible to become a DR in sub-network 105 and mobile leaf routers may not head a multi-access network as its designated router.
Routers may be assigned a priority for election as a designated router. For example, two special priority values may be reserved: never (=0) and always (=255). A router assigned a priority of never may never be eligible for election as a designated router. A router assigned a priority of always may always elect itself as designated router. Priority values between never and always indicate that the router may be chosen as designated router, with the priority indicated. This priority information may be flooded between routers in sub-network 105 such that every router knows the designated router election priority of all other routers in its vicinity. If router 120 is not eligible to become a designated router, then the exemplary process may continue at act 1005 below. If router 120 is eligible to become a designated router, then router 120 may determine if any other DRs are located within a distance of DR-SPACING-MAX of router 120 and have a higher priority [act 810]. DR-SPACING-MAX may include a value indicating a maximum distance DRs should be apart. For example, DR-SPACING-MAX may equal 3 hops in some implementations. If other DRs are located within a distance of DR-SPACING-MAX of router 120 and have a higher priority, the exemplary process may continue at act 1005 below. If no other DRs are located within a distance of DR-SPACING-MAX of router 120, or don't have a higher priority, then a determination may be made whether conditions in acts 805 and 810 have persisted for a random time period [act 815]. If not, the exemplary process may continue at act 1005 below. If so, then router 120 may be elected as a designated router [act 820].
Router 120 may then determine whether another DR, with higher priority, is located within a distance of DR-SPACING-MIN of router 120 [act 905]. DR-SPACING-MIN may include a value indicating a minimum distance DRs should be apart. For example, DR-SPACING-MIN may equal 2 hops in some implementations. As long as the process of flooding OSPF route advertisements through network 105 does not itself depend upon the choice of designated routers, router 120 can determine what other routers in its vicinity in sub-network 105 have declared themselves to be designated routers, by monitoring the OSPF Network Links Advertisements emitted by such routers and flooded throughout network 100 (including sub-network 105). If the flooding process does not meet this criterion, then designated routers may advertise themselves by means of beacons broadcast, or multicast, to its neighbors through mechanisms provided by the internal routing protocol private to sub-network 105, and router 120 can determine what routers in its vicinity have declared themselves to be designated routers, by monitoring these beacons. If another DR, with higher priority, is not located within a distance of DR-SPACING-MIN of router 120, router 120 may determine whether another DR is located within a distance of DR-SPACING-MIN with a same priority and a higher network address [act 910]. If not, the exemplary process may return to act 905. If router 120 determines that either another DR is located within a distance of DR-SPACING-MIN of router 120 and has a higher priority, or another DR is located within a distance of DR-SPACING-MIN of router 120 with a same priority and a higher address, then router 120 may determine whether resigning as a designated router will force another router to elect itself as a designated router [act 915]. If not, router 120 may resign as a designated router [act 920] and the exemplary process may continue at act 805. If router 120 determines the resigning as a designated router will force another router to elect itself as a designated router, then router 120 may not resign as a designated router and the exemplary process may return to act 905.
If any of the three conditions of acts 805,810 or 815 above were not met, then router 120 may affiliate with a closest designated router [act 1005]. Router 120 may determine the closest designated router from information contained in the connectivity graph constructed by simulated HELLOs from the private, internal routing protocol of network 105. This distance information may be modified, for example, by other configured information so as to establish a preference for affiliation with particular routers. Router 120 may affiliate with a designated router by listing it in its OSPF router links advertisement as a network link. The designated router may reciprocate by listing the affiliated router in its corresponding OSPF network links advertisement.
While it is affiliated with a designated router, Router 120 may intermittently check to see if it should reaffiliate with a different designated router, or promote itself to the status of designated router. It may do so either periodically, or in response to some event, such as a change in the topology of network 105 as reported via simulated HELLO messages and represented by a change in the connectivity graph. To do so, router 120 may determine whether it is eligible to become a designated router [act 1010]. If so, router 120 may determine whether any other DRs are within a distance of DR-SPACING-MAX of router 120 with a higher priority [act 1015]. If not, then router 120 may determine whether the conditions of acts 1010 and 1015 have persisted for a random time period [act 1020]. If the conditions have persisted for the random time period, then router 120 should promote itself to designated router and the exemplary process may continue at act 820. If not, the exemplary process may continue at act 1025.
Returning to act 1015, if router 120 determines that other DRs are within a distance of DR-SPACING-MAX of router 120 with a higher priority, router 120 may check to see if it should reaffiliate with one of these other DRs. To prevent bouncing back and forth among different DRs, router 120 should not reaffiliate simply because it is now closer to some other DR, but rather should apply a hysteresis check. To do so, router 120 may monitor distances between itself and every other designated router in its vicinity, as reflected by the connectivity graph [act 1025], over time. For example, let ci be router 120's cost to the ith designated router, and c be the cost to router 120's current designated router (both c and ci may change with time). The time-integral of the advantage (Cadvantage) of switching to a different designated router may be computed by the following relation:
Cadvantage=∫maxi((c(t)−ci(t)))dt Eqn. (1)
Router 120 may then re-affiliate with another DR based on the monitored distances [act 1030]. For example, if Cadvantage exceeds a configurable threshold value, then router 120 may re-affiliate with the corresponding designated router, which is now closest. These costs ci may be adjusted, for example, by configurable values, so as to create a preference for router 120 to affiliate with particular designated routers.
The exemplary process may begin with the acquisition of a connectivity graph [act 1105]. The connectivity graph may be constructed from simulated HELLO messages that are received from an internal routing protocol private to network 105. These simulated HELLO messages may inform the mobile leaf router 115 as to the set of other routers in network 105, their distance from router 115, and their set of one-hop neighbors and distance to each. From these simulated HELLO messages, router 115 can determine its own set of one-hop neighbors, and whether or not it has bi-directional connectivity to each such neighbor. From the simulated HELLO messages, router 115 may construct a graph representing the connectivity with at least a set of other routers in network 105.
The router 115 may then affiliate with a standard area router (i.e., the “parent” router)[act 1110]. Initially, mobile leaf router 115 may affiliate with a closest standard area router. As mobile leaf router 115 moves around, it may re-affiliate as needed to present a reasonable model of the network. Mobile leaf router 115 may affiliate with any standard area router, regardless of whether or not it is a designated router. The parent router may serve as a border router between the standard area and the area whose sole member in sub-network 105 is the mobile leaf router 115. Mobile leaf router 115 may then receive the network model (including the parent router's virtual model of network 105) advertised by the parent router [act 1115]. The parent router may advertise this model in a simplified form, consisting, for example, of just a single default route with itself as “next hop.” In an alternative implementation, mobile leaf router 115 may generate this default route itself. Conversely, mobile leaf router 115 may incorporate the mobile leaf router 115 and the mobile leaf networks behind it into its model of the network by representing them, for example, by means of one or more OSPF AS-external or Area Summary route advertisements.
A determination may be made whether one or more specified events have occurred [act 1120]. Router 120 may, for example, monitor simulated HELLO messages looking for changes to the connectivity graph. If one or more specified events have occurred, then the exemplary process may return to act 1105 to re-fresh the network graph 300. For example, if changes to the connectivity graph are noted, then mobile leaf router 115 may re-initiate acts 1105-1115. If one or more of the specified events have not occurred, then a determination may be whether it is time for a periodic re-fresh [act 1125]. For example, acts 1105-1115 may be re-initiated on a periodic basis (i.e., a periodic “re-fresh”). If it is not time for the periodic re-fresh, then the exemplary process may return to act 1120. If it is time for a periodic re-fresh, then the exemplary process may return to act 1105.
The exemplary process may begin with the receipt of simulated HELLO messages [act 1205]. Simulated HELLO messages may be generated by a private routing protocol internal to sub-network 105 and may include, for example, data specifying the type of node represented by the simulated HELLO message, the lower layer address of the node's interface onto sub-network 105 and a cost of the remote node from router 115. A private routing protocol may generate a simulated HELLO message representing each router 120 in sub-network 105 every HELLOINTERVAL seconds, where HELLOINTERVAL is a parameter that specifies an exact periodic interval for sending the HELLO messages.
HELLOINTERVAL need not be the same for every router so represented and may change dynamically. Alternatively, the private routing protocol may generate a simulated HELLO message representing a router 120 in sub-network 105 in response to some event, such as receipt of a routing update through the private routing protocol.
A lower layer address contained in each received simulated HELLO message may be translated into a corresponding Internet Protocol (IP) address [act 1210]. This translation may be performed by a mechanism, such as, for example, Ethernet ARP. OSPF Router IDs may be determined [act 1215]. An OSPF Router ID, associated with each router 115/120 in sub-network 105, may be determined from OSPF link-state advertisement packets, database description packets, link-state request packets, or other OSPF protocol packets received from a respective router 115/120.
Inactive and other mobile leaf routers may be eliminated from the connectivity graph [act 1220]. Routers identified by a flag in their simulated HELLO messages as being not active may be eliminated from the connectivity graph. Additionally, other mobile leaf routers may be eliminated from the connectivity graph. These may be identified, for example, by their IP addresses. Routers may be eliminated from the connectivity graph by first considering a set of all the vertices adjacent to the vertex to be eliminated. The vertex to be eliminated and all edges leading to it may be deleted from the graph. Then, new edges may be inserted connecting all vertices to which the deleted vertex had previously been adjacent, and assigned costs equal to the sum of the costs along the two edges that it replaces. This process may be repeated until all such vertices have been eliminated.
The exemplary process may begin with mobile leaf router 115 affiliating with a closest standard area router 120 [act 1305]. Mobile leaf router 115 may determine the standard area router 120 with which to affiliate from information contained in the connectivity graph constructed from the simulated HELLO messages received from the private, internal routing protocol of sub-network 105. The distances determined from the connectivity graph may be modified, for example, by configured values so as to establish a preference for affiliation with certain routers. Mobile leaf router 115 may then continue to monitor distances between itself and every standard area router 120 in mobile leaf router's vicinity, as reflected by the connectivity graph, to determine whether or not it should reaffiliate with a different parent router [act 1310]. To avoid bouncing between one parent router and another, it should not reaffiliate just because some other potential parent router has become closer, but instead apply a hysteresis check. For example, let ci be router 115's cost to the ith neighboring router, and c be the cost to router 115's current affiliated router (both c and ci may change with time). The time-integral of the advantage (Cadvantage) of affiliating with a different router may be computed by Eqn. (1) above. Mobile leaf router 115 may then re-affiliate with another standard area router based on the monitored distances [act 1315]. For example, if Cadvantage exceeds a configurable threshold value, then mobile leaf router 115 may re-affiliate with a corresponding router, which is now closest.
The exemplary process may begin with the receipt of an advertisement from a parent router announcing a default route to the remainder of sub-network 105 with the parent router as a next hop [act 1405]. Mobile leaf router 115 may flood the received advertisement into the mobile leaf area [act 1410]. Mobile leaf router 115 may also send an advertisement into the mobile leaf area describing the mobile leaf router's link to the parent router [act 1415]. Mobile leaf router 115 may then construct a virtual model network graph as including the parent router, a link from the parent to the mobile leaf router, a default route from the parent to the remainder of the network, and the network behind the mobile leaf router [act 1420]. The constructed virtual model network graph may be stored in memory at mobile leaf router 115. As an alternative, since the identity of the parent router is already known to mobile leaf router 115, mobile leaf router 115 may construct this virtual model itself without need for an explicit advertisement of a default route by the parent router.
In addition, the parent router may incorporate mobile leaf router 115 and the mobile leaf network(s) behind it into its own virtual model network graph. To do so, it represents mobile leaf router 115 and the mobile leaf networks(s) behind it by means of OSPF AS-external or Area Summary advertisements.
The exemplary process may begin with router 120 computing the shortest path(s) to every known network and node of network 100 in accordance with existing OSPF mechanisms [act 1505]. This computation may be performed, for example, through use of the well-known Dijkstra algorithm, or by any other equivalent algorithm. However, when computing the shortest path(s) in act 1505, the rule employed for choosing the “next hop” may be modified, so that actual routing within sub-network 105 will be performed by its private routing protocol, and not by OSPF, in accordance with the advertised virtual model (e.g., network graph 300). As each shortest path is determined, the node at which that path first exits sub-network 105 may be determined and selected as the “next hop” in place of the node that would normally have been chosen for this purpose. The node at which the shortest path first exits sub-network 105 can be found, for example, by modifying the Dijkstra algorithm, or equivalent, to retain full path information, and then searching down that path until the first node not belonging to sub-network 105 is found. The node immediately preceeding that node may be the desired exit point. In an alternative implementation, the node at which the shortest path first exits sub-network 105 can be determined by modifying the Dijkstra algorithm, or its equivalent, to compute this information directly.
The OSPF routing algorithm implemented at router 120 may install the computed shortest path(s) into an IP forwarding table [act 1510]. A packet may then be routed to its destination in accordance with the information contained in the IP forwarding table [act 1515]. If the IP “next hop” for this packet is a router on sub-network 105, then forwarding the packet may require a second lookup in a second forwarding table maintained by the private routing protocol internal to sub-network 105 to determine the true “next hop.” In this second lookup, the IP “next hop” (after conversion into the appropriate address format for the private routing protocol internal to sub-network 105) becomes the destination address for the private forwarding process internal to sub-network 105. If sub-network 105 is split across multiple OSPF areas, including mobile leaf areas, then the shortest path(s) computation (described with respect to act 1505 above) for finding the exit point from sub-network 105 may terminate before the true exit point from sub-network 105 is found, due to lack of full routing information beyond that point. In that case, a packet to be forwarded would exit the private forwarding system internal to sub-network 105 at this intermediate point, have a new IP “next hop” determined from the IP forwarding table at this intermediate point, and then re-enter the private forwarding system internal to sub-network 105 for delivery to the true exit point. Although a packet would still be correctly routed to its destination, this could result in undesirably heavy traffic loads at such intermediate points, such as area border routers (including the parent routers of mobile leaf routers). This case, however, can be detected at the area border router [act 1520] because it will forward back onto sub-network 105 a packet just received from the same network. The area border router may then send an Internet Control Message Protocol (ICMP) redirect, or equivalent, message [act 1525] to the router at which the packet entered network 105, instructing it as to the proper exit point to which future packets with the same destination should be forwarded. A router receiving such a message may incorporate it into its routing computation (see act 1505 above) to permit it to determine the true exit point from sub-network 105 for future packets with the same destination.
Systems and methods consistent with the present invention modify OSPF to permit seamless integration of a multi-hop, multi-access packet radio network that includes its own private, internal routing protocol, into an overall OSPF routing environment. These modifications maintain strict compatibility with standard OSPF on all routers outside the multi-hop, multi-access radio network, while optimizing the representation of the packet radio network so as to minimize overhead from the OSPF routing protocol and facilitate scaling to networks containing large numbers of OSPF routers. In this modified version of OSPF, routers within the multi-hop, multi-access packet radio network generate a virtual OSPF network model in which a multi-hop, multi-access radio network may be represented as a set of multi-access links, with each being identified by its own designated router. In the virtual model, standard area routers may affiliate with the designated router to which they are closest in the absence of mobility. Adjacent multi-access links may be connected by connecting routers that belong to both links and/or by point-to-point links between routers in each multi-access link.
The virtual model, consistent with the principles of the invention, may be advertised to OSPF routers outside the packet radio network using the standard OSPF protocol, and may be disseminated within the packet radio network by either the standard or a modified version of the OSPF protocol. Routers outside the multi-hop, multi-access packet radio network route packets in accordance with the standard OSPF procedures, and are not even aware that they are employing a model of the network that is virtual rather than actual. Within the packet radio network, the routing procedure may be modified so that the packet radio network's private, internal routing protocol, rather than OSPF, is used for routing within the packet radio network itself.
The foregoing description of preferred embodiments of the present invention provides illustration and description, but is not intended to be exhaustive or to limit the invention to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of the invention. For example, while this invention is described herein in terms of its applicability to a packet radio network, it will be appreciated, that the actual physical means of communication employed by that network may vary. It may include wired, radio, sonar, optical, microwave, and other physical means of communication. An element for determining the applicability of this invention is the existence (or createability) of a private, internal routing protocol for that network, whose actual connectivity can be modeled by a virtual model as described herein. Likewise, while the invention is described in terms of integrating a packet radio network with its own internal routing system into an overall OSPF routing environment and in terms of constructing a virtual model for use by OSPF, the actual routing protocol into which the packet radio network is to be integrated may vary. It may include variants and future derivatives of OSPF, other link-state routing protocols, hybrids, and variants thereof, which may form components of the IPv4 protocol suite, the IPv6 protocol suite, the OSI protocol suite, other networking suites, or may stand independently. The element determining the applicability of this invention to a particular protocol is the ability of that protocol to represent the packet radio network by a virtual model as described herein.
While series of acts have been described with regard to
As one skilled in the art will appreciate, the exemplary processes of
The scope of the invention is defined by the following claims and their equivalents.
The instant application claims the benefit of provisional application No. 60/438,459, filed Jan. 7, 2003; provisional application No. 60/475,177, filed Jun. 2, 2003; and provisional application No. 60/493,660, filed Aug. 8, 2003; the disclosures of which are hereby incorporated herein by reference in their respective entireties.
The U.S. Government has a paid-up license in this invention and the right in limited circumstances to require the patent owner to license others on reasonable terms as provided for by the terms of Contract No. DAAB07-02-C-C403 awarded by the United States Army.
Number | Name | Date | Kind |
---|---|---|---|
4718002 | Carr | Jan 1988 | A |
4827411 | Arrowood et al. | May 1989 | A |
5079767 | Perlman | Jan 1992 | A |
5093824 | Coan et al. | Mar 1992 | A |
5117422 | Hauptschein et al. | May 1992 | A |
5175843 | Casavant et al. | Dec 1992 | A |
5243592 | Perlman et al. | Sep 1993 | A |
5412654 | Perkins | May 1995 | A |
5430729 | Rahnema | Jul 1995 | A |
5541912 | Choudhury et al. | Jul 1996 | A |
5649119 | Kondoh et al. | Jul 1997 | A |
5742820 | Perlman et al. | Apr 1998 | A |
5764895 | Chung | Jun 1998 | A |
5828835 | Isfeld et al. | Oct 1998 | A |
5850592 | Ramanathan | Dec 1998 | A |
5878056 | Black et al. | Mar 1999 | A |
5878095 | Kainulainen | Mar 1999 | A |
5881246 | Crawley et al. | Mar 1999 | A |
5884040 | Chung | Mar 1999 | A |
5903735 | Kidder et al. | May 1999 | A |
5913921 | Tosey et al. | Jun 1999 | A |
5959989 | Gleeson et al. | Sep 1999 | A |
5960047 | Proctor, Jr. et al. | Sep 1999 | A |
5974327 | Agrawal et al. | Oct 1999 | A |
6000011 | Freerksen et al. | Dec 1999 | A |
6028857 | Poor | Feb 2000 | A |
6032190 | Bremer et al. | Feb 2000 | A |
6046978 | Melnik | Apr 2000 | A |
6067301 | Aatresh | May 2000 | A |
6069895 | Ayandeh | May 2000 | A |
6088622 | Dollin et al. | Jul 2000 | A |
6088734 | Marin et al. | Jul 2000 | A |
6092096 | Lewis | Jul 2000 | A |
6094435 | Hoffman et al. | Jul 2000 | A |
6122753 | Masuo et al. | Sep 2000 | A |
6139199 | Rodriguez | Oct 2000 | A |
6151308 | Ibanez-Meier et al. | Nov 2000 | A |
6173324 | D'Souza | Jan 2001 | B1 |
6215765 | McAllister et al. | Apr 2001 | B1 |
6216167 | Momirov | Apr 2001 | B1 |
6252856 | Zhang | Jun 2001 | B1 |
6262976 | McNamara | Jul 2001 | B1 |
6272567 | Pal et al. | Aug 2001 | B1 |
6275492 | Zhang | Aug 2001 | B1 |
6304548 | Shaffer et al. | Oct 2001 | B1 |
6304556 | Haas | Oct 2001 | B1 |
6310883 | Mann et al. | Oct 2001 | B1 |
6330459 | Crichton et al. | Dec 2001 | B1 |
6349091 | Li | Feb 2002 | B1 |
6362821 | Gibson et al. | Mar 2002 | B1 |
6385174 | Li | May 2002 | B1 |
6385673 | DeMoney | May 2002 | B1 |
6385714 | Koumura et al. | May 2002 | B1 |
6396814 | Iwamura et al. | May 2002 | B1 |
6418299 | Ramanathan | Jul 2002 | B1 |
6456599 | Elliott | Sep 2002 | B1 |
6470329 | Livschitz | Oct 2002 | B1 |
6473421 | Tappan | Oct 2002 | B1 |
6473434 | Araya et al. | Oct 2002 | B1 |
6496510 | Tsukakoshi et al. | Dec 2002 | B1 |
6542469 | Kelley et al. | Apr 2003 | B1 |
6570867 | Robinson et al. | May 2003 | B1 |
6574227 | Rosenberg et al. | Jun 2003 | B1 |
6594268 | Aukia et al. | Jul 2003 | B1 |
6611522 | Zheng et al. | Aug 2003 | B1 |
6628929 | Nomura et al. | Sep 2003 | B1 |
6631136 | Chowdhury et al. | Oct 2003 | B1 |
6633544 | Rexford et al. | Oct 2003 | B1 |
6671819 | Passman et al. | Dec 2003 | B1 |
6683885 | Sugai et al. | Jan 2004 | B1 |
6687781 | Wynne et al. | Feb 2004 | B2 |
6714563 | Kushi | Mar 2004 | B1 |
6721273 | Lyon | Apr 2004 | B1 |
6745224 | D'Souza et al. | Jun 2004 | B1 |
6769043 | Fedorkow et al. | Jul 2004 | B1 |
6804236 | Mahajan et al. | Oct 2004 | B1 |
6807158 | Krishnamurthy et al. | Oct 2004 | B2 |
6807172 | Levenson et al. | Oct 2004 | B1 |
6829222 | Amis et al. | Dec 2004 | B2 |
6870846 | Cain | Mar 2005 | B2 |
6954449 | Cain et al. | Oct 2005 | B2 |
RE38902 | Srisuresh et al. | Nov 2005 | E |
6977895 | Shi et al. | Dec 2005 | B1 |
6977937 | Weinstein et al. | Dec 2005 | B1 |
6980515 | Schunk et al. | Dec 2005 | B1 |
6980537 | Liu | Dec 2005 | B1 |
6990350 | Davis et al. | Jan 2006 | B2 |
7020501 | Elliott et al. | Mar 2006 | B1 |
7020701 | Gelvin et al. | Mar 2006 | B1 |
7039720 | Alfieri et al. | May 2006 | B2 |
7042834 | Savage | May 2006 | B1 |
7042837 | Cassiday et al. | May 2006 | B1 |
7046628 | Luhmann et al. | May 2006 | B2 |
7065059 | Zinin | Jun 2006 | B1 |
7068971 | Abutaleb et al. | Jun 2006 | B2 |
7072952 | Takehiro et al. | Jul 2006 | B2 |
7103344 | Menard | Sep 2006 | B2 |
7106703 | Belcea | Sep 2006 | B1 |
7120120 | Guerin et al. | Oct 2006 | B2 |
7177295 | Sholander et al. | Feb 2007 | B1 |
7184421 | Liu et al. | Feb 2007 | B1 |
7200120 | Greenberg et al. | Apr 2007 | B1 |
7215926 | Corbett et al. | May 2007 | B2 |
7254111 | Choe et al. | Aug 2007 | B2 |
7266386 | Kim et al. | Sep 2007 | B2 |
7281057 | Cain | Oct 2007 | B2 |
7289456 | Gupta et al. | Oct 2007 | B2 |
7353259 | Bakke et al. | Apr 2008 | B1 |
7369512 | Shurbanov et al. | May 2008 | B1 |
20010007560 | Masuda et al. | Jul 2001 | A1 |
20010034793 | Madruga et al. | Oct 2001 | A1 |
20010040895 | Templin | Nov 2001 | A1 |
20010045914 | Bunker | Nov 2001 | A1 |
20020016869 | Comeau et al. | Feb 2002 | A1 |
20020029214 | Yianilos et al. | Mar 2002 | A1 |
20020057660 | Park et al. | May 2002 | A1 |
20020067693 | Kodialam et al. | Jun 2002 | A1 |
20020071392 | Grover et al. | Jun 2002 | A1 |
20020075813 | Baldonado et al. | Jun 2002 | A1 |
20020080755 | Tasman et al. | Jun 2002 | A1 |
20020103893 | Frelechoux et al. | Aug 2002 | A1 |
20020108107 | Darnell et al. | Aug 2002 | A1 |
20020131409 | Frank et al. | Sep 2002 | A1 |
20020143755 | Wynblatt et al. | Oct 2002 | A1 |
20020176390 | Sparr et al. | Nov 2002 | A1 |
20020186694 | Mahajan et al. | Dec 2002 | A1 |
20020191545 | Pieda et al. | Dec 2002 | A1 |
20030012168 | Elson et al. | Jan 2003 | A1 |
20030016624 | Bare | Jan 2003 | A1 |
20030043742 | De Maria et al. | Mar 2003 | A1 |
20030048771 | Shipman | Mar 2003 | A1 |
20030058852 | Luhmann et al. | Mar 2003 | A1 |
20030063613 | Carpini et al. | Apr 2003 | A1 |
20030093576 | Dettinger et al. | May 2003 | A1 |
20030096577 | Heinonen et al. | May 2003 | A1 |
20030124976 | Tamaki et al. | Jul 2003 | A1 |
20030126284 | Houston et al. | Jul 2003 | A1 |
20030152182 | Pai et al. | Aug 2003 | A1 |
20030153338 | Herz et al. | Aug 2003 | A1 |
20030174654 | Tateson et al. | Sep 2003 | A1 |
20030174719 | Sampath et al. | Sep 2003 | A1 |
20030179751 | Omae et al. | Sep 2003 | A1 |
20030202476 | Billhartz et al. | Oct 2003 | A1 |
20040001720 | Krill et al. | Jan 2004 | A1 |
20040003111 | Maeda et al. | Jan 2004 | A1 |
20040027284 | Leeper et al. | Feb 2004 | A1 |
20040029553 | Cain | Feb 2004 | A1 |
20040032856 | Sandstrom | Feb 2004 | A1 |
20040106408 | Beasley et al. | Jun 2004 | A1 |
20040131079 | Hegde et al. | Jul 2004 | A1 |
20040202164 | Hooper et al. | Oct 2004 | A1 |
20040213167 | Garcia-Luna-Aceves et al. | Oct 2004 | A1 |
20040243702 | Vainio et al. | Dec 2004 | A1 |
20050013613 | Stevenson et al. | Jan 2005 | A1 |
20050030949 | Shirakawa et al. | Feb 2005 | A1 |
20050036442 | Saleh et al. | Feb 2005 | A1 |
20050050221 | Tasman et al. | Mar 2005 | A1 |
20050117914 | Chuah et al. | Jun 2005 | A1 |
20050213586 | Cyganski et al. | Sep 2005 | A1 |
20070106852 | Lam et al. | May 2007 | A1 |
Number | Date | Country |
---|---|---|
0447725 | Sep 1991 | EP |
WO 0137483 | May 2001 | WO |
Number | Date | Country | |
---|---|---|---|
60438459 | Jan 2003 | US | |
60475177 | Jun 2003 | US | |
60493660 | Aug 2003 | US |