Devices known as routers are responsible for selecting the best path or paths to route information from one location or node within the Internet to another. For example, when information needs to be sent from a node within one network to a node within a different network, a router using a Border Gateway Protocol (“BGP”) (hereafter “BGP router”) is assigned the task of determining the best path or paths.
Because new nodes are constantly being added, deleted, etc. from networks making up the Internet, at any given point in time the best path from one node to another may change very rapidly. Realizing this, existing techniques provide BGP routers (sometimes called BGP speaker nodes) with the capability of comparing a pre-existing, best available path with a next available path formed when a change occurs to a given network. If the next available path is determined to be better than the pre-existing, best available path, then the next available path will be given the status of “best available path”. Thereafter, this new path will be used to route information in place of the pre-existing path (i.e., old, best available path).
When a new path is selected a BGP router is responsible for generating a forwarding table(s) associated with this new path. Once generated, the forwarding table is stored within the BGP router. When a packet arrives at the BGP router it is forwarded on using the stored forwarding table.
A BGP router is constantly comparing its pre-existing, stored best available path to next available paths. If a next available path is even slightly better than a pre-existing, best available path, then existing techniques require a BGP router to replace the pre-existing best available path with the new path. Thus, a given BGP router may be constantly updating its forwarding tables. Complicating matters further, each time a new, best available path is determined, it must be transmitted (referred to as “advertised”) to neighboring nodes (e.g., neighboring BGP routers). Upon receiving a new, best available path, the neighboring nodes will also update their forwarding tables. Thereafter, these neighboring nodes will advertise to their neighboring nodes and so on. Thus, any change by one BGP router has a cascading effect upon other BGP routers.
Inherent in this comparison, selection, advertisement and updating process is a time requirement. That is, relatively speaking, the comparison, selection, advertising and updating process takes up a significant amount of time. During this time it may not be possible to forward a received packet on to a next node until the process has been completed. For example, even though the comparison, selection and updating and advertising process has been completed at some nodes along a path, this process may not be completed at other nodes. As a result, any attempt to forward a packet along the path may be unsuccessful (i.e., the packet will not reach its destination) until each of the nodes along the path have completed their comparison, selection, updating and advertising process.
Other times a phenomena called “looping” occurs which results in a packet being sent back toward a preceding node instead of being forwarded on to a subsequent node.
Only when each node in the network has completed its comparison, selection and updating (and associated advertising) process can it be assured that a packet can successfully be transferred over any given path. When each node finishes this process, a network is said to have “converged.” This may take, relatively speaking, a substantial amount of time. The faster a network converges, the faster a packet can be transferred.
It is, therefore, desirable to provide for methods and devices which reduce the amount of time it takes a network to converge.
We have recognized that the time it takes for a network to converge can be significantly reduced by reducing delays associated with computing routing paths. In one embodiment of the present invention, a detected next available path will only be selected as a best available path if it is substantially better than the pre-existing, best available path.
Because some detected, next available paths will not be substantially better than pre-existing, best available paths, some of the detected paths will not be selected. When a path is not selected, there is no need for a BGP router to update its forwarding table. There is also no need to advertise the unselected path to its neighbors. It is believed by the present inventors that this may greatly reduce the number of times a BGP router needs to update its forwarding tables and reduce cascading, thereby reducing the time it takes a network to converge.
Referring now to
Suppose further that in the next instant of time a next available path i″ is detected. In one embodiment of the present invention, BGP router B is operable to compare the next available path i″ to the pre-existing, best available path i. If this comparison results in a determination that the next available path i″ is substantially better (e.g., cost-wise, length-wise, time-wise or otherwise comparatively better) than the pre-existing, best available path i, then the BGP router B is further operable to select the next available path i″ as the new, best available path. However, if the results of the comparison determine that the next available path i″ is not substantially better than the pre-existing, best available path i, then the BGP router B is operable to maintain the pre-existing, best available path i as the best available path.
Such comparisons may take the form of comparing the length or cost of a next available path with the length or cost of a pre-existing best available path and only selecting the next available path if its length/cost is substantially shorter/less than that of the pre-existing, best available path. Alternatively, one or more known metrics or weights may be assigned to the pre-existing, best available path and the detected next available path. Upon comparing the metrics or weights, the next available path will be selected only if the metric or weight is substantially better than the metric or weight associated with the pre-existing, best available path. In yet a further embodiment of the invention, the metric or weight associated with the next available path maybe compared to a threshold or the like. Only if the metric or weight equals or exceeds the threshold (which acts as an indicator that the next available path is substantially better than the pre-existing best available path) is the next available path selected. It should be understood that a metric or weight may be associated with a length, cost, transmission channel quality, error rate, etc . . . . It should be understood that these are just some of the metrics and weights which may be used to determine whether the detected next available path is substantially better than a pre-existing, best available path.
For example, the next available path may be associated with a higher cost because it traverses a network operated by an entity which is not affiliated with the entity which operates a given BGP router. In contrast, the cost associated with the pre-existing, best available path may be lower than the cost associated with the detected next available path because the pre-existing, best available path traverses a network that is operated by an affiliate of the BGP router.
By requiring that a next available path be substantially better than a pre-existing, best available path, the present invention allows BGP routers to generate new forwarding tables only when the next available path is substantially better than the pre-existing, best available path. Because many times the next available path will not be substantially better than the pre-existing, best available path, the present invention effectively reduces the number of times a given BGP router will have to generate new forwarding tables.
In addition, because it is only necessary for a BGP router to advertise or transmit new, best available paths to its neighbors, these advertisements or transmissions need only occur when the next available path is substantially better than the pre-existing, best available path. In the example above, though a next available path i″ has been detected, it may not be substantially better than path i. In a further embodiment of the present invention, BGP router B would not select the next available path i″ because it is not substantially better than the pre-existing best available path i. As a result, BGP router B would not need to update its forwarding table, nor would it need to advertise a new path to its neighboring nodes. As a result, neighboring routers A, C, E and F would not have to change their routing paths and associated forwarding tables either. Conversely, if BGP router B determines that i″ is substantially better than path i, BGP routers A, C, E and F may have to change their pre-existing best available path to next available path i″ (assuming they also know of no other path that is substantially better than i or ii) as well as their forwarding tables. Thereafter, they would also have to advertise this new path to their surrounding BGP routers (not shown in
To avoid such a cascading effect when a next available path is only slightly better than a pre-existing, best available path, it will not be selected or used to route packets. Delays associated with changing forwarding tables and cascading effects are reduced, thereby reducing the time it takes a network to converge. Fast converging networks make it possible to forward received packets faster than previously thought possible.
Backtracking somewhat, it was mentioned above that metrics or weights maybe assigned to pre-existing and next available paths. It should be understood that these metrics and weights may be assigned, modified or configured (collectively “configured”) by a user, network operator or the like (collectively “user”) at a BGP router (i.e., they are variable, not fixed).
In yet additional embodiments of the present invention, the problems associated with so-called “looping” are prevented by the present invention. When BGP router B initially selects a next available path as a new, best available path, it determines whether the next available path will result in a packet being transmitted back (i.e., looped back) to BGP router B or any other router along the next available path. If it determines that this may occur, then this path is rejected and not selected as a new, best available path.
In addition, the present invention also allows for another comparison to ensure that the next available path i″, for example, is in fact the best path of all known paths. For example, though i″ may be substantially better than i, at the same time the next available path i″ becomes available, changes may occur to another path, for example, path k. To ensure that the next available path, i″, is not only substantially better than the pre-existing, best available path i, but is also the best path of all known paths (where it is assumed that path k is previously known to BGP router B), the next available path i″ will only be selected provided it is indeed the best path among all known paths, in this case the best path among paths i i″ and k. This proviso holds true for each BGP router shown in
In a further embodiment of the present invention, once BGP router B selects a new best available path (e.g., i″) and advertises this new path to its surrounding neighbors, it should be understood that the pre-existing best available path i can no longer be used by BGP router A, etc. . . . Said another way, BGP router A may be further operable to determine whether the pre-existing, best available path i traverses a neighboring node (e.g., BGP router B) which has advertised a next available path (e.g., i″). If this is the case, then the BGP router A is further operable to select the next available path i″ (provided, of course, this next available path, i″, has been determined to be the best path along all known paths, i and k.)
In yet a further embodiment of the present invention, each BGP router of the present invention may assign a different metric or weight to each best available path. Because of this, when each BGP router carries out its own comparison process, each BGP router may generate a different comparison result.
The discussion above has set forth some of the examples of the present invention. The true scope of the present invention, however, is set forth in the claims which follow.
Number | Name | Date | Kind |
---|---|---|---|
5854899 | Callon et al. | Dec 1998 | A |
6016306 | Le Boudac et al. | Jan 2000 | A |
6671819 | Passman et al. | Dec 2003 | B1 |
6704795 | Fernando et al. | Mar 2004 | B1 |
7197040 | Bressoud et al. | Mar 2007 | B2 |
20030095504 | Ogier | May 2003 | A1 |
20050036486 | Sahinoglu et al. | Feb 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20060067294 A1 | Mar 2006 | US |