The present invention relates to communication technology, more particularly, to methods for supporting migration of virtual machines (VMs) across multiprotocol label switching network and corresponding devices.
Cloud Computing has emerged with the development of the traditional computer technologies and network technologies such as Grid Computing, Distributed Computing, Parallel Computing, Utility Computing, Network Storage Technologies, Virtualization, Load Balance, etc. It is intended to integrate multiple low-cost computing entities into one system with powerful computing capability through the network, and distribute such powerful computing capability to end users with the help of such modes as SaaS (Software-as-a-Service), PaaS (Platform-as-a-Service), IaaS (Infrastructure-as-a-Service), MSP (Manage Service Provider), etc.
The virtualization technology can perform re-mapping of virtual machines and physical resources based on variation in workload by encapsulating services into the virtual machines and mapping them to the physical resources, namely a cloud center, thereby dynamically realizing the workload balance of the whole system. That is, the virtual machines may be dynamically migrated from one cloud center to another so as to realize the workload balance of the system.
From users' point of view, no matter how the virtual machines are migrated, their services should be continuous during the virtual machine migrations.
In practice, multiprotocol label switching (MPLS) network can be employed to interconnect the respective cloud centers.
The purpose of the present invention is to provide a solution to support the migration of the virtual machines across the multiprotocol label switching network.
According to a first aspect of the present invention, there is provided a method for supporting migration of virtual machines across multiprotocol label switching network, which comprises the steps of:
a first label edge router (LER) receiving a migration enablement function (MEF) discovery message from a first virtual machine that wishes to register with the first LER;
the first LER updating its own virtual machine binding database to reflect binding of the first virtual machine to the first LER; and
the first LER sending a MEF advertisement message to the first virtual machine to indicate that the first LER completes the registration of the first virtual machine.
According to a second aspect of the present invention, there is provided a first label edge outer (LER) of supporting migration of virtual machines across multiprotocol label switching network, which comprises:
migration enablement function (MEF) discovery message receiving means that receives a migration enablement function (MEF) discovery message from a first virtual machine that wishes to register with the first LER;
updating means that updates its own virtual machine binding database to reflect binding of the first virtual machine to the first LER; and
MEF advertisement message sending means that sends a MEF advertisement message to the first virtual machine to indicate that the first LER completes the registration of the first virtual machine.
According to a third aspect of the present invention, there is provided a method for supporting migration of virtual machines across multiprotocol label switching network, which comprises the steps of:
a first area route reflector (ARR) receiving a virtual machine binding update message from a first label edge outer (LER) located in an area of the first ARR, the virtual machine binding update message indicating that the first virtual machine is bound to the first LER;
the first ARR updating its own virtual machine binding database based on the received virtual machine binding update message to reflect the binding of the first virtual machine to the first LER.
According to a fourth aspect of the present invention, there is provided a first area route reflector (ARR) of supporting migration of virtual machines across multiprotocol label switching network, which comprises:
virtual machine binding update message receiving means that receives a virtual machine binding update message from a first label edge router (LER) located in an area of the first ARR, the virtual machine binding update message indicating that the first virtual machine is bound to the first LER; and
updating means that updates its own virtual machine binding database based on the received virtual machine binding update message to reflect the binding of the first virtual machine to the first LER.
With the present invention, no complex registration hierarchy is needed. Furthermore, the virtual machine has no need to get aware of the registration hierarchy and only a few registration signaling and processes involve the virtual machine.
Other objects and effect of the present invention will become more apparent and comprehensive from the following description in conjunction with drawings and with the full understanding of the present invention, in which:
a illustratively shows the basic encoding format of MP_REACH_VMB;
b illustratively shows the basic encoding format of MP_UNREACH_VMB;
c illustratively shows a virtual machine binding update extension field;
The same reference number refers to the same, similar or corresponding feature or function throughout the above drawings.
Now the preferred embodiments of the present invention are described in detail in conjunction with the accompany drawings.
As shown in
Assume that the virtual machine 41 is currently registered with the LER 11, the virtual machine 42 is currently registered with the LER 21, and the virtual machine 43 is currently registered with the LER 31. More specifically, the virtual machine 41 is instantiated at a cloud center connected to the LER 11, the virtual machine 42 is instantiated at a cloud center connected to the LER 21, and the virtual machine 43 is instantiated at a cloud center connected to the LER 31, these cloud centers are not shown in
To support the VM migration, the LERs and ARRs in each serving area are implemented with migration enablement function (MEF), as will be described in detail below.
Considering extensibility, the ARR is introduced in the embodiments of the present invention as described below. The ARR is used to limit the direct transmission of some messages between the LERs, instead, these messages are forwarded via the ARR. That is to say, some messages are not directly transmitted between the LERs, instead, they are transmitted between the LER and the ARR or between the ARRs, as will be described in detail below.
In addition, it is to be noted that although the interconnections between the LERs are not shown in
Of course, it should be appreciated by those skilled in the art that the ARR is not necessary in other embodiments of the present invention.
In the embodiments of the present invention, some public IP addresses are reserved, which define virtual machine identifiers (VMIDs) supporting the VM migration. These VMIDs are meaningless for all the intermediate label switching routers (LSRs) not shown in
The embodiments of the present invention will be described below taking IPv4 for example. However, those skilled in the art should understand that the present invention is not limited to IPv4, and also applicable to IPv6.
Table 1 shows the assumed IP addresses of the VMs, LERs and ARRs in the MPLS network 100 shown in
Assume that the virtual machine migration enablement function discovery and registration process shown in
Firstly, at step S210, the first LER, namely LER 11, receives a migration enablement function (MEF) discovery message from the first virtual machine (i.e. VM 41) that wishes to register with the first LER.
When the LER 11 discovers that the VMID contained in the MEF discovery message falls within the IP address range for supporting the migration of the virtual machine, at step S220, the first LER updates its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER.
Finally, at step S230, the first LER sends a MEF advertisement message to the first virtual machine to indicate completion of the registration of the first virtual machine.
The virtual machine is only registered with the routers at the edge of the MPLS network, i.e. the LERs. That is to say, the MEF discovery and registration process will not be extended to the intermediate LSRs behind the LERs.
The MEF discovery message may be sent through an ICMP (Internet Control Message Protocol) router solicitation message.
More specifically, the ICMP router solicitation message may be extended to send the MEF discovery message.
For the ICMP router solicitation message, the ICMP Type field should be set to “10”. The ICMP router solicitation message is identified as being used to send the MEF discovery message by setting the ICMP Code field of the ICMP router solicitation message with the unused value C1 or other value.
The MEF discovery message may carry the following information, including but not limited to:
1) Type Flag;
2) Virtual Machine ID;
3) Last LER ID;
4) Last ARR ID;
5) Association ID.
The Type Flag “0” indicates that this message is the MEF discovery message. The Virtual Machine ID indicates the IP address of the virtual machine to be registered, and the LER will register this virtual machine only when the VM ID is within a specified range. The Last LER ID indicates the IP address of the LER with which the virtual machine is lastly registered before the current registration. When the virtual machine initiates the MEF discovery and registration for the first time, the Last LER ID equals to “0”. The Last ARR ID indicates the IP address of the ARR of the area where the LER with which the virtual machine is lastly registered prior to the current registration is located. When the virtual machine initiates the MEF discovery and registration for the first time, Last ARR ID equals to “0”. Association ID is a sequence number used to keep track of the registration message pairs—MEF discovery/MEF advertisement.
As shown in
As described above, the LER 11 updates its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER.
The following Table 2 shows the virtual machine binding database of the LER 11.
As shown in Table 2, the first LER 11 has registered the first virtual machine VM 41, 210.101.34.25, in its virtual machine binding database.
After registering the first VM 41 in its virtual machine binding database, the LER 11 replies the MEF advertisement message to the first VM 41.
The MEF advertisement message may be sent through the ICMP router advertisement message.
More specifically, the ICMP router advertisement message may be extended to send the MEF advertisement message.
For the ICMP router advertisement message, the ICMP Type field should be set to “9”. The ICMP router advertisement message is identified as being used to send the MEF advertisement message by setting the ICMP Code field of the ICMP router advertisement message with an unused value C2 or other value.
The MEF advertisement message may carry the following information, including but not limited to:
1) Type Flag;
2) Serving LER ID;
3) Serving ARR ID;
4) Association ID.
The Type Flag “1” indicates that the message is the MEF advertisement message. The Serving LER ID indicates the IP address of the LER with which the virtual machine is currently registered, i.e. the IP address of the LER 11 in this embodiment. The Serving ARR ID indicates the IP address of the ARR of the area where the LER with which the virtual machine is currently registered is located, i.e. the IP address of ARR 1 in this embodiment. The Association ID is a sequence number used to keep track of the Registration message pairs—MEF discovery/MEF advertisement.
As shown in
Upon completion of the registration, the first LER 11 can forward the data packets received from the first virtual machine 41 to the LER to which the corresponding client is connected, such as the second LER 31 connected with the client 53.
According to an embodiment of the present invention, after completion of the registration, the process shown in
The virtual machine binding update message may be sent through a BGP (Boundary Gateway Protocol) update message.
More specifically, the BGP update message may be extended to send the virtual machine binding update message.
For example, the virtual machine binding update message is sent using MP_REACH_NLRI by defining a new <AFI(=A1), SAFI(=S1)> pair. The AFI is the Address Family Identifier, and the SAFI is the Subsequent Address Family Identifier.
That is to say, MP_REACH_NLRI is extended to send the virtual machine binding update message.
Such extended MP_REACH_NLRI attribute is specifically represented as MP_REACH_VMB.
a illustratively shows the basic encoding format of the MP_REACH_VMB.
As shown in
c illustratively shows the virtual machine binding update extension field 520.
As shown in
For example, the LER 11 can send to the ARR 1 the virtual machine binding update message including: <VMID=210.101.34.25, Target Server ID=211.136.10.1, Serving LER ID=211.140.111.1, Serving ARR ID=211.136.10.1, Last LER ID=0, Last ARR ID=0>. After receiving the virtual machine binding update message, the ARR 1 updates its own virtual machine binding database to reflect the binding of the first virtual machine 41 to the first LER 11.
Table 3 shows the recording format in the virtual machine binding database for the ARR 1.
In Table 3, the first three columns represent the ID of the VM, the ID of the serving LER with which the VMID is registered and the ID of the serving ARR of the area where the serving ARR is located, respectively. The latter two columns respectively represent query logs of the previous binding record of the virtual machine to the LER, that is, the ID of the LER which queries the binding record of the VM to the LER, and the ID of the ARR of the area where the LER is located.
The virtual machine binding database of the ARR differs from that of the LER in that it further comprises a query log entry. In addition, the virtual machine binding database of the ARR only records the VM bindings to the LERs within its area, but not records the VM bindings to the LERs outside its area.
Here, since the VM 41 is just registered with the LER 11 and no other LER and ARR queries this binding record, the query log for this binding record is null.
If the MEF discovery and registration is initiated when the VM is being migrated, after completion of the registration, the process shown in
the first LER sends the virtual machine binding update message to a third LER (e.g., the LER 22) with which the first virtual machine is lastly registered prior to registering with the first LER, such that the third LER can update its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER.
The first LER forwards to the first virtual machine the data packets received from the third LER with which the first virtual machine is lastly registered prior to registering with the first LER, or the first LER forwards to the first virtual machine the data packets received from the second LER connected with the client.
Assume
Of course, those skilled in the art should appreciate that the process shown in
When the client 51 initiates the communication with the second VM 43 registered with the LER 31, the data packet is sent (step S602) to the first LER 11 to which the client 51 is connected.
The first LER 11 learns the destination address (i.e., the ID of the VM 43) from the data packet, and queries (step S604) its own virtual machine binding database based on this VMID so as to find the binding record of the second VM 43.
If the binding record of the second VM 43 is found in its own virtual machine binding database, the first LER 11 determines the forwarding equivalence class of the data packet destined to the second VM 43 based on the IP address of the LER with which the second VM 43 is registered, and the process ends.
If the binding record of the second VM 43 is not found in its own virtual machine binding database, the first LER 11 sends (step S606) the first virtual machine binding query message to the ARR 1 of the area where the first LER 11 is located to obtain the binding of the second VM 43.
After receiving the first virtual machine binding query message, the ARR 1 queries (step S608) its own virtual machine binding database to find the binding record of the second VM 43.
If the binding record of the second VM 43 is found in its own virtual machine binding database, the ARR 1 sends the first virtual machine binding query advertisement message to the first LER 11 to notify the first LER 11 of the binding of the second virtual machine VM 43 to the corresponding LER, and records the query log in its virtual machine binding database.
After receiving the first virtual machine binding query advertisement message, the first LER 11 updates its own virtual machine binding database, and determines the forwarding equivalence class of the data packet destined to the second VM 43 based on the IP address of the LER with which the second VM 43 is registered, and the process ends.
In the process shown in
After receiving the second virtual machine binding query message, the ARR (e.g., ARR 3) queries (step S612) its own virtual machine binding database to find the binding record of the second VM 43.
Since the ARR 3 finds the binding record of the second VM 43 in its own virtual machine binding database, the ARR 3 sends (step S614) the second virtual machine binding query advertisement message to the ARR1 to notify the ARR 1 of the binding of the second virtual machine VM 43 to the corresponding LER (i.e., the LER 31), and records the query log in its virtual machine binding database.
After receiving the second virtual machine binding query advertisement message, the ARR 1 sends (step S616) the first virtual machine binding query advertisement message to the first LER 11 to notify the first LER 11 of the binding of the second virtual machine VM 43 to the corresponding LER.
After receiving the first virtual machine binding query advertisement message, the first LER 11 updates (step S618) its own virtual machine binding database, and determines the forwarding equivalence class of the data packet destined to the second VM 43 based on the IP address of the LER with which the second VM 43 is registered. Thereafter, as shown by step S620, the data packets can be transmitted between the client 51 and the VM 43.
The above described virtual machine binding query messages and virtual machine binding query advertisement messages may be sent through the BGP update message.
Furthermore, considering extensibility, the virtual machine binding query message and the virtual machine binding query advertisement message are only transmitted between the LER and the ARR or between the ARRs, and are not transmitted between the LERs.
More specifically, the BGP update message can be extended to send the virtual machine binding query message and the virtual machine binding query advertisement message.
The virtual machine binding query message can be sent using MP_REACH_NLRI by defining a new <AFI(=A1), SAFI(=S2)> pair.
That is to say, the MP_REACH_NLRI is extended to send the virtual machine binding query message.
Such extended MP_REACH_NLRI attribute is specifically represented as MP_VMB_QUERY.
The virtual machine binding query advertisement message can be sent using MP_REACH_NLRI by defining a new <AFI(=A1), SAFI(=S3)> pair.
That is to say, the MP_REACH_NLRI is extended to send the virtual machine binding query advertisement message.
Such extended MP_REACH_NLRI attribute is specifically represented as MP_VMB_NTFC.
As shown in
The Length field 722 and the fields thereafter are extensions to the virtual machine binding query message.
The Type Flag field 724 may be set with two values, for example, 1 and 2.
When the value of the Type Flag field is “1”, it indicates that the virtual machine binding query message is the virtual machine binding query message from the LER to the ARR of the area where the LER is located, for example, the first virtual machine binding query message described above.
When the value of the Type Flag field is “2”, it indicates that the virtual machine binding query message is the virtual machine binding query message from the ARR of the area where the LER is located to any other ARR, for example, the second virtual machine binding query message described above.
For example, the LER 11 can send to the ARR 1 the first virtual machine binding query message including: <Type Flag=1, Querying LER ID=211.140.111.1, Querying ARR ID=, Number of Queries=1, VMID=210.101.34.35>.
For the first virtual machine binding query message, since it is sent from the LER 11 to the ARR 1 of the area where the LER 11 is located, the Querying ARR ID field may be omitted.
The ARR 1 may send to any other ARR the second virtual machine binding query message including: <Type Flag=2, Querying LER ID=211.140.111.1, Querying ARR ID=211.136.10.1, Number of Queries=1, VMID=210.101.34.35>.
For the second virtual machine binding query message, the Querying ARR ID field cannot be omitted.
As shown in
The Length field 822 and the fields thereafter are extensions.
The Type Flag field 822 may be set with four values, for example, 1, 2, 3 and 4.
When the value of the Type Flag field is 1, it indicates that the virtual machine binding query advertisement message is sent from the ARR of the area where the LER that initiates the virtual machine binding query is located to the LER, for example, the above-described first virtual machine binding query advertisement message. In this case, the pair of Querying LER and Querying ARR fields may be omitted.
When the value of the Type Flag field is 2, it indicates that the virtual machine binding query advertisement message is sent from other ARR to the ARR of the area where the LER that initiates the virtual machine binding query is located, for example, the above-described second virtual machine binding query advertisement message.
When the value of the Type Flag field is 3, it indicates that the MP_VMB_NTFC attribute sends the first virtual machine binding database advertisement message, and the first virtual machine binding database advertisement message is sent from the ARR to the LER. In this case, the pair of Querying LER and Querying ARR pair fields may be omitted. The Number of Queries may be set to 0.
When the value of the Type Flag field is 4, it indicates that the MP_VMB_NTFC attribute sends the second virtual machine binding database advertisement message, and the second virtual machine binding database advertisement message is sent from one ARR to another ARR.
For example, the ARR 3 can send to the ARR 1 the second virtual machine binding query advertisement message including: <Type Flag=2, VMID=210.101.34.35, Serving LER ID=213.140.111.1, Serving ARR ID=213.136.10.1, Number of Queries=1, Querying LER ID 1=211.140.111.1, Querying ARR ID 1=211.136.10.1>.
The ARR 1 may send to the LER 11 the first virtual machine binding query advertisement message including: <Type Flag=1, VMID=210.101.34.35, Serving LER ID=213.140.111.1, Serving ARR ID=213.136.10.1, Number of Queries=0>.
In the embodiment shown in
Firstly, at step S902, the VM 41 sends to the fourth LER (i.e. the LER 12) the MEF discovery message including: <Type=0, VMID=210.101.34.25, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1, Association ID=14>.
After receiving the MEF discovery message, the LER 12 knows that the VM 41 performs the intra-domain migration, because the Last ARR ID is same as the ID of the ARR of the area where the LER 12 is located. At step S904, the LER 12 updates its own virtual machine binding database to reflect the binding of the VM 41 to the LER 12.
Next, at step S906, the LER 12 sends to the VM 41 the MEF advertisement message including: <Type=1, Serving LER ID=211.140.222.1, Serving ARR ID=211.136.10.1, Association ID=14>.
Upon completion of the MEF discovery and registration process, as shown in step S908, the data packet sent from the VM 41 to the client 53 will be directly transferred to the LER 12, which forwards the data packet to the LER 31 to which the client 53 is connected, and the LER 31 forwards the data packet to the client 53.
Then, at steps S909 and S910, the LER 12 sends the virtual machine binding update message to the LER 11 with which the VM 41 is lastly registered prior to registering with the LER 12 and to the ARR 1 of the area where the LER 12 is located, respectively.
The virtual machine binding update message sent to the LER 1 lincludes: <VMID=210.101.34.25, Target Router ID=211.140.111.1, Serving LER ID=211.140.222.1, Serving ARR ID=211.136.10.1, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1>.
The virtual machine binding update message sent to the ARR 1 includes: <VMID=210.101.34.25, Target Router ID=211.136.10.1, Serving LER ID=211.140.222.1, Serving ARR ID=211.136.10.1, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1>.
After receiving the virtual machine binding update message sent by the LER 12, the LER 11 knows that the VM 41 has been migrated from the LER 11 to the LER 12. Therefore, at step S911, the LER 11 updates its own virtual machine binding database to reflect the binding of the VM 41 to the LER 12.
Thereafter, as shown in step S914, the LER 11 forwards to the LER 12 the data packet received from the LER 31 to which the client 53 is connected and destined to the VM 41 in step 912, and the data packet is forwarded to the VM 41 by the LER 12 at step S916.
After receiving the virtual machine binding update message from the LER 12, the ARR 1 knows that the VM 41 is still within its serving area, and updates its own virtual machine binding database to reflect that the VM 41 has been migrated from the LER 11 to the LER 12, as shown in step S918.
Next, the ARR 1 sends the second virtual machine binding database advertisement message to all of the other ARRs that have queried the binding of the VM 41.
As described above, the ARR 3 has queried the binding of the VM 41. Therefore, at step S920, the ARR 1 sends to the ARR 3 the second virtual machine binding database advertisement message including: <Type Flag=4, VMID=210.101.34.25, Serving LER ID=211.140.222.1, Serving ARR ID=211.136.10.1, Number of Queries=1, Querying LER ID 1=213.140.111.1, Querying ARR ID 1=213.136.10.1>.
After receiving the second virtual machine binding database advertisement message, at step S922, the ARR 3 sends the first virtual machine binding database advertisement message to the LER 31. The first virtual machine binding database advertisement message includes: <Type Flag=3, VMID=210.101.34.25, Serving LER ID=211.140.222.1, Serving ARR ID=211.136.10.1, Number of Queries=0>.
After receiving the first virtual machine binding database advertisement message, the LER 31 knows that the VM 41 has been migrated from the LER 11 to the LER 12. Therefore, at step S924, the LER 31 updates its own virtual machine binding database to reflect the migration of the VM 41. Furthermore, the forwarding equivalence class of the data packet sent to the VM 41 is determined based on the IP address of the LER 12 with which the VM 41 is registered, at step S926, the data packet destined to the VM 41 are directly sent to the LER 12 instead of the LER 11 through the label switching path (LSP). That is to say, after the step S926, there is no necessary to forward the data packet from the LER 31 to the LER 12 via the LER 11.
In addition, step S925 is further comprised after step S924. At step S925, the LER 31 sends additional virtual machine binding update message to the LER 11, such that the LER 11 removes the binding record of the VM 41 from its virtual machine binding database.
The additional virtual machine binding update message can be sent through the BGP (Boundary Gateway Protocol) update message.
More specifically, the BGP update message can be extended to send the virtual machine binding update message.
For example, the additional virtual machine binding update message can be sent using MP_UNREACH_NLRI by defining a new <AFI(=A1), SAFI(=S1)> pair. The AFI is the address family identifier, and the SAFI is the subsequent address family identifier.
That is to say, MP_UNREACH_NLRI is extended to send the additional virtual machine binding update message.
Such extended MP_UNREACH_NLRI attribute is specifically represented as MP_UNREACH_VMB.
b illustratively shows the basic encoding format of MP_UNREACH_VMB.
As shown in
The VM Binding Update Extension field 520 has been described above in conjunction with
In the embodiment shown in
First, at step S1002, the VM 41 sends to the fourth LER (i.e. the LER 21) the MEF discovery message including: <Type=0, VMID=210.101.34.25, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1, Association ID=15>.
After receiving the MEF discovery message, the LER 21 knows that the VM 41 performs the inter-domain migration, because the Last ARR ID is different from the ID of the ARR of the area where the LER 21 is located. At step S1004, the LER 21 updates its own virtual machine binding database to reflect the binding of the VM 41 to the LER 21.
Next, at step S1006, the LER 21 sends to the VM 41 the MEF advertisement message including: <Type=1, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Association ID=15>.
Upon completion of the MEF discovery and registration process, as shown in step S1008, the data packet sent from the VM 41 to the client 53 will be directly transferred to the LER 21, which forwards the data packet to the LER 31 to which the client 53 is connected, and the LER 31 forwards the data packet to the client 53.
Then, at steps S1009 and S1010, the LER 21 sends the virtual machine binding update message to the LER 11 with which the VM 41 is lastly registered before registering with the LER 21, and to the ARR 2 of the area where the LER 21 is located, respectively.
The virtual machine binding update message sent to the LER 11 includes: <VMID=210.101.34.25, Target Router ID=211.140.111.1, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1>.
The virtual machine binding update message sent to the ARR 2 includes: <VMID=210.101.34.25, Target Router ID=212.136.10.1, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1>.
After receiving the virtual machine binding update message sent by the LER 21, the LER 11 knows that the VM 41 has been migrated from the LER 11 to the LER 21. Therefore, at step S1011, the LER 11 updates its own virtual machine binding database to reflect the binding of the VM 41 to the LER 21.
Thereafter, as shown in step S1014, the LER 11 forwards the data packet received from the LER 31 connected to the client 53 and destined to the VM 41 in step 1012 to the LER 21, which forwards the data packet to the VM 41 at step S1016.
After receiving the virtual machine binding update message from the LER 21, the ARR 2 knows that the VM 41 is migrated into its serving area, and as shown in step S1018, the ARR 2 sends to the ARR 1 the virtual machine binding update message which includes: <VMID=210.101.34.25, Target Router ID=211.136.10.1, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Last LER ID=211.140.111.1, Last ARR ID=211.136.10.1>.
Upon receiving this message, the ARR 1 knows that VM 41 has been migrated outside of its serving area, and as shown in step S1020, the ARR 1 updates its own virtual machine binding database to modify the serving LER of the VM 41 from the LER 11 to the LER 21 and modify the serving ARR of the VM 41 from the ARR 1 to the ARR 2.
Then, at step S1022, the ARR 1 sends the binding record about the VM 41 including the query log of the VM 41 to the ARR 2 through the second virtual machine binding database advertisement message. For example, the ARR 1 sends to the ARR 2 the second virtual machine binding database advertisement message including: <Type Flag=4, VMID=210.101.34.25, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Number of Queries=3, Querying LER ID 1=213.140.111.1, Querying ARR ID 1=213.136.10.1, Querying LER ID 2=211.142.109.1, Querying ARR ID 2=211.130.10.1, Querying LER ID 3=213.145.111.1, Querying ARR ID 3=213.130.10.1>.
After receiving the second virtual machine binding database advertisement message from the ARR 1, as shown in step S1024, the ARR 2 updates its own virtual machine binding database to add a triple <VMID=210.101.34.25, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1> and three query logs <Querying LER ID 1=213.140.111.1, Querying ARR ID 1=213.136.10.1>, <Querying LER ID 2=211.142.109.1, Querying ARR ID 2=211.130.10.1>, <Querying LER ID 3=213.145.111.1, Querying ARR ID 3=213.130.10.1> into its virtual machine binding database.
Then, at step S1026, the ARR 2 sends the second virtual machine binding database advertisement message to each of the ARRs that query the binding of the VM 41 (e.g., the ARR 3). The second virtual machine binding database advertisement message, for example, includes <Type Flag=4, VMID=210.101.34.25, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Number of Queries=1, Querying LER ID 1=213.140.111.1, Querying ARR ID 1=213.136.10.1>.
After receiving the second virtual machine binding database advertisement message, at step S1028, the ARR 3 sends to the LER 31 the first virtual machine binding database advertisement message which includes: <Type Flag=3, VMID=210.101.34.25, Serving LER ID=212.140.111.1, Serving ARR ID=212.136.10.1, Number of Queries=0>.
After receiving the first virtual machine binding database advertisement message, the LER 31 knows that the VM 41 has been migrated from the LER 11 to the LER 21. Therefore, at step S1030, the LER 31 updates its own virtual machine binding database to reflect the migration of the VM 41. The forwarding equivalence class of the data packet sent to the VM 41 is determined based on the IP address of the LER 21 with which the VM 41 is currently registered. At step S1032, the data packet destined to the VM 41 is directly sent to the LER 21 instead of the LER 11 through the label switching path (LSP). That is to say, after step S1032, there is no necessary to forward the data packet from the LER 31 to the LER 21 via the LER 11.
In addition, after step S1030, step S1031 is further comprised. At step S1031, the LER 31 sends to the LER 11 additional virtual machine binding update message as described above in conjunction with
The LER as shown in
As shown in
According to an embodiment of the present invention, when finding that the VMID contained in the MEF discovery message falls within the IP address range for supporting the migration of the virtual machines, the updating means updates its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER.
According to an embodiment of the present invention, the LER 11 further comprises: virtual machine binding update message sending means 1108 configured to send the virtual machine binding update message to the first area route reflector (ARR) of the area where the first LER is located, such that the first ARR can update its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER, and/or to send the virtual machine binding update message to the third LER with which the first virtual machine is recently registered prior to registering with the first LER, such that the third LER can update its own virtual machine binding database to reflect the binding of the first virtual machine to the first LER.
According to an embodiment of the present invention, the LER 11 further comprises: data packet forwarding means 1110 configured to forward the data packets received from the first virtual machine to the second LER to which the client is connected, and/or to forward, to the first virtual machine, the data packets received from the third LER with which the first virtual machine is lastly registered prior to registering with the first LER, and/or forward, to the fourth LER, the data packets received from the second LER to which the client is connected and destined to the first virtual machine. The data packet forwarding means forwards the data packets based on forwarding equivalence classes of the data packets, wherein the forwarding equivalence class of the data packet destined to the first virtual machine is determined, by an ingress LER for the data packets, based on the IP address of the LER with which the first virtual machine is registered, instead of the IP address of the first virtual machine itself.
According to an embodiment of the present invention, the LER 11 further comprises: virtual machine binding update message receiving means 1112 configured to receive the virtual machine binding update message from the fourth LER with which the first virtual machine is lastly registered after being registered with the first LER; and wherein the updating means is further configured to update its own virtual machine binding database to reflect the binding of the first virtual machine to the fourth LER.
According to an embodiment of the present invention, the LER 11 further comprises: virtual machine binding query message sending means 1114 configured to send the first virtual machine binding query message to the first ARR of the area where the first LER is located to obtain the binding of the second virtual machine, wherein the client connected to the first LER wishes to send the data packets to the second virtual machine; and virtual machine binding query advertisement message receiving means 1116 configured to receive the first virtual machine binding query advertisement message from the first ARR of the area where the first LER is located; and wherein the updating means 1104 is further configured to update its own virtual machine binding database to reflect the binding of the second virtual machine to the corresponding LER.
According to an embodiment of the present invention, the LER 11 further comprises: virtual machine binding database advertisement message receiving means 1118 configured to receive the first virtual machine binding database advertisement message from the first ARR of the area where the first LER is located; and wherein the updating means 1104 is further configured to update its own virtual machine binding database to reflect the migration of the second virtual machine between the LERs.
The ARR as shown in
As shown in
According to an embodiment of the present invention, the ARR 1 further comprises: virtual machine binding query message receiving means 1206 configured to receive the first virtual machine binding query message from the first LER, wherein the first virtual machine binding query message is intended to obtain the binding of the second virtual machine; and virtual machine binding query advertisement message sending means 1208 configured to send the first virtual machine binding query advertisement message to the first LER to notify the first LER of the binding of the second virtual machine to the corresponding LER.
According to an embodiment of the present invention, the ARR 1 further comprises: virtual machine binding query message sending means 1210 configured to send the second virtual machine binding query message to any other ARR to obtain the binding of the second virtual machine; and virtual machine binding query advertisement message receiving means 1212 configured to receive the second virtual machine binding query advertisement message from at least one of the any other ARR, the second virtual machine binding query advertisement message reflecting the binding of the second virtual machine to the corresponding LER.
According to an embodiment of the present invention, the virtual machine binding query message receiving means 1206 is configured to receive the second virtual machine binding query message from the second ARR, wherein the second virtual machine binding query message is intended to obtain the binding of the first virtual machine, and the second ARR is the ARR 3; and the virtual machine binding query advertisement message sending means is configured to send the second virtual machine binding query advertisement message to the second ARR to notify the second ARR of the binding of the first virtual machine.
According to an embodiment of the present invention, the ARR 1 further comprises: virtual machine binding database advertisement message sending means 1214 configured to send the first virtual machine binding database advertisement message to the first LER to notify the first LER of the migration of the second virtual machine between the LERs.
According to an embodiment of the present invention, the ARR 1 further comprises: virtual machine binding database advertisement message receiving means 1216 configured to receive the second virtual machine binding database advertisement message from at least one of the any other ARR, the second virtual machine binding database advertisement message indicating the migration of the second virtual machine between the LERs.
According to an embodiment of the present invention, the virtual machine binding database advertisement message sending means 1214 is configured to send the second virtual machine binding database advertisement message to the second ARR to notify the second ARR of the migration of the first virtual machine between the LERs.
According to an embodiment of the present invention, the ARR 1 further comprises: virtual machine binding update message sending means 1218 configured to send the virtual machine binding update message to the third ARR, wherein the virtual machine binding update message indicates that the first virtual machine is migrated from one LER in an area served by the third ARR to the first LER, and the third ARR is the ARR 2; and virtual machine binding database advertisement message receiving means 1216 configured to receive the second virtual machine binding database advertisement message from the third ARR, the second virtual machine binding database advertisement message indicating the query log about the first virtual machine.
According to an embodiment of the present invention, the virtual machine binding update message receiving means 1202 is further configured to receive the virtual machine binding update message from the fourth ARR, and the virtual machine binding update message received from the fourth ARR indicates that the first virtual machine is migrated from the first LER to one LER in the area served by the fourth ARR, the fourth ARR is the ARR 2; the updating means 1204 is further configured to update its own virtual machine binding database to reflect that the first virtual machine is migrated from the first LER to the one LER in the area served by the fourth ARR; and the virtual machine binding database advertisement message sending means 1214 is configured to send the second virtual machine binding database advertisement message to the fourth ARR to notify the fourth ARR of the query log about the first virtual machine.
It should be noted that in order to ease the understanding of the present invention, the above description has omitted some more specific technical details known to those skilled in the art but may be necessary to implement the present invention.
Those skilled in the art should also appreciate that the present invention is not limited to the above described steps, and the present invention also encompasses combination, or order change, etc. of the above described steps. The final scope of the present invention is defined by the appended claims.
Therefore, the above embodiments are chosen and described in order to explain the principles and practical application of the present invention, and to enable those skilled in the art to understand that, without departing from the essence of the invention, all such modifications and alterations will fall into protection scope of the invention defined by claims.
Furthermore, those skilled in the art will appreciate that the steps of the various methods described above may be implemented by a programmed computer. Here, some embodiments cover the program storage, which is machine or computer readable and encoded with machine executable or computer executable instruction program, wherein the instructions perform some or all of the steps of the above methods. The program storage may be magnetic storage medium such as magnetic disk or magnetic tape, hard disk driver or optical readable digital data storage medium. The embodiments also cover the computer programmed to perform the steps of the above methods.
Number | Date | Country | Kind |
---|---|---|---|
201110153072.6 | Jun 2011 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2012/001334 | 6/4/2012 | WO | 00 | 10/24/2013 |