The present invention relates to a communication path control system for controlling communication paths between communication nodes, and also relates to a program for making a computer function as the relevant communication path control system, and a storage medium which stores the program.
Priority is claimed on Japanese Patent Application No. 2007-080406, filed Mar. 27, 2007, the contents of which are incorporated herein by reference.
In a network (called an “MPLS network”, below) which uses MPLS (multi protocol label switching) (see Non-Patent Document 1), an “MPLS TE” (traffic engineering) technique (see Non-Patent Document 2) is used for controlling a large amount of traffic.
In the MPLS TE technique, a plurality of parallel links are connected between nodes, so as to handle a large amount of traffic. In order to efficiently use the links, it is necessary to equally distribute “MPLS TE LSPs (label switched paths)” (called “MPLS paths”, and see Non-Patent Document 2) for the frequency band and the number of the paths, where the MPLS paths are arranged along links provided between the start node (as the start point of the relevant communication) and the end node.
When setting MPLS paths by using reserved bands, it is possible to equally distribute the MPLS paths, which are arranged along links between the relevant nodes, by using already-established techniques (see Non-Patent Documents 2 and 6).
However, when setting MPLS paths while there is no reserved band at present, if there is an ECMP (equal cost multi path) (see Non-Patent Document 3) in an MPLS network, then load distribution cannot be performed between the relevant nodes. In this case, a problem (e.g., path concentration at a specific link) occurs, which obstructs efficient establishment of MPLS paths.
Conventionally, systems disclosed in Non-Patent Documents 4 and 5 are implemented.
In addition, computation of MPLS paths is performed at the start node, by using LSA (link state advertisement) data (see Non-Patent Documents 3 and 6) defined in OSPF (open shortest path fast) protocol (see Non-Patent Document 3).
On the other hand, in order to distribute MPLS paths along links between the relevant nodes, it is proposed that the number of the MPLS paths be communicated to relevant systems, by using the OSPF protocol (see Non-Patent Document 7). However, a specific method of computing the MPLS paths has not been shown.
Non-Patent Document 1: E. Rosen, A. Viswanathan, R. Callon, “Multiprotocol Label Switching Architecture”, IETF RFC3031, January, 2001.
Non-Patent Document 2: D. Awduche, et al., “RSVP-TE: Extensions to RSVP for LSP Tunnels”, IETF RFC3209, December, 2001.
Non-Patent Document 3: J. Moy, “OSPF version 2”, IETF RFC2328, April, 1998.
Non-Patent Document 4: “How CSPF Selects a Path”, retrieved from the Internet on Mar. 7, 2007.
Non-Patent Document 5: E. Osborne, A. Simha, “Traffic Engineering with MPLS”, pp. 119-124, Cisco Press, 2003.
Non-Patent Document 6: D. Katz, et al., “Traffic Engineering (TE) Extensions to OSPF Version 2”, IETF RFC 3630, September, 2003.
Non-Patent Document 7: J.-P. Vasseur, M. Mayer, K. Kumaki and A. Bonda, “A Link-Type sub-TLV to convey the number of Traffic Engineering Label Switch Paths signalled across a link”, IETF Internet draft, June, 2006. (draft-ietf-mpls-number-0-bw-te-lsps-05.txt)
A conventional technique disclosed in Non-Patent Documents 4 and 5 has a problem, which will be explained with reference to a network shown in
In the network shown in
In the conventional technique, when establishing a plurality of MPLS paths between the edge router R1 (the start node) and the edge router R5 (the end node), many paths are concentrated at the link E-F between the core routers R3 and R4, or paths are not equally distributed among the links E-F, G-H, and I-J.
Therefore, even when a plurality of links is established between the relevant nodes so as to control a large amount of traffic, paths are concentrated to a specific link, and thus the network works (i) without using the other links, or (ii) while usage rates of each link are not equal. Therefore, the links cannot be sufficiently efficiently used.
In consideration of the above problem, an object of the present invention is to provide a communication path control system, a relevant program, and a storage medium therefor, so as to equally distribute communication paths to a plurality of parallel links provided between communication nodes.
In order to solve the above problem, the present invention provides a communication path control system for controlling communication paths between communication nodes, comprising:
a storage device which stores data of paths between the communication nodes; and
a communication path selecting device which selects a path candidate for setting a new communication path among path candidates, each of which can be provided as a communication path between the communication nodes, wherein:
based on the data of paths which is stored by the storage device, the communication path selecting device obtains MAX(PN) for each of the path candidates P1, . . . , Pn, n being an integer of 2 or larger, where MAX(PN) is the maximum value of the number PN of already-established communication paths passing through each link which forms said each path candidate, that is, PN=[N1, . . . , Nm], m is an integer of 1 or larger, and N is the number of the already-established communication paths passing through said each link; and
the communication path selecting device selects the path candidate having the smallest value among the maximum values MAX(PN) of the path candidates.
In a typical example:
if there is a plurality of the path candidates which have the smallest value among the maximum values MAX(PN), the communication path selecting device:
The present invention also provides a program for making a computer function as the above-described communication path control system.
The present invention also provides a computer readable storage medium which stores the above program.
In accordance with the present invention, it is possible to equally distribute communication paths to a plurality of parallel links provided between communication nodes.
Below, an embodiment in accordance with the present invention will be explained with reference to the drawings.
In
The storage part 10a stores data which is used in the MPLS path computation.
Based on the data stored in the storage part 10a, the path computing part 10b executes the MPLS path computation, so as to select a path candidate for setting a new communication path among path candidates, each of which can be provided as a communication path between the relevant communication nodes.
The control part 10 also has a control data exchange part 10c for exchanging control data with another MPLS path control system via an interface part 12.
In accordance with the MPLS paths determined by the control part 10, a transfer part 11 transfers data through the interface part 12, which is a physical communication interface connected to the relevant network.
The following explanation relates to a method for efficiently establishing MPLS paths by using no reserved band when there is an ECMP, and there are parallel links between nodes.
Before the execution of the MPLS path computation, the control data exchange part 10c of the control part 10 communicates OSPF protocol data (see Non-Patent Documents 6 and 7), so that a plurality of MPLS path control systems commonly have the same data. This data is stored by the storage part 10a, and includes data for indicating links between the relevant nodes on the network, and the number of already-established MPLS paths passing through each link.
Step S100 in
When the MPLS path computation starts, the path computing part 10b retrieves the above data from the storage part 10a, and lists up all ECMPs between the start node and the end node.
That is, if assuming that there are n ECMPs (n is an integer of 2 or larger), the path computing part 10b stores the MPLS path data, which is retrieved from the storage part 10a, into an array “ECMP” indicated by the following formula (1):
ECMP=[P[1], . . . , P[n]] (1)
The data of MPLS paths as candidates for an MPLS path which can be established between the relevant nodes is stored into P[i] (1≦i≦n) which forms the array “ECMP”.
When a single MPLS path is formed by m links (m is an integer of 1 or larger), the array P[i] for the i-th MPLS path is represented by the following formula (2):
P[i]=[Li1, . . . , Lim] (2)
In addition, the path computing part 10b stores data of the number of MPLS paths, which is retrieved from the storage part 10a, into an array “PN[i]” which indicates the number of already-established MPLS paths passing through each link as a constituent of the i-th MPLS path.
The array PN[i] is indicated by the following formula (3):
PN[i]=[Ni1, . . . , Nim] (3)
where Nij (1≦j≦m) indicates the number of already-established MPLS paths which pass through the j-th link.
Step S110 in
For all of the n MPLS paths, the path computing part 10b computes the maximum values MAX PN[i] for the number of the already-established MPLS paths, which is indicated by the formula (3) (see formula (4)).
MAX(PN[i])=MAX(Ni1, . . . , Nim) (4)
Next, the path computing part 10b stores the maximum value MAX(PN[i]) for each MPLS path into an array “MAX” represented by the following formula (5):
MAX=[MAX(PN[1]), . . . , MAX(PN[m])] (5)
Step S120 in
The path computing part 10b acquires the minimum value MIN(MAX(PN)) among the maximum values MAX(PN[i]) which form the array MAX (see formula (6)).
MIN(MAX(PN))=MIN(MAX(PN[1]), . . . , MAX(PN[n])) (6)
Step S130 in
The path computing part 10b acquires each MPLS path which satisfies the condition “MAX(PN[i])=MIN(MAX(PN))”, and determines whether a plurality of MPLS paths satisfies the above condition.
Step S140 in
If there is only one MPLS path which satisfies the above condition in accordance with the determination in step S130, the path computing part 10b selects the relevant MPLS path as the newly-established MPLS path.
Step S150 in
If there is a plurality of MPLS paths which satisfies the above condition in accordance with the determination in step S130, the path computing part 10b computes, for each MPLS path which satisfies the condition, the sum “SUM(PN[i])” of the numbers of the already-established MPLS paths assigned to each link which forms the relevant MPLS path (see formula (7)).
SUM(PN[i])=Ni1+ . . . +Nim (7)
The path computing part 10b then stores the sum SUM(PN[i]), acquired for each relevant MPLS path, into an array “SUM” represented by the following formula (8):
SUM=[SUM(PN[1]), . . . , SUM(PN[m])] (8)
Step S160 in
Next, the path computing part 10b acquires the minimum value “MIN(SUM(PN))” among the sums SUM(PN[i]) which form the array SUM (see formula (9)).
MIN(SUM(PN))=MIN(SUM(PN[1]), . . . , SUM(PN[n])) (9)
Step S170 in
The path computing part 10b then acquires each MPLS path which satisfies the condition “SUM(PN[i])=MIN(SUM(PN))”, and determines whether a plurality of MPLS paths satisfies the above condition.
Step S180 in
If there is only one MPLS path which satisfies the above condition in accordance with the determination in step S170, the path computing part 10b selects the relevant MPLS path as the newly-established MPLS path.
Step S190 in
If there is a plurality of MPLS paths which satisfies the above condition in accordance with the determination in step S170, the path computing part 10b selects the MPLS path having the smallest number (i) as the newly-established MPLS path.
When the newly-established MPLS path has been determined, the control part 10 retrieves the data of the relevant MPLS path from the array ECMP. Based on the retrieved data, the control part 10 executes path determination for the data transfer performed by the transfer part 11.
In addition, the control data exchange part 10c communicates the data of the newly-established MPLS path to the relevant systems.
Below, a concrete example of the path computation in accordance with the above procedure will be shown.
In
In the network of
In the network shown in
That is, three MPLS paths pass through the link A-B. Similarly, five MPLS paths pass through the link C-D; one MPLS path passes through the link E-F; three MPLS paths pass through the link G-H; four MPLS paths pass through the link I-J; three MPLS paths pass through the link K-L; and five MPLS paths pass through the link M-N.
In order to establish a new MPLS path passing from the edge router R1 to the edge router R5, the MPLS path control system provided in the edge router R1 selects the new MPLS path, as follows:
The ECMPs from the edge router R1 to the edge router R5 are represented by the set of MPLS paths P1, P2, and P3 (see formula (10)).
ECMP={P1, P2, P3} (10)
In the formula (10), the MPLS paths P1, P2, and P3 are each represented by a set of links (see formulas (11) to (13), which correspond to the above-explained formula (2)).
P1={A-B, E-F, K-L} (11)
P2={A-B, G-H, K-L} (12)
P3={A-B, I-J, K-L} (13)
In addition, for each MPLS path, the number (i.e., PN1, PN2, or PN3) of already-established MPLS paths passing through each link as a constituent of the relevant MPLS path is represented by the following formulas (14) to (16), which correspond to the above-explained formula (3)):
PN1={3, 1, 3} (14)
PN2={3, 3, 3} (15)
PN3={3, 4, 3} (16)
The maximum values MAX(PN1), MAX(PN2), and MAX(PN3) of PN1, PN2, and PN3 are respectively represented by the following formulas (17) to (19), which correspond to the above-explained formula (4):
MAX(PN1)=3 (17)
MAX(PN2)=3 (18)
MAX(PN3)=4 (19)
The minimum value among MAX(PN1), MAX(PN2), and MAX(PN3) is 3, and there are two, that is, MAX(PN1) and MAX(PN2).
For each of the two MPLS paths, the sum of the numbers of the already-established MPLS paths passing through each link as a constituent of the relevant MPLS path is computed, and the result is 7 for the MPLS path P1, and 9 for the MPLS path P2.
Therefore, the MPLS path P1 passing through the link E-F between the edge routers R3 and R4 is selected as the newly-established MPLS path.
Similarly, in order to establish a new MPLS path from the edge router R2 to the edge router R6, an MPLS path passing through the link E-F between the core routers R3 and R4 is selected as the newly-established MPLS path.
Next, path computations performed by the MPLS path control system of the present embodiment will be compared with path computations performed by systems disclosed in Non-Patent Documents 4 and 5.
The network structure used for the computation is the same as that shown in
For each pattern, the following three methods were used for performing the computation for establishing an MPLS path:
Each figure shows the number of MPLS paths assigned to each of the links E-F, G-H, and I-J. In addition, the “initial value” indicates the number of already-established MPLS paths which are assigned to each link in an initial state before the computation is executed. The “verified value” indicates the number of MPLS paths which are newly established.
In addition,
In the results of each computation executed by the system disclosed in Non-Patent Document 4 or 5, the MPLS paths are not equally assigned to the relevant links. In contrast, in the results of each computation executed by the MPLS path control system in accordance with the present embodiment, the MPLS paths are equally distributed for any settings of the MPLS paths in the initial state.
As described above, in accordance with the present embodiment, communication paths can be equally distributed to parallel-arranged links between communication nodes.
In addition, if a plurality of MPLS paths satisfies the relevant condition (see step S130 in
In accordance with the present embodiment, on the point of design and use of an actual network, it is possible to efficiently and effectively use network resources, and thus to provide an inexpensive and stable network service.
In contrast to conventional systems in which complex MPLS-path setting is manually performed, such complex MPLS-path setting can be avoided, thereby reducing the load and cost for using an actual network.
The embodiments of the present invention have been explained in detail with reference to the drawings. However, concrete structures are not limited to the embodiments, and also include design modifications or the like, within the scope of the present invention.
For example, a program for implementing the operations and functions of the MPLS path control system in accordance with the above-described embodiment may be stored in a computer readable storage medium, and the program stored in the storage medium may be loaded and executed on a computer.
If the computer employs a WWW system, the computer can provide a homepage viewable environment.
The above computer readable storage medium is a storage device, for example, a portable medium such as a flexible disk, magneto optical disk, ROM, or CD-ROM, or a memory device such as a hard disk built in a computer.
The computer readable storage medium also includes a device for temporarily storing the program, such as a volatile storage medium (RAM) in a computer system which functions as a server or client and receives the program via a network (e.g., the Internet) or a communication line (e.g., a telephone line).
The above program, stored in a memory device of a computer, may be transmitted via a transmission medium or by using transmitted waves passing through a transmission medium to another computer. The transmission medium for transmitting the program has a function of transmitting data, and is, for example, a (communication) network such as the Internet or a communication line such (e.g., a telephone line).
In addition, the program may execute a part of the above-explained functions.
The program may also be a “differential” program so that the above-described functions can be executed by a combination program of the differential program and an existing program which has already been stored in the relevant computer.
In accordance with the present invention, communication paths can be equally distributed to a plurality of parallel-arranged links between communication nodes.
Number | Date | Country | Kind |
---|---|---|---|
2007-080406 | Mar 2007 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2008/054961 | 3/18/2008 | WO | 00 | 5/1/2009 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2008/123063 | 10/16/2008 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6697333 | Bawa et al. | Feb 2004 | B1 |
6956821 | Szviatovszki et al. | Oct 2005 | B2 |
7221646 | Kawano et al. | May 2007 | B2 |
7450513 | Okamura et al. | Nov 2008 | B2 |
7596088 | Agmon et al. | Sep 2009 | B2 |
7725035 | Tyan et al. | May 2010 | B2 |
7804952 | Chandra et al. | Sep 2010 | B2 |
7885398 | Chandra et al. | Feb 2011 | B2 |
20050169313 | Okamura et al. | Aug 2005 | A1 |
20050259586 | Hafid et al. | Nov 2005 | A1 |
Number | Date | Country |
---|---|---|
1411687 | Apr 2004 | EP |
2001-244974 | Sep 2001 | JP |
2003-224585 | Aug 2003 | JP |
2004-129135 | Apr 2004 | JP |
2005-217838 | Aug 2005 | JP |
Number | Date | Country | |
---|---|---|---|
20100067532 A1 | Mar 2010 | US |