The present disclosure generally relates to virtualized application clusters. In particular, a technique for managing deployment of a virtualized application cluster is described. The technique can be implemented as a method, a software solution, a hardware solution, or a combination thereof.
In computing, booting is the initial set of operations a computer system performs after its start. When a computer system boots via a network connection, the Dynamic Host Configuration Protocol (DHCP) is often used to gather an Internet Protocol (IP) address by the booting computer system. To this end, the computer system sends an initial DHCP request and queries another computer system, the DHCP server, for an IP address. When the DHCP server has a valid entry for the requesting computer system in its configuration database, it will send out a DHCP response with the IP address assigned to the requesting computer system.
The IP address provided by the DHCP server can be assigned randomly or based on a system identifier contained in the DHCP request. Often, a Media Access Control (MAC) address of the requesting computer system is used by the DHCP server to assign a specific IP address to it. To this end, a mapping between MAC addresses and IP addresses can be configured by an operator after the installation of the computer systems. The mapping can also be performed automatically. When, for example, the computer systems are part of a physical blade system with multiple blade servers, the MAC addresses of the blade servers can automatically be discovered or assigned according to their physical positions in a chassis or shelf.
In a virtualized environment, such as a virtualized application cluster with multiple virtual machines, the virtual “hardware” of the virtual machines cannot be based on physical parameters identifying the physical hardware (such as a position in a chassis). However, identifying parameters can be generated automatically at deployment time of the virtual machines. Each new virtual machine can be assigned a random MAC address when it is created. This also means that the MAC address cannot be entered in a configuration database of the DHCP server before the actual deployment of the virtual machine takes place.
In a virtualized environment, a DHCP server can therefore not easily recognize the MAC address or other DHCP options of its clients (i.e., the virtual machines). This fact makes it difficult to automate the deployment of new virtual machines in a virtual environment, even though virtual environments are suitable and actually intended to exploit automated procedures. This problem applies to both legacy application clusters that are ported to a cloud or virtualized environment, and to new application clusters that are designed to work in both virtualized and physical deployments.
A possible workaround for the initial deployment of a virtualized application cluster requires human intervention. After all virtual machines have been created, an administrator may edit the configuration database of a virtual DHCP server within the cluster and give it a list of MAC addresses that have been assigned to the virtual machines. However, this solution is not suitable for fully automated deployments. Also, it requires all virtual machines to be persistent, and it makes it difficult to increase the capacity of the cluster at a later point in time by adding new virtual machines to it because the required human intervention limits the opportunities for automatic scaling.
There is a need for a technique that permits an efficient deployment of virtual machines within a virtualized application cluster.
According to a first aspect, a method of operating a virtual machine within a virtualized application cluster is provided. The method comprises receiving basic booting information and booting a basic system environment using the basic booting information. The method also comprises determining, within the basic system environment, an identifier of the virtual machine and sending a message including the identifier of the virtual machine. Further, the method comprises receiving, in response to the message, booting information dedicated to the virtual machine, and booting a dedicated system environment using the dedicated booting information.
The basic booting information may be received responsive to a request message sent by the virtual machine. The request message may, for example, be a discovery message broadcasted by the virtual machine.
The identifier of the virtual machine may be determined in various ways. As an example, the identifier may be read from a descriptor accessible to the virtual machine. The descriptor may generally describe one or more properties of the virtual machine or of the virtualized application cluster including the virtual machine. The virtual machine may have access to the descriptor via a file containing the descriptor, or in any other manner. In one variant, a descriptor file is accessible to the virtual machine via a virtual drive comprising the descriptor file.
The method may further comprise receiving, together with the basic booting information, a preliminary network address for the virtual machine. The preliminary network address may be an IP address or any other Layer 3 address. The preliminary network address may be used by the basic system environment for communication. The communication may include the sending of the message with the virtual machine is identifier to an entity within or outside the virtualized application cluster.
The method may also comprise requesting, within the dedicated system environment, a dedicated network address. To this end, a request message may be sent using the preliminary network address. Further, the dedicated network address may be received at the virtual machine and used, by the dedicated system environment, for communication. The dedicated network address may have been statically configured prior to deployment of the virtual machine.
The booting information may define various items of information required by the virtual machine for performing one or more operations after its initial deployment.
The booting information may, for example enable the virtual machine to obtain the required software to assume a dedicated function within the cluster. The booting information may, for example, conform to RFC 2132 of the Internet Engineering Task Force (IETF).
As an example, the booting information may define an address of a boot server configured to provide one or more boot files to the virtual machine. Additionally, or as an alternative, the booting information may comprise one or more file paths to the one or more boot files (e.g., on the boot server). In one realization, a system controller within the cluster may also assume the role of the boot server. The boot server may generally be configured to provide the one or more boot files via one or more Trivial File Transfer Protocol (TFTP) messages.
The one or more boot files may comprise at least one of an operating system file, a kernel file and a configuration file. A configuration of the virtual machine may, for example, be defined in terms of memory resources and processing recourses allocated to the virtual machine. Unless otherwise noted, the statements made herein with respect to booting information may apply to both the basic booting information and the dedicated system information.
According to a further aspect, a method of operating a system controller in a virtualized application cluster is provided, wherein the cluster comprises at least one virtual machine. The method comprises sending basic booting information to the virtual machine, wherein the basic booting information defines a basic system environment. The method further comprises receiving a message from the virtual machine, wherein the message includes an identifier of the virtual machine. Based on the identifier, booting information dedicated to the virtual machine is determined. The dedicated booting information is then sent to the virtual machine.
The method may further comprise assigning a preliminary network address to the virtual machine and sending the preliminary network address together with the basic booting information to the virtual machine (e.g., within a single message). Alternatively, or in addition, a request for a dedicated network address may be received from the virtual machine. A dedicated network address associated with the virtual machine may be determined and then sent to the virtual machine. Determining the dedicated network address may be performed based on an association between dedicated network addresses on the one hand and virtual machine identifiers on the other hand. Such an association may be statically configured at the system controller.
At least one of the preliminary network address and the dedicated network address may be an IP address. It could alternatively be any other Layer 3 address.
The basic booting information may be sent responsive to receipt of a request message from the virtual machine. The request message may be a discovery message broadcasted by the virtual machine.
The method may also comprise associating a Layer 2 address with the identifier of the virtual machine. The Layer 2 address may be included in the request message (e.g., the discovery message) received from the virtual machine. As understood herein, a Layer 2 address may be a Media Access Control (MAC) address.
The system controller may maintain (e.g., establish, update, etc.) an association between virtual machine identifiers on the one hand and booting information dedicated to the virtual machines on the other hand. Such an association may be defined by a mapping. The corresponding association may also comprise the Layer 2 addresses.
The identifier of the virtual machine may globally or at least locally be unique. As an example, the virtual machine identifier may be unique among multiple virtual machines handled by one and the same system controller.
According to a further aspect, a method of operating a managing component of a virtualized application cluster is provided, wherein the cluster is to comprise a system controller and at least one virtual machine with a dedicated function. The method comprises deploying the system controller and providing the system controller with access to an association between virtual machine identifiers and virtual machine functions. The method further comprises determining a virtual machine identifier that is associated with the dedicated function of a virtual machine to be deployed. Still further, the method comprises deploying the virtual machine and statically configuring the virtual machine, at deployment, with the determined virtual machine identifier.
The function of a virtual machine may be defined as a role of the virtual machine within the cluster. As such, a specific function may be defined by a specific software package for the virtual machine.
In one variant each virtual machine identifier is associated with exactly one function. Additionally, or as an alternative, multiple virtual machine identifiers may be associated with the same function. The association may be defined by a mapping (i.e., in a table) or otherwise.
Deployment of the system controller and/or of the virtual machine may comprise the creation of one or more virtual hardware elements, such as a virtual network card or a virtual Electronically Erasable Programmable Read-Only Memory (EEPROM). In one variant, the managing component configures at least one of a firmware of the virtual network card, a Basic Input Output System (BIOS) and the virtual EEPROM of the virtual machine with the determined virtual machine identifier. As such, the managing component may a establish a uniqueness of the virtual machine in terms of its network card firmware, BIOS and/or virtual EEPROM.
The dedicated function of an individual virtual machine may define booting information dedicated to the virtual machine. The booting information, in turn, may define at least one of a address of a boot server configured to provide one or more boot files to the virtual machine and a file path to the one or more boot files as explained above.
The system controller may itself be deployed as a virtual machine within the cluster.
In some implementations, the system controller may provide services (e.g., DHCP services) for one or more of the other virtual machines within the cluster.
The virtual machine identifier may be a Layer 2 address of the virtual machine or may be different from the Layer 2 address of the virtual machine. In the latter case, the virtual machine identifier may be a Layer 3 or higher layer address or any operator-defined item of information.
The method may further comprise reading a descriptor of the virtualized application cluster and deploying at least one of the system controller and the virtual machine in accordance with the descriptor. The descriptor may define one or more parameters of the virtualized application cluster and may be provided in the form of a file or via an operator setting. In one variant, the virtual machine identifier is determined from the descriptor. As such, the descriptor may define one or more virtual machines in terms of their associated identifiers. Also the function of an individual virtual machine may be defined in the descriptor. As such, the descriptor may define the association between the virtual machine identifiers and the virtual machine functions that will also be made available to the system controller.
According to a still further aspect, a method of operating a virtual machine within a virtualized application cluster is provided. The method comprises determining a virtual machine identifier that has been statically configured at deployment of the virtual machine. The method further comprises sending a request message for booting information, wherein the request message includes the virtual machine identifier.
The request message may be sent to a system controller of the cluster or any virtual or physical component (e.g., a switch) located between the virtual machine and the system controller.
The method further comprises receiving the booting information responsive to the request message. As explained above, the booting information defines at least one of an address of a boot server configured to provide one or more boot files to the virtual machine and a file path to the one or more boot files. The one or more boot files may comprise at least one of an operating system file, a kernel file and a configuration file, as also stated above.
In one variant, the request message includes a Layer 2 address of the virtual machine in addition to the virtual machine identifier. The request message may be a discovery message broadcasted by the virtual machine.
Still further, a method of operating a switch for a virtualized application cluster is provided, wherein the cluster comprises a system controller and at least one virtual machine. To each virtual machine a first identifier and second identifier are assigned, and the switch has access to information associating the first and second identifiers. The method comprises receiving, from a virtual machine, a message comprising the first identifier assigned to the virtual machine and determining, based on the association of first and second identifiers, the second identifier assigned to the virtual machine. The method further comprises including the second identifier in the message and sending the message with the second identifier to the system controller.
The switch may be a virtual (e.g., software) component or a physical component. As understood herein, the term switch also encompasses routers and similar network components capable of performing identifier translation services.
The method may further comprise receiving, from the system controller, a message comprising the second identifier, including the first identifier in a message, and sending the message with the first identifier to the virtual machine. As such, the switch may be configured for a bi-directional communication between the system controller and the virtual machine.
The message received from the system controller may comprise booting information for the virtual machine. The booting information may define at least one of an address of a boot server configured to provide one or more boot files to the virtual machine and a file path to the one or more boot files. The content of exemplary boot files has already been explained above.
The second identifier may be included in the message in various ways. As an example, the first identifier may be substituted with the second identifier so that the out-going message includes only a single (the second) identifier. Alternatively, the second identifier may be added to the message such that the outgoing message comprises both the first identifier and the second identifier. Similar considerations apply to the other communication direction in which the first identifier is included in the message.
The first identifier may have been dynamically assigned to the virtual machine upon deployment of the virtual machine. Such an assignment may have been performed by a managing component of the cluster as explained above (e.g., via a configuration of a network card firmware, a BIOS and/or a virtual EEPROM of the virtual machine). The second identifier may have been statically configured at the system controller. Such a configuration may take place via the managing component of the cluster. The second identifier may be configured at the system controller together with an associated function of the virtual machine and/or associated booting information as explained above.
As least one of the first identifier and the second identifier may be a network address, such as a layer 2 address. One of the first identifier and the second identifier may also be different from a network address. Especially in the latter case, a deep packet inspection technique may be applied in connection with processing of the second identifier (e.g., in connection with reading the second identifier or including the second identifier in the message).
The method performed by the switch may also comprise receiving information associating the first and second identifiers. The information may take the form of a table or any other data structure. The association may define a one-two-one relationship between the first identifiers and second identifiers. In one variant, the first identifier and the second identifiers are each unique.
According to a still further aspect, a method of operating a managing component of a virtualized application cluster is provided, wherein the cluster is to comprise at least one virtual machine. To each virtual machine a first identifier and a second identifier are assigned. The method comprises determining the first identifier assigned to the virtual machine. The method further comprises deploying the virtual machine and statically configuring the virtual machine, at deployment, with the determined first identifier. Still further, the method comprises configuring a switch interfacing the virtual machine with information associating the first and second identifiers.
The method may further comprise deploying a system controller of the cluster and providing the system controller with access to information associating the second identifiers and virtual machine functions. As explained above, the system controller may itself be a virtual machine within the cluster.
In one variant, the switch is a virtual switch. In this variant, the method may further comprise deploying the virtual switch, wherein the virtual switch is configured at deployment. In another variant the switch is a physical switch. In this variant, the method may further comprise sending a configuration message with the information associating the first and second identifiers to the physical switch.
Also provided is a computer program product comprising program code portions for performing the steps of any methods and method aspects disclosed herein when the computer program product is executed on at least one computing device. It will be appreciated that the computer program product may also be executed in a distributed manner on multiple computer devices. The computer program product may be stored on a computer-readable recording medium, such as a semiconductor memory,
DVD or CD-ROM. The computer program product may also be provided for download via a communications network.
Still further, a virtual machine within a virtualized application cluster is provided, wherein the virtual machine is configured to receive basic booting information, to boot a basic system environment using the basic booting information, to determine, within the basic system environment, an identifier of the virtual machine, to send a message including the identifier of the virtual machine, to receive, in response to the message, booting information dedicated to the virtual machine, and to boot a dedicated system environment using the dedicated booting information.
Further provided is a system controller in a virtualized application cluster, wherein the cluster comprises at least one virtual machine. The system controller is configured to send basic booting information to the virtual machine, wherein the basic booting information defines a basic system environment, to receive a message from the virtual machine, wherein the message includes an identifier of the virtual machine, to determine, based on the identifier, booting information dedicated to the virtual machine, and to send the dedicated booting information to the virtual machine.
Also provided is a managing component of a virtualized application cluster, wherein the cluster is to comprise a system controller and at least one virtual machine with a dedicated function. The managing component is configured to deploy the system controller and to provide the system controller with access to an association between virtual machine identifiers and virtual machine functions, to determine a virtual machine identifier that is associated with the dedicated function of the virtual machine to be deployed, and to deploy the virtual machine and to statically configure the virtual machine, at deployment, with the determined virtual machine identifier.
Moreover, a virtual machine within a virtualized application cluster is provided. The virtual machines is configured to determine a virtual machine identifier that has been is statically configured at deployment of the virtual machine, and to send a request message for booting information, wherein the request message includes the virtual machine identifier.
Also provided is a switch for a virtualized application cluster, the cluster comprising a system controller and at least one virtual machine. To each virtual machine a first identifier and a second identifier are assigned, wherein the switch has access to information associating the first and second identifier. The switch is configured to receive, from a virtual machine, a message comprising the first identifier assigned to the virtual machine, to determine, based on the association of the first and second identifiers, the second identifier assigned to the virtual machine, to include the second identifier in the message, and to send the message with the second identifier to the system controller.
Further provided is a managing component of the virtualized application cluster, wherein a cluster is to comprise at least on virtual machine. To each virtual machine a first identifier and a second identifier are assigned. The managing component is configured to determine the first identifier assigned to the virtual machine, to deploy the virtual machine and to statically configure the virtual machine, at deployment, with the determined first identifier, and to configure a switch interfacing the virtual machine with information associating the first and second identifiers.
The virtual machine, the switch, the system controller and the managing component may additionally be configured to perform any of the methods and method aspects presented herein. Those methods and method aspects may be performed by an associated processor, optionally in combination with an associated interface. Any interface may be realized in the form of software, in the form of hardware, or as a software/hardware combination.
Also provided is a virtualized computing system comprising one or more of the virtual machine, the switch, the system controller and the managing component presented herein. The virtualized application cluster may represent a network node of a telecommunications network. In such a realization, the virtual machines of the virtualized application cluster may run different network node applications.
It will appreciated that the above methods and entities (i.e., system controller, managing component, virtual machine and switch) may be combined as needed. Moreover, it will be appreciated that any statements made with respect to one aspect also relates to all the other aspects unless specifically excluded.
Further aspects, details and advantages of the present disclosure will become apparent from the following description of exemplary embodiments in conjunction with the accompanying drawings, wherein:
In the following description of exemplary embodiments, for purposes of explanation and not limitation, specific details are set forth, such as particular methods, functions and procedures, in order to provide a thorough understanding of the technique presented herein. It will apparent to one skilled in the art that this technique may be practiced in other embodiments that depart from these specific details. For example, while the following embodiments will primarily be described with respect to exemplary protocols (e.g., DHCP, TFTP, etc.) and particular identifier types (e.g., MAC addresses, etc.), it will be evident that the present disclosure can also be practiced using different protocols and different identifiers.
Moreover, those skilled in the art will appreciate that the methods, functions and procedures explained herein may be implemented using software functioning in conjunction with one or more programmed processors, an Application Specific Integrated Circuit (ASIC), a Digital Signal Processor (DSP) or general purpose computers. It will also be appreciated that while the following embodiments will primarily be described in the context of methods and virtual or physical devices, the present disclosure may also be embodied in a computer program product which can be loaded to run on a computer or a distributed computer system comprising one or more processors and one or more memories functioning as storage, wherein the one or more memories are configured to store one or more programs that realize the technique presented herein when the one or more programs are executed on one or more computers.
The following embodiments describe aspects in connection with the deployment of one or more virtual machines in a virtualized application cluster. The virtual machines typically assume dedicated functions, or roles, within the cluster. Those functions rely on dedicated software and/or hardware configurations that are defined in initial booting procedures. The booting procedures may involve request/response messaging with a system controller, for example in an initial discovery phase to request IP or other network addresses by the virtual machines. In such requests, the virtual machines may signal their identifiers, such as their MAC addresses.
When booting a new virtual machine that is part of a clustered application, the systerm controller of that cluster may get requests from multiple virtual machines but it often does not know anything about the virtual machines issuing these requests (e.g., it sees unknown MAC addresses). As a result, the system controller cannot infer what kind of software should be installed on the virtual machines, and it cannot even be sure that a particular virtual machine should be part of the cluster at all, or if the request was received from a virtual machine that was not supposed to boot on a specific subnet (e.g., the one associated with the system controller).
This situation can cause problems because although all virtual machines may start booting in the same way, they may need to have different characteristics which require that each virtual machine gets exactly the function, or role, (and the corresponding software) that was allocated to it. Exemplary characteristics that can differ from one virtual machine to another include one or more of the amount of memory, the number of virtual Central Processing Unit (CPU) cores, the number of virtual network cards and the way they are connected to the virtual switches, and so on. If the system controller cannot assign the right function (and software) to the right virtual machine, then the cluster may fail to boot or fail to run correctly.
Some of the following embodiments are thus directed to deploying a virtualized application cluster in a cloud and making the virtual machines in the clusters distinguishable on the basis of information available to the system controller. The system controller has to know how to assign the appropriate booting information (e.g., in terms of an Operating System, OS, kernel and other software) to each virtual machine. As said, in a virtual environment, the MAC addresses of the virtual machines may not be known in advance by the system controller, so the system controller has to be enabled to recognize the virtual machines belonging to the cluster. Various approaches for gaining such knowledge will now be described in more detail. This knowledge can also be useful after an initial deployment of the cluster, when new virtual machines are added via automatic or manual scaling, or in general for all lifecycle management operations on virtual machines belonging to that cluster.
As illustrated in
The managing component 30 of the virtualized computing system 10 may take various forms. As an example, the managing component 30 may be a cluster manager. Since virtualized environments are sometimes also referred to as “clouds”, the cluster manager is sometimes also referred to as cloud manager, or cloud orchestrator.
The managing component 30 is in one variant configured to deploy the cluster 20, and in particular the system controller 40 and the one or more virtual machines 50. It will be appreciated that the managing component 30 may be configured to deploy, and manage, multiple such clusters 20. Cluster deployment by the managing component 30 may be performed on the basis of control information received in the form of the file 60 or otherwise (e.g, via an operator setting). The managing component 30 can be operated for the initial deployment of the cluster 20 with the virtual machines 50, or when an additional virtual machine 50 is added a later point in time to the cluster 20 (e.g., to provide elasticity or application scaling).
The managing component 30 can generally be realized in the form of a software entity that provides an abstraction layer above a virtualization layer comprising the virtualized application cluster 20. As such, external applications requesting services provided by the cluster 20 may only see the abstraction layer. The abstraction layer with the managing component 30 may manage accesses to the underlying physical infrastructure and physical resources.
The system controller 40 within the virtualized application cluster 20 may be a software entity. Moreover, the system controller 40 may be a dedicated virtual machine itself. As such, the system controller 40 may be located together with the virtual machines 50 in the virtualization layer.
The virtual machines 50 may be realized in the form of software entities without disc space, which will be loaded only at run time. Since the virtual machines 50 at initial deployment will not have any software or operating system thereom, they rely on the system controller 40 for loading the required software and other configuration at boot time depending on their function within the cluster 20.
The virtual machines 50 that form the virtualized application cluster 20 will, upon booting from the system controller 40 or otherwise, be given various functions with the appropriate software and configuration. Once the cluster 20 is ready (e.g., all virtual machines 50 have fully been booted), it will typically be visible to other systems as a single large system instead of a collection of individual virtual machines.
The virtual machines 50 are in one variant deployed using control information conforming to the Open Virtualization Format (OVF). OVF is an open standard defined by the Distributed Management Task Force (DMTF) and used for packaging and distributing virtual applications by way of OVF files (see reference numeral 60 in
An OVF file is a descriptor in XML (Extensible Markup Language) format which describes the virtual hardware requirements and characteristics of the different virtual machines 50 forming the virtualized application cluster 20. As will be appreciated, there exist several other proposed standards and proprietary formats for descriptors.
The descriptor is used as input for the managing component 30, such as a cloud manager. The descriptor is read by the cloud manager and controls the cloud manager when deploying the set of virtual machines 50 fulfilling the requested functions or services.
For the booting procedure, including the initial installation of software in the virtualized environment shown in
Thus, DHCP may not only used to assign IP addresses but also to pass booting information (and other information about available services) to a requesting virtual machine 50 that needs to be booted. This information can include, but is not limited to, the addresses of routers, time servers, TFTP boot servers and file paths. Based on these parameters, the virtual machine 50 fetches all required data and software for the boot process and executes the boot process.
In the exemplary implementation of
The general boot process for the virtualized application cluster 20 in some or all the embodiments described herein can in one variant be described with the example of a Preboot Execution Environment (PXE) boot process of a single virtual machine (VM) 50. In the following, it will be assumed that there is a running DHCP server in the same Layer 2 domain as the booting virtual machine 50:
It can be easily understood that the booting information (in particular the TFTP server address and the path to the initial OS kernel) contained in the DHCP response determines the initial software loaded by the virtual machine 50. Therefore, this DHCP messaging may in one implementation be used to define the function, or role, the virtual machine 50 should execute in the virtualized application cluster 20 after it is booted. Details thereof will be described below.
The managing component 30 comprises a processor 32 as well as a first interface 34 coupled to the virtual machine 50, a second interface 36 coupled to the switch 70, and a third interface 38 coupled to the system controller 40. As will be appreciated, the second interface 36 is optional in case the switch 70 is not present.
The system controller 40 comprises a processor 42, a first interface 44 coupled to the interface 38 of the managing component 30 as well as a second interface 46 coupled to the switch 70. In case the switch 70 is not provided, the interface 46 of the system controller 40 may directly be coupled to the virtual machine 50. In other configurations, the interface 46 may couple the system controller 40 to both the virtual machine 50 and the switch 70.
The virtual machine 50 comprises a processor 52 as well as a first interface 54 coupled to the interface 34 of the managing component 30 and a second interface 56 is coupled to the switch 70. Again, when the switch 70 is not present, the interface 56 may directly be coupled to the system controller 40. It will be appreciated that the cloud 20 may comprise multiple virtual machines 50 as shown in
The optional switch 70 comprises a processor 72 as well as a first interface 74 coupled to the interface 56 of the virtual machine 50, a second interface 76 coupled to the interface 36 of the managing component 30, and a third interface 78 coupled to the interface 46 of the system controller 40.
The processors 32, 42, 52 and 72 are generally configured to perform the processing steps described herein, such as booting steps, determining steps, deploying steps including steps, configuring steps, and so on. The interfaces 34, 36, 38, 44, 46, 54, 56, 74, 76 and 78 are generally configured to perform the sending and receiving steps described herein.
Any interface illustrated in
The following embodiments partially assume that there is a communication protocol in place between the interfaces illustrated in
The communication protocol may, for example, be based on any message queue protocol or any protocol suitable for sending notifications. In one implementation, the Hypertext Transfer Protocol (HTTP) can be used as communication, or transport, protocol (e.g., for REST-style requests to a predefined port number on one of the components). In another realization, a publish/subscribe mechanism could be used by which one component connects to the other component.
Embodiments of three operational modes of the virtualized computing system 10 illustrated in
The signaling illustrated in
Based on the control information included in the file 60 the managing component 30 first deploys the system controller 40 as a virtual machine within the cluster 20 (step 402). As understood herein, the deployment of a virtual machine may include the installation of one or more virtual hardware elements (such as a virtual network card) for each virtual machine to be created.
After the system controller 40 has been deployed by the managing component 30, the managing component 30 provides the system controller 40 with access to an association between virtual machine identifiers and virtual machine functions. An exemplary association (in the form of a mapping table) installed at the system controller 40 by the managing component 30 is illustrated in
The booting information may conform to RFC 2132 and comprise an address of a boot server that is configured to provide one or more boot files. Furthermore, the booting information provides a file path and a file name for each of a kernel file and a configuration file. The kernel file includes an operating system for the virtual machine 50 and the configuration file configures the virtual machine 50 with respect to its specific function within the cluster 20.
In the exemplary table illustrated in
As shown in
As also illustrated in
Once the system controller 40 has been deployed and been provided with a table as illustrated in
The managing component 30 has various options for configuring a specific virtual machine 50. As an example, the firmware of a virtual network card of the virtual machine 50 may be configured to include the virtual machine identifier. Additionally, or as an alternative, one or more of a BIOS and a virtual EEPROM of that virtual machine 50 may be configured with the virtual machine identifier. The configuration of the virtual machines 50 by the managing component 30 is static and performed at deployment time (step 406).
In the implementation illustrated in
As discussed above, the identifiers defined in the OFV file 60 are associated with dedicated functions of the virtual machines to be deployed (see
In the exemplary scenario illustrated in
After a specific virtual machine 50 has been deployed, it performs a PXE boot process as discussed above, or any other boot process, to obtain the operating system and configuration information required for performing its dedicated function within the cluster 20. To this end, the virtual machine 50 initially has to determine the identifier that has been statically configured at deployment time (step 408). As explained above, the virtual machine 50 may determine its identifier configuration from the firmware of its virtual network card, its BIOS or its virtual EEPROM.
Once the virtual machine 50 has determined its identifier, it sends a request message for booting information to the system controller 40 (step 410). The request message includes the virtual identifier. In a PXE boot process, the request message may be a DHCP request message that is sent by the virtual machine 50 to a broadcast address.
The DHCP request message comprises a source MAC address together with the identifier assigned to the virtual machine 50. The source MAC address may in one variant be autonomously generated by the virtual machine 50 (e.g., based on a random number).
Since the system controller 40 is configured to be of the same Layer 2 domain like the virtual machines 50, the system controller 40 will receive the DHCP request messages broadcasted by the virtual machines 50 (together with the associated identifier and MAC address of an individual virtual machine 50).
Upon receipt of the DHCP response message with the proper IP address and the booting information required for fulfilling its dedicated function, the virtual machine 50 may continue the boot process as explained above with respect to an exemplary PXE scenario.
It can be appreciated from
What matters to the virtual machine 50 is, of course, the booting information. The “function” column in
With respect to
In a first variant, the virtual machines 50 are also deployed as discussed above with reference to
After an individual virtual machine 50 has been deployed and configured with its unique identity, it performs a PXE-type or other boot process. During that boot process, it sends a generic request message to the system controller 40 (see step 904).
As an example, a generic DHCP request message may be broadcasted by the virtual machine 50 in this regard.
The initial request message will contain the source MAC address of the virtual machine 50 as explained above, but will not (yet) contain the identifier of the virtual machine 50 as the virtual machine 50 is not yet configured to process the OVF file received from the managing component 30.
The system controller 40, which is again part of the same Layer 2 domain as the virtual machines 50, will receive the broadcasted DHCP request message. However, since that message does not contain any virtual machine identifier, and since the source MAC address contained in the message is initially unknown to the system controller 40, the system controller 40 cannot determine the booting information required for the requesting virtual machine 50. Specifically, the table of
For this reason, the system controller 40, upon receipt of the generic DHCP request message in step 906, first assigns a preliminary IP address to the requesting virtual machine 50 and selects basic, or generic, booting information. In step 908, the pre-liminary IP address and the basic booting information are sent to the requesting virtual machine 50. The preliminary IP address enables the virtual machine 50 to use the Transport Control Protocol (TCP)/IP stack. The basic booting information defines a file path to a generic system kernel and points to a boot server. As explained above, in one variant the system controller 40 itself may be configured as a boot server (e.g., as a TFTP server). The generic system kernel provides a small operating and file system with minimal functionality to the virtual machine 50 so that it is enable a to execute simple procedures.
The basic booting information is received by the virtual machine 50 in step 910. The virtual machine 50 then, in step 912, uses the basic booting information to boot a basic system environment that comprises the minimal operating and file system. The basic system environment booted in step 912 is eqiupped with processing logic that permits the virtual machine 50 to read the OVF file received from the managing component 30. As an example, a virtual CD-ROM drive may have been attached to the virtual machine 50 at deployment, wherein that drive contains the associated OVF file and can be accessed within the basic system environment. In this way, the virtual machine 50 determines, within the basic system environment, its identifier (e.g., “PL-01”) as defined in the OVF file 60 (step 914).
Since the virtual machine 50 has been provided with the basic system environment and has an IP address assigned to it, the virtual machine 50 can send a further request message in step 916. That message includes the identifier of the virtual machine 50 in order to obtain booting information dedicated to the virtual machine 50 in terms of the function the virtual machine 50 is to assume within the cluster 20. Based on the preliminary IP address, the virtual machine 50 may use any protocol based on TCP/IP for the messaging in step 916. As an example, HTTP, TFTP or FTP may be used.
In the present implementation, it will be assumed that the message sent by the virtual machine 50 in step 916 is again received by the system controller 40 in step 918. Since the request message includes the identity of the virtual machine 50 (e.g., “PL-01”), the system controller may consult locally available association information, such as the table of
The dedicated booting information sent by the system controller in step 922 is received by the virtual machine 50 in step 924. Based on the booting information received in step 924, the virtual machine 50 can then boot its dedicated system environment for its specific function within the cluster 20 (e.g., “Payload”) in step 926 as explained above.
In certain cases, the association information maintained by the system controller 40 includes a dedicated IP address for each virtual machine 50 that is different from the preliminary IP address assigned earlier (see
The initial steps performed in connection the signaling embodiment illustrated in
Deviating from the embodiments above, in the present embodiment each virtual machine 50 is associated with two dedicated identifiers. One or both of the identifier associated with a particular virtual machine 50 may take the form of an MAC address. In some implementations, at least one of the identifiers may also be different from a network address and take a form similar to the identifiers discussed above (e.g., “PL-01”).
The managing component 30 is configured to determine, for an individual virtual machine 50 to be deployed, a first identifier assigned to that virtual machine (step 1102). The first identifier may be determined from a descriptor as the file 60.
Then, in step 1104, the managing component 30 deploys the virtual machine 50 and statically configures the virtual machine at deployment, with the first identifier determined in step 1102. In step 1104, the managing component 30 may configure the virtual machine 50 with a dedicated MAC address, or, alternatively, with a dedicated identifier as discussed above with reference to
In a further step 1106, the managing component 30 configures the switch 70 with information associating the first and second identifiers of each virtual machine 50 to be deployed. In one variant, each switch 70 is configured to access a table that defines a one-to-one mapping between first and second identifiers for multiple virtual machines 50. The first identifiers and the second identifiers are each unique to ensure that the individual virtual machines 50 are distinguishable via both the first identifiers and the second identifiers.
The manging component 30 may further provide the system controller 40 with access to information associating the second identifiers and virtual machine functions. To this end, the system controller may be provided access to a table similar to the one illustrated in
After its deployment, each virtual machine 50 performs a PXE-type or other booting procedure. In that booting procedure, the virtual machine 50 will send a DHCP request message with its statically configured first identifier (e.g., its MAC address) towards the system controller 40. The messaging between the virtual machine 50 and the system controller 40 is intercepted by the switch 70. Thus, in step 1108, the switch 70 receives the DHCP request message sent by the virtual machine 50. The switch 70 analyzes the received message to determine both the first identifier included therein and also determines the associated second identifier of the same virtual machine 50 (step 1110). For this purpose the switch consults its pre-configured table associating the first and second identifiers of the virtual machines 50.
In the further step 1112, the switch 70 includes the second identifier of the requesting virtual machine 50 thus determined in the message. As an example, the switch 70 may replace the first MAC address in the DHCP request message received from the virtual machine 50 with the second MAC address (or other identifier) the system controller 40 expects to see from that virtual machine 50 (see
Depending on efficiency configurations, the switch 70 can be configured to either re-write the MAC address (or other identifier) in all traffic going through it, or to do so only for DHCP request and response messaging.
s The system controller 40 may return the booting information either directly to the requesting virtual machine 50 or via the switch 70. In case the messaging from the system controller 40 to the virtual machines 50 runs through the switch 70, the switch 70 may perform its translation function in the opposite direction (i.e., include the first identifier in the message received from the system controller 40 prior to forwarding it to the associated virtual machine 50).
In case additional virtual machines 50 are added at a later point in time, or if an existing virtual machine 50 is removed from the cluster 20, the managing component 30 may inform the switch 70 accordingly. The switch 70 may thus update the association of identifiers.
As has been explained above, the translation function of the switch 70 may in one variant be based solely on MAC addresses as first and second identifiers. In another implementation, the switch 70 may translate an MAC address received from a virtual machine 50 into a unique identifier different from a network address, such as “PL-01” (and vice versa). In such a case the unique identifier need not be kept in the virtual machine 50 (e.g., in the firmware of the virtual network card as explained above), but in the switch 70. The processing capabilities of the switch 70 in this implementation cannot be limited to Layer 2 processing, but also require Layer 3 packet inspection capabilities so as to parse and modify the DHCP requests.
As has become apparent from the above description of exemplary embodiments, the technique presented herein permits a deployment of clustered applications in a cloud environment and a booting without requiring manual intervention. The technique also facilitates an increase or decrease of a cluster size by adding or removing virtual machines without manual intervention.
In certain variants, unique identifiers (e.g., MAC addresses) can be dynamically assigned to the virtual machines when they are created, instead of requiring the identifiers (e.g., MAC addresses) to be static and pre-configured. This approach is useful to allow two or more application clusters of the same type to be deployed (e.g., in the same network) without having conflicting identifiers (e.g., conflicting MAC addresses).
The technique presented herein can be useful for legacy application clusters that are to be ported to a cloud or virtualization environment and for new application clusters that are designed to work in both virtualized and physical deployments.
Modifications of the disclosed embodiments will come to mind to one skilled in the art having the benefit of the teachings presented in the foregoing description and the associated drawings. Therefore, it is to be understood that the present invention is not to be limited to the specific embodiments disclosed herein, and that modifications are intended to be included within the scope of this disclosure. Although specific terms may be employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2014/052491 | 2/7/2014 | WO | 00 |