The subject matter described herein relates to providing voice over IP (VoIP) traffic engineering and path resilience. More particularly, the subject matter described herein relates to methods, systems, and computer program products for multi-path shortest-path-first (SPF) computations and distance-based interface selection for VoIP traffic.
IP routing protocols use SPF methods to compute and select the shortest path to a network destination. IP routing protocols that use SPF methods have conventionally implemented path cost calculations assuming that each network device is a single node. In these networks, all potential paths between the source and destination IP devices are identified through network topology information provided by network devices through link state advertisement (LSA) or similar status messages. Costs are assigned to each network segment by a network administrator to reflect relative geographic distance, equipment cost, or other network attributes as deemed appropriate by the administrator. Conventionally, assigned cost values are constrained to be zero or positive, and cost metrics have relative meaning only.
One SPF algorithm conventionally calculates an aggregate sum of the network segment costs for each of a set of predefined paths from a source IP device to a destination IP device, and the path with the lowest cost is selected by the source IP device for data transfers. Multiple paths having the same aggregate cost may be utilized by the source IP device in a load-sharing configuration where the total data traffic is distributed across all paths. The path lists generated by conventional SPF calculations do not permit an IP device to autonomously identify alternate paths to a destination IP device for the purposes of either distributing data traffic for load-balancing or for redirecting traffic under a segment or IP device failure in the data network. If an IP device experiences traffic load demands beyond the capacity of the preferred path identified by the SPF calculation, the excess traffic is discarded. Likewise, if a network node or segment in the lowest cost path fails, the IP device cannot autonomously redirect its data traffic. Until new path definitions are provided by other network nodes through link state advertisement messages, data traffic flows are interrupted and requests for establishment of new VoIP call connections are rejected due to blockage.
One published protocol commonly used in public data networks, called Open Shortest Path First (OSPF), utilizes the basic SPF algorithm and methods. OSPF is defined to support general purpose unidirectional data traffic, such as file or webpage retrieval from a remote server. However, the OSPF definitions do not include methods to pre-assign alternate paths, nor do they include methods for data traffic recovery under node or segment failures along the preferred path. Similarly, the OSPF definitions do not include methods to constrain data traffic assignment among a group of equal low-cost paths in a load-balancing application.
OSPF has been extended to support modified segment cost definitions to support real-time traffic. This modified algorithm, called Traffic Engineering OSPF (TE-OSPF), continues to utilize the fundamental SPF calculation method. Applications that require interactive or low-latency data transfers between two IP devices, such as VoIP or interactive video services, typically have predefined levels of service quality to meet. These service quality levels are conventionally defined in terms of data throughput rates, maximum path delay, and percent availability, and these levels are commonly defined such that the service cannot tolerate data flow interruptions. However, the TE-OSPF definitions, like the OSPF definitions, do not support definitions of pre-assigned alternate paths for rapid network failure recovery or provide mechanisms to constrain load balancing among multiple lowest-cost paths. Systems supporting low-latency or interactive data traffic are consequently limited in their ability to implement the functions often required to support the defined service quality levels.
Accordingly, in light of these difficulties associated with obtaining a ranked list of paths to a destination IP device across a data network based on path costs, there exists a need for improved methods, systems, and computer program products for multi-path SPF computations and distance-based interface selection for VoIP traffic.
Methods, systems, and computer program products for multipath Shortest-Path-First (SPF) computations and distance-based interface selection for VoIP traffic are disclosed. According to one method, a multi-path router instance associated with a plurality of network interfaces in a source IP device is provided. A cost is assigned to each of a plurality of internal segments between the multi-path router instance and the network interfaces associated with the multi-path router instance. An aggregate cost is calculated for each of a plurality of traffic paths originating at the multi-path router instance in the source IP device and extending through each of the network interfaces associated with the multi-path router instance to a destination IP device in the network. A list of IP paths is generated, and the paths in the list are ranked based on the calculated cost. Traffic is sent from the source IP device over at least one of the paths in the list. The path costs and rankings are updated in response to segment cost changes.
As used herein, the term “IP device” refers to any system that has at least one interface to a data network, supports conventional data network routing protocols, and accepts data traffic in conventional formats. An IP device may be a conventional router or it may be a conventional endpoint, such as a media gateway or a server. The term “source IP device” refers to an IP device serving as the origin of data traffic to be carried across the data network. The term “destination IP device” refers to an IP device serving as the destination or termination point in the data network for the data traffic. The term “node” refers to any system in the data network that is capable of routing data traffic and supporting SPF cost assignments and calculations. The term “segment” refers to a physical connection between adjacent network nodes. The terms “data path” or “path” refers to a defined set of segments and nodes that jointly provide a connection across a data network between an IP device sourcing data traffic and an IP device sinking or terminating data traffic.
The subject matter described herein for multi-path SPF computations and distance-based interface selection for VoIP traffic may be implemented using a computer program product comprising computer executable instructions embodied in a computer-readable medium. Exemplary computer-readable media suitable for implementing the subject matter described herein include chip memory devices, disk memory devices, programmable logic devices and application specific integrated circuits. In addition, a computer-readable medium that implements the subject matter described herein may be distributed across multiple physical devices and/or computing platforms.
Preferred embodiments of the subject matter described herein will now be explained with reference to the accompanying drawings of which:
In view of the problems described above with respect to obtaining a ranked list of paths from a source IP device to a destination IP device across a data network using SPF calculations, the subject matter described herein provides a method to obtain a ranked list of paths to a destination IP device across a data network based on path costs.
In
At block 104, the multi-path router instance may assign a cost to the segment between each network interface and the IP device resource hosting the multi-path router instance. This cost may be defined by the multi-path router instance, or it may be assigned by the host system. For example, if a diagnostic task running on the IP device determines that a network interface requires maintenance, the IP device may present a request to the multi-path router instance to change the cost for the segment between the multi-path router instance and the network interface. This permits the multi-path router instance to gracefully shift data traffic from the network interface before the diagnostic task disables the interface for maintenance operations. Once the system diagnostic has completed its work on the network interface, the IP device may then provide a request to the multi-path router instance to return the segment cost to its original value in order to re-enable data traffic on that interface.
Once the interior segment costs have been assigned, the multi-path router instance in the IP device may advertise these costs to adjacent SPF network nodes. For example, an IP device with multiple network interfaces to an adjacent network router may advertise the interior segment costs in order to assist the router with data path selection for traffic terminating at the IP device. These costs may be transmitted to the adjacent network node(s) using conventional link state advertisement (LSA) messages.
At block 106, the SPF may calculate the total path cost for each network path originating at the multi-path router instance. The assigned and available network paths may be maintained in a link state database (LSDB) created and maintained by the multi-path router instance based on network topology information received from neighboring IP devices. The network path calculations may start at the network interface, using the cost assigned to the interior segment at block 106 as the first cost in the summation.
At block 108, the multi-path router instance may create and maintain a list of all available network paths to IP destinations to which the host IP device has traffic flow assignments. This list may be ranked in order of calculated path cost, with the most preferred path to a destination IP device being the path with lowest aggregate cost. This list may be maintained by the multi-path router instance separate from the LSDB in order to ensure that the multi-path router instance has the opportunity to filter incoming LSA messages from adjacent network nodes for applicable network topology definition changes before recalculating and potentially changing the ranks of the network path definitions.
The multi-path router instance may also analyze the ranked path list before enabling data traffic on the preferred path. For example, the multi-path router instance may define the preferred path(s) as being the path(s) having the lowest aggregate cost. The multi-path router instance may also cross-check the definition of the preferred path(s) against the contents of the LSDB to ensure that the defined preferred path(s) are available for use. In the even that the methods at block 108 identify multiple paths with the same preferred cost, the multi-path router instance may further constrain assignment of data traffic along those paths in order to achieve a level of performance desired by an application.
At decision point 110, the multi-path router instance may query the host IP device to determine if changes to the interior segment cost assignments are required. The host IP device may need to modify these assignments for a variety of reasons, including system maintenance operations or network interface reconfiguration requirements. If a change to segment costs is required, the multi-path router instance may implement the change and then transition to block 104 in order to recalculate all network path costs and generate new path rank lists. If no change is required, the process may proceed to decision point 112.
At decision point 112, the multi-path router instance may receive at least one LSA message from adjacent nodes to analyze for any network topology or network segment cost changes. Each LSA message may have a format defined for conventional SPF protocols including OSPF or TE-OSPF. If the multi-path router instance determines that a network topology change has occurred that impacts its LSDB, the multi-path router instance may update its LSDB and the process may transition to block 106 in order to recalculate all network path costs. If the LSA message does not provide updated network topology information, the process may transition to decision point 110 to monitor for any interior segment changes required by the host IP device.
In one implementation, an IP device, such as a media gateway, may include a single multi-path router instance that executes a path cost calculation algorithm, multiple times to calculate path costs to a destination through a plurality of network interface in the IP device.
In
IP device 1202 and IP device 2204 may define application data traffic flows using conventional data communication protocol methods including IP source and destination addresses, TCP or UDP addresses, and Real-Time Transport Protocol (RTP) addresses used for VoIP traffic. IP device 1202, IP device 2204, RT1206, RT2208, and RT3210 may each maintain network topology information in a LSDB and may update their respective LSDBs upon receipt of LSAs as defined according to conventional implementations of the SPF protocol.
IP device 1202 may assign SPF node identities to network interface A 226, network interface B 228, and network interface C 230. IP device 1302 or the operator of IP device 1202 may assign SPF costs to interior segments 232, 234, and 236. These costs may be defined by system management resources within IP device 1 through interaction with multi-path router instance 224, and may be keyed to constrain data traffic flows through specific network interfaces within IP device 1202. Once assigned, these costs may also be advertised to adjacent network devices RT1206, RT2208, and RT3210 using conventional LSA messages. The network path definitions and associated path costs to each destination IP device may also be stored by multi-path router instance 224 in the path cost table 238.
In an exemplary application, a network administrator may assign the following costs to data network segments 212, 214, 216, 218, 220, and 222, as indicated in
Cost(212)=5; Cost(214)=10; Cost(216)=8;
Cost(218)=12; Cost(220)=3; Cost(222)=18
Multi-path router instance 224 may then derive three parallel network path definitions and cost models costs to destination IP device 2204 as follows:
Path A: network interface A 226::RT1206::IP device 2204
Path B: network interface B 228::RT2208::IP device 2204
Path C: network interface C 230::RT3210::IP device 2204
In a second exemplary application with the above exemplary network segment costs, multi-path router instance 224 may set costs for interior segments 232, 234, and 236 so that all three network paths between multi-path router instance 224 and IP device 2204 have equal cost. This configuration may permit IP device 1202 to distribute the aggregate data traffic destined for IP device 2204 among the three paths in a load sharing configuration. In order to achieve this configuration, multi-path router instance 224 may assign the following values to the interior segment cost parameters:
Cost(232)=9; Cost (Path A)=26
Cost(234)=13; Cost (Path B)=26
Cost(236)=0; Cost (Path C)=26
In a third exemplary application of with the above exemplary network segment costs, multi-path router instance 224 may be required by other resources within IP device 1202 to establish a prioritized rank of network interface or path utilization without changing assigned costs for external data network segments 212, 214, 216, 218, 220, and 222. For example, an autonomous system management function within IP device 1202 (not shown) may determine that network interface C 230 has become overloaded and can no longer carry the same level of traffic as before. Multi-path router instance 224 may assign the following cost parameters in order to favor use of network interface A 226 first, followed by network interface B 228, and then reserve network interface C 230 for sparing or overflow traffic only:
Cost (232)=20; Cost (Path A)=37
Cost (234)=35; Cost (Path B)=48
Cost (236)=100; Cost (Path C)=126
In the example illustrated in
In
IP device 1302, IP device 2304, and IP device 306 may define application data traffic flows using conventional data communication protocol methods including IP source and destination addresses, TCP or UDP addresses, and RTP addresses for VoIP traffic. IP device 1302, IP device 2304, IP device 3306, RT1308, RT2310, RT3312, and RT4314 may each maintain network topology information in a LSDB and may update their respective LSDBs upon receipt of LSAs as defined according to conventional implementations of the SPF protocol.
IP device 1302 may assign SPF node identities to network interface A 340, network interface B 342, network interface C 344, network interface D 346, network interface E 348. IP device 1302 or the operator of IP device 1302 may assign SPF costs to interior segments 350, 352, 354, 356, and 358. These costs may be defined by system management resources within IP device 1302 through interaction with multi-path router instances SPF 1336 and SPF 2338, and may be keyed to constrain data traffic flows through specific network interfaces within IP device 1302. Once assigned, these costs may be advertised to adjacent network devices RT1308, RT2310, RT3312, and RT4314 using conventional LSA messages. Multi-path router instance 1336 may maintain a LSDB and path calculations for network interface A 340, network interface B 342, and network interface C 344, and may store its network path definitions and associated path costs to each destination IP device in the path cost table 360. Multi-path router instance 2338 may maintain a LSDB and path calculations for network interface D 346 and network interface E 348, and may store its network path definitions associated path costs to each destination IP device in the path table 362. IP device 1302 may collect the LSDB and path calculation information from multi-path router instance 1336 and multi-path router instance 2338 and create a combined LSDB and path table for the overall device.
In an exemplary application, a network administrator may assign the following costs to data network segments 316, 318, 320, 322, 324, 326, 328, 330, 332, and 334, as indicated in
Cost(316)=50; Cost(318)=64; Cost(320)=39;
Cost(322)=70; Cost(324)=83; Cost(326)=23;
Cost(328)=58; Cost(330)=28; Cost(332)=35;
Cost(334)=18;
Multi-path router instance 1336 may derive three parallel network path definitions and costs to destination IP device 2304 as follows:
Path A: network interface A 340::RT1308::IP device 2304
Path B: network interface B 342::RT2310::IP device 2304
Path C: network interface C 344::RT3312::IP device 2304
Multi-path router instance 1336 may also derive a single, non-redundant network path definition and cost model to destination IP device 3306 using conventional SPF protocols as follows:
Path D: network interface C 344::RT3312::IP device 3306
Multi-path router instance 2338 may derive two parallel network path definitions and cost models to destination IP device 3306 as follows:
Path E: network interface D 346::RT3312::IP device 2306
Path F: network interface E 348::RT4314::IP device 2306
Multi-path router instance 2338 may also derive a single, non-redundant network path definition and cost model to destination IP device 2304 using conventional SPF protocols as follows:
Path G: network interface D 346::RT3312::IP device 2304
In a second exemplary application of IP device 1302 in data network 300 with the above network segment costs, SPF 1 instance 336 may set costs for interior segments 350, 352, and 354 such that Paths A, B, and C have the same aggregate cost. This may be desired by application resources in IP device 1302 in order to provide load balancing across multiple network paths for data traffic between IP applications associated with SPF 1336 and IP device 2304. In order to achieve this goal, the assigned costs may be as follows:
Cost(350)=49; Cost(Path A)=122
Cost(352)=0; Cost(Path B)=122
Cost(354)=55; Cost(Path C)=122 and Cost(Path D)=129
In a third exemplary application of IP device 1302 in data network 300 with the above exemplary network segment costs, multi-path router instance 2338 may independently set cost values for interior segments 356 and 358 such that Paths D and E have the same cost, in order to provide load balancing of data traffic between IP applications associated with SPF 2 and IP device 3306. In order to achieve this goal, the assigned costs may be as follows:
Cost(356)=30; Cost(Path E)=135 and Cost(Path G)=128
Cost(358)=34; Cost(Path F)=135
In another exemplary application of IP device 1302 in data network 300 with the above network segment costs, multi-path router instance 1336 may be required by other resources within IP device 1302 to established a prioritized rank of network interface or path utilization without changing assigned costs for external data network segments. For example, an autonomous system management function within IP device 1302 may determine that network interface A 340 requires a new software load and can only carry traffic on an emergency basis until the update is complete. Multi-path router instance 1336 may assign the following cost parameters in order to favor use of network interface B 342 first, followed by network interface C 344, and then reserve network interface A 340 for sparing or overflow traffic only:
Cost(350)=500; Cost(Path A)=573
Cost(352)=10; Cost(Path B)=132
Cost(354)=70; Cost(Path C)=137 and Cost(Path D)=144
In yet another exemplary application of IP device 1302 in data network 300 with the above network segment costs, multi-path router instance 2338 may be required by other resources within IP device 1302 to established a prioritized rank of network interface or path utilization without changing assigned costs for external data network segments. For example, an autonomous system management function within IP device 1302 may determine that network interface E 348 requires diagnostic testing and should have data traffic temporarily diverted to network interface D 346 until the tests are complete. Multi-path router instance 2338 may assign the following cost parameters in order to favor use of network interface E 346 first and then reserve network interface F 348 for sparing or overflow traffic only:
Cost(356)=20; Cost(Path E)=125 and Cost(Path G)=118
Cost(358)=1000; Cost(Path F)=1101
An IP device with a multi-path router instance according to an embodiment of the subject matter described herein may communicate with other like devices to maintain ranked VoIP path lists to the devices.
In
In an exemplary application, a network administrator may assign the following costs to data network segments 412, 414, 416, 418, 420, and 422, as indicated in
Cost(412)=35; Cost(414)=30; Cost(416)=45
Cost(418)=40; Cost(420)=45; Cost(422)=35
Multi-path router instance 424 and multi-path router instance 438 may define three interconnecting network paths and associated cost models, as follows:
In a second exemplary application, the multi-path router instances in IP device 1402 may autonomously assign costs to interior segments 350, 352, 354, 356, and 358 while maintaining the external network costs identified above. For example, multi-path router instance 424 may autonomously assign costs to IP device 1402 interior segments 432, 434, and 436, as follows:
Cost(432)=15; Cost(434)=10; Cost(436)=15
Additionally, multi-path router instance 438 may autonomously assign costs to IP device 2404 interior segments 446, 448, and 450, as follows:
Cost(446)=20; Cost(448)=20; Cost(450)=20
These multi-path router instances may then define the end-to-end cost for each of the three network paths as follows:
Path A represents the preferred path between IP device 1 multi-path router instance 424 and IP device 2 multi-path router instance 438, with paths B and C as alternates in a load-sharing configuration.
In a third exemplary application, IP device 2404 may have a requirement to stop sending traffic through network interface 2B 444 so that equipment at IP device 2404 may be replaced or reconfigured. Multi-path router instance 440 may reassign interior segment 450 cost to be 10,000 in order to gracefully shift traffic away from network interface 444. This change of cost assignment may raise the aggregate cost for Path B to 10,085 if the external network does not make any contemporaneous changes to costs assigned to network segments 414 or 420. Since the interior segment costs may be advertised using SPF LSA messages, IP device 1 may update its internal path cost calculations and ranked path list with the change at IP device 2, shifting all data traffic away from Path B before the conventional LSA messages associated with SPF network protocols would provide an indication that network interface 2B 444 has been disabled by IP device 2404.
In one exemplary implementation, an IP device with a multi-path router instance may comprise a media gateway or other like device for processing media packets, such as VoIP packets.
In
Switch fabric 504 may provide connectivity among control module 502, VoIP hosts H1506, H2508, H3510, and H4512, multi-path SPF router instances SPF 1514 and SPF 2516, and other resources in media gateway 500. In one implementation, switch fabric 504 may be an Ethernet switch fabric. In an alternate implementation, switch fabric 504 may be an ATM switch fabric. Although not illustrated in
VoIP hosts H1506, H2508, H3510, and H4512 may contain resources for processing VoIP and TDM voice streams. For example, each VoIP host may include codecs, voice over ATM, voice over IP, and TDM components, and digital signal processing resources for processing VoIP streams. Each host may also include resources to implement RTP protocol functions, including datagram creation and control messaging. Each host may also have a unique IP address assigned by media gateway 500.
Multi-path SPF router instances SPF 1514 and SPF 2516 and cost tables 518 and 520 may be utilized in media gateway 500 to implement all routing protocol interactions with adjacent SPF nodes in the external data network. Multi-path router instances SPF 1514 and SPF 2516 may implement a published protocol utilizing SPF algorithms and methods, such as OSPF and TE-OSPF or may implement a propriety SPF protocol. Multi-path SPF router instances SPF 1514 and SPF 2516 may each be associated with multiple network interfaces and implement network path definitions and cost calculations according to the subject matter described herein.
Network interfaces A 522, B 524, C 526, and D 528 may provide standard external interface functions to media gateway 500, including physical termination of network segments to adjacent network nodes. For example, network interfaces 522, 524, 526, and 528 may be IP network interfaces that interface with an external IP network.
In operation, multi-path SPF router instances 514 and 516 may each implement an SPF algorithm multiple times using network interfaces 522, 524, 526, and 528 as SPF nodes to calculate costs for a plurality of paths through network interface 522, 524, 526, and 528 to a destination. Multi-path SPF router instances 514 and 516 may create and maintain a ranked list of IP paths to the destinations based on the calculated costs. Multi-path SPF router instances 514 and 516 may forward traffic over at least one of the paths, such as a lowest cost path. If the lowest-cost path fails, multi-path SPF router instances 514 and 516 may select a new lost cost path and begin using that path for outgoing media packets.
It will be understood that various details of the subject matter described herein may be changed without departing from the scope of the subject matter described herein. Furthermore, the foregoing description is for the purpose of illustration only, and not for the purpose of limitation, as the subject matter described herein is defined by the claims as set forth hereinafter.
This application is a continuation-in-part of U.S. patent application Ser. No. 10/943,513 filed Sep. 17, 2004 (pending), which is a continuation-in-part of U.S. patent application Ser. No. 10/676,233, filed Oct. 1, 2003 (pending), and which claims the benefit of U.S. Provisional Patent Application Ser. No. 60/526,126 filed Dec. 1, 2003 and U.S. Provisional Patent Application Ser. No. 60/551,814 filed Mar. 10, 2004. This application claims the benefit of U.S. Provisional Patent Application Ser. No. 60/748,749 filed Dec. 9, 2005. This application is related to U.S. patent application Ser. No. 10/943,275 filed Sep. 17, 2004 (now U.S. Pat. No. 6,956,820). The disclosure of each of the above-referenced documents is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6061348 | Castrigno et al. | May 2000 | A |
6633563 | Lin et al. | Oct 2003 | B1 |
6674744 | Doshi et al. | Jan 2004 | B1 |
6714535 | Herh | Mar 2004 | B1 |
6771673 | Baum et al. | Aug 2004 | B1 |
6831895 | Ji et al. | Dec 2004 | B1 |
6831898 | Edsall et al. | Dec 2004 | B1 |
6879667 | Carew et al. | Apr 2005 | B1 |
6956820 | Zhu et al. | Oct 2005 | B2 |
7177943 | Temoshenko et al. | Feb 2007 | B1 |
7185094 | Marquette et al. | Feb 2007 | B2 |
7212519 | Johnson et al. | May 2007 | B2 |
7394818 | Johnson et al. | Jul 2008 | B1 |
7424025 | Qian et al. | Sep 2008 | B2 |
20020006112 | Jaber et al. | Jan 2002 | A1 |
20020012352 | Hansson et al. | Jan 2002 | A1 |
20020016926 | Nguyen et al. | Feb 2002 | A1 |
20020051464 | Sin et al. | May 2002 | A1 |
20020191612 | Curtis | Dec 2002 | A1 |
20030093555 | Harding-Jones et al. | May 2003 | A1 |
20030099192 | Scott et al. | May 2003 | A1 |
20030118039 | Nishi et al. | Jun 2003 | A1 |
20030142795 | Gavette et al. | Jul 2003 | A1 |
20030193898 | Wong et al. | Oct 2003 | A1 |
20040047345 | Joseph et al. | Mar 2004 | A1 |
20040066782 | Nassar | Apr 2004 | A1 |
20050068942 | Chu et al. | Mar 2005 | A1 |
20050073998 | Zhu et al. | Apr 2005 | A1 |
20070064613 | Qian et al. | Mar 2007 | A1 |
20070083528 | Matthews et al. | Apr 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20070053300 A1 | Mar 2007 | US |
Number | Date | Country | |
---|---|---|---|
60526126 | Dec 2003 | US | |
60551814 | Mar 2004 | US | |
60748749 | Dec 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10943513 | Sep 2004 | US |
Child | 11545788 | US | |
Parent | 10676233 | Oct 2003 | US |
Child | 10943513 | US |