Server clustering is a common method used to expand availability of applications and services to clients. Servers in a cluster function together and can work simultaneously under a single IP address. An organization can add or remove servers from a cluster based on consumer demand. Creating and modifying server clusters has become dynamic with the use of virtual machines (“VMs”). VMs can be installed, uninstalled, and migrated across physical servers in a network.
Server clustering can require that the VMs in the cluster be running the same operating system (“OS”) or image. Current methods for creating and managing server clusters require that the image used in the management interface be selected from a set of preselected image files. For example, when assigning a single image to a cluster in VMWARE's VSPHERE LIFE CYCLE MANAGER (“VLCM”), the only available option to pick an image during cluster creation is to select the image from a depot. The depot must be prepopulated with images prior to creating the cluster. VMWARE and other organizations publish official depots with host images that are available online. However, this option is not available for images in air-gapped environments because the host is isolated or otherwise not accessible to other server clusters. To be able to use the image of an air-gapped host, an administrator (“admin”) must manually find and download the desired image file. Only then can the image file be used for single use or uploaded into a depot like the VLCM depot.
As a result, a need exists for extracting image files from hosts and applying the image to new or existing server clusters.
Examples described herein include systems and methods for providing a Graphical User Interface (“GUI”) for applying an existing server image to a server cluster. The GUI can be part of an application for managing server clusters that is hosted by an application server. Actions described herein as being performed by the GUI can be performed by the corresponding application or application backend on the application server rather than the GUI itself.
The GUI can provide options for creating a server cluster based on a single image. As used herein, the term “image” can refer to an OS, any executables in the OS, and any data files related to programs installed on the OS. Two such options for creating the server cluster can allow the user to select an image already running on a host. A first option can allow the user to pick an image from a host that is part of an inventory of known hosts in a system. As used herein, these known hosts are referred to as “existing hosts.” If the user selects this option, the GUI can present a list of hosts that the user can choose from. When the user selects a host, the application server can extract or import the host's image and create a new server cluster in which all the hosts run the imported image.
A second option can allow a user to extract an image from a host not in the inventory of known hosts. As used herein, these unknown hosts are referred to as “new hosts.” If the user selects this option, the GUI can prompt the user to provide an address for the new host, such as an Internet Protocol (“IP”) address or fully qualified domain name (“FQDN”). The GUI can also prompt for access credentials, such as a username and password. The application server can use the new host's address and access credentials to retrieve an image file from the new host. The application server can then create a server cluster with all the hosts running the new host's image. The GUI can include an option that allows the user to make the new host available as an existing host. In other words, when creating a new cluster in the future, the new host can appear in the list of existing hosts for image extraction.
The GUI can allow the user to modify an image before applying the image to the new server cluster. For example, the GUI can include a feature that allows the user to add or remove components of the image. As an example, the user can add, remove, or change drivers, executables, or applications. After the user confirms the changes, the application server can create the server cluster with the modified image. The GUI can also include a feature that allows the user to add the selected host to the server cluster.
In addition to creating a new cluster based on an existing image, the GUI can allow a user to add new hosts to an existing cluster with an existing image and apply an existing image to an existing cluster. For example, the user can select an option for adding hosts to a cluster, and the GUI can allow the user to choose to use a new image, an image from an existing host, or an image from a new host for the new hosts. If the user chooses one of the options for using an existing image, the user can either select an existing host or provide information for a new host, similar to the process for creating a new server cluster described previously. The application server can then create new hosts for the server cluster using the extracted image. The GUI can also allow the user to apply the extracted image to the hosts already in the cluster. The user can also add the selected host to the cluster, if desired.
The examples summarized above can each be incorporated into a non-transitory, computer-readable medium having instructions that, when executed by a processor associated with a computing device, cause the processor to perform the stages described. Additionally, the example methods summarized above can each be implemented in a system including, for example, a memory storage and a computing device having a processor that executes instructions to carry out the stages described.
Both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the examples, as claimed.
Reference will now be made in detail to the present examples, including examples illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
Systems and methods are described for providing a GUI for applying an existing image to a server cluster. The existing image can come from an existing host or new host to a system. For an existing host, using the GUI a user can select a host from a list of existing hosts. A server can import an image file for the selected host and create a server cluster with the image file. For a new host, using the GUI the user can input an address and access credentials for the new host. The server can use the address and access credentials to import an image file and create a server cluster. The GUI can also allow the user to view and modify components of the imported file before creating the server cluster. Using the GUI, the user can also apply an existing image to hosts in an existing server cluster or use an existing image to add new hosts to a cluster
References are made throughout to a GUI for applying server images to new and existing server clusters. The GUI can be a front-end interface of an application that a user can interact with for managing server clusters. The application can be hosted by one or more servers or a group of servers (referred to throughout as the “application server”), including multiple servers implemented virtually across multiple computing platforms. For example, the application can be hosted by a web server, and a user can access the application through a web browser. Alternatively, the application as a whole, the GUI, or other components of the application may be installed directly on a user's device. Actions described herein as being performed by the GUI can be performed by the corresponding application or service rather than the GUI itself.
To access the GUI, a user can launch an application for managing servers, and the application can cause the GUI to be displayed on the user's device. The GUI can include various options for managing servers, including, for example, creating a server cluster. If the user selects an option for creating a server cluster, then the GUI can present a new cluster window that includes configuration options for the new server cluster. The new cluster window can allow the user to assign a name to the new cluster and designate where the cluster will be hosted. For example, if an organization has multiple data centers, then the user can choose which data center will host the server cluster.
The GUI can include an option for managing all hosts in the cluster with a single image. As used herein, the term “image” can refer to a copy of a server, or more specifically its operating system. Selecting this option can cause the GUI can present options for setting up the cluster's image. For example, the GUI can display options for composing a new image, importing an image from an existing host, and importing an image from a new host.
At stage 120, the GUI can receive a selection for creating a server cluster from an existing host. The GUI can receive the selection and inform the application server. In response, the application server can retrieve a list of existing hosts in the system that are available for host seeding. As used herein, the term “existing host” refers to a known host in a system that is available for host seeding. The term “host seeding” refers to providing an image for use by other hosts. For example, information about existing hosts (i.e. hosts that the system knows are available for host seeding) can be stored in a database that the application server can access. Host seeding availability can depend on a variety of factors. For example, users can be assigned policies that determine which hosts they can import an image from. Also, admins can designate whether a host's image can be used for host seeding. Authentication information for existing hosts can be accessible by the application server, and authenticating with the GUI can allow a user to use an image of an existing host without any further authentication.
The term “new host” is used later herein to refer to hosts that can be used for host seeding that are not yet known to the system. For example, a user can provide information about a new host that the application server can use to retrieve an image file. An example method for creating a server cluster is described in detail later herein regarding
At stage 130, the GUI can present existing hosts that can be used for host seeding. For example, the GUI can display a list of the existing hosts and information about the host's image. The image information can include the host's name, IP address, hypervisor version, and model, as some examples. Added components that were installed at the host, such as additional drivers or applications, can also be presented as added to the image. The image information can also indicate a cluster that the host belongs to. The GUI can include a filtering tool that allows the user to locate the desired existing host more quickly. For example, the filtering tool can include a text field that actively filters the results based on user input. As an example, the user can input the IP address of the desired existing host. As the user inputs the IP address, the GUI can filter out hosts whose IP address does not match.
At stage 140, the GUI can receive a selection of one of the existing hosts. For example, the user can select a host from the list of existing hosts described above. Before creating a server cluster based on the selected host's image, the GUI can allow the user to customize the image. For example, when the user selects a host, the GUI can make an Application Programming Interface (“API”) call to a retrieve the image information for the selected host. The image information can include information like the image's identifier (“ID”), OS version, executables, application data files, installed drivers, and so on. The GUI can then allow the user to customize certain aspects of the image, such as by adding or removing drivers or other components. Components that were added to the selected host, such as applications and drivers, can be separately displayed for selection or deselection by the user for inclusion as part of the image.
At stage 150, the server cluster can be created using the image from the selected existing host. For example, the application server can create a cluster of VMs based on the selected host's image. The VMs can be installed on host devices in a location designated by the user, such as a specified data center. The application server can add and remove components from the selected image according to the modifications made by the user. The GUI can allow the user to add the selected existing host to the server cluster in certain circumstances. For example, if the existing host is a standalone host (i.e., not part of a server cluster), then the GUI can present an option, such as a toggle button, that the user can select to add the existing host to the new server cluster.
At stage 204, the GUI can receive a selection to manage the new server cluster with a single image. This stage can be optional, however, and the GUI can proceed to stage 206 without requiring any such selection from the user. At stage 206, the GUI can present options for setting up the cluster's image. For example, the GUI can display options for composing a new image, importing an image from an existing host, and importing an image from a new host.
At stage 208, the GUI can receive a selection to create the cluster using an image from an existing host. For example, the GUI options can be selection mechanisms that the user can select. Upon making the selection, at stage 210, the GUI can notify the application server.
At stage 212, the application server can identify existing hosts that are available for host seeding. This can allow the user to bootstrap a cluster of hosts with a desired image. For example, the application server can have access to data relating to existing hosts in a system that are available for host seeding. Such data can be stored in a database, for example. The application server can retrieve data about the existing hosts and cause the data to be displayed in the GUI. For example, the application server can make an API call or database query to retrieve the host data.
At stage 214, the application server can send the host data to the GUI with instructions for presenting the hosts and their corresponding data as an ordered list. The GUI can then display the list of existing hosts at stage 216. The GUI can include an active filter that allows the user to filter out existing hosts by any categories of the host data, such as the host's IP address, ID, OS version, model, and so on.
At stage 218, the user can select a host displayed in the GUI. In response, the application server can make an API call to the corresponding host to retrieve information about the host's image. Such image information can include information like the image's OS version, executables, application data files, installed drivers, and so on. The application server can then cause the image information to be displayed for the user.
At stage 220, the GUI can display modification options for the image. For example, the GUI can allow the user to modify the image before the server cluster is created. As some examples, the user can add or remove drivers, executables, and so on. The modification options can be displayed in response to the user selecting a selection mechanism in the GUI. When the user selects to modify the image, the GUI can display a window with a list of modifications that can be made. For example, the GUI can display a list of components of the image that can be added, removed, or modified. The GUI can also include a feature that allows the user to add new components to the image, such as new drivers, executables, and applications. For example, the application server can have a library of applications that can be added to an image. These applications, and any other components that can be readily added, can be displayed in the GUI for the user choose. The GUI can also allow a user to upload drivers to be used in addition to, or in lieu of, the drivers in the current image.
At stage 222, the GUI can receive modification input from the user. For example, the user can select components to add or remove, upload any data files, and select any applications or other options to add or remove. At stage 224, the GUI can send the ID of the selected host and any modifications to the application server. For example, the GUI can create a data file, such as a Hypertext Markup Language (“HTML”) file or a JavaScript Object Notation (“JSON”) file, that includes the image ID and modifications. The GUI can send the file to the application server, such as with an HTTP or API call.
At stage 226, the application server can retrieve the image corresponding to the selected existing host from the image depot. For example, the application server can send instructions to the existing host to create an image file and send it to the application server. Upon receiving the image file, at stage 228, the application server can create the server cluster using the existing host's image. In an example where the user opts to add the existing host to the cluster, the application server can reconfigure the existing host accordingly.
The GUI can include an option for managing all hosts in the cluster with a single image. Selecting this option can cause the GUI can present options for setting up the cluster's image. For example, the GUI can display options for composing a new image, importing an image from an existing host, and importing an image from a new host. At stage 320, the GUI can receive a selection for importing an image from a new host.
In response to the selection, at stage 330, the GUI can present a window for providing an address of a new host and access credentials. The GUI can accept various formats for the new host's address, such as an IP address or a fully qualified domain name (“FQDN”). An FQDN can be a complete domain name for a specific host. The access credentials can be required to access the new host. For example, the new host can require that the proper access credentials be provided before allowing communications with any unknown device. The access credentials may therefore be required for retrieving the new host's image file. The GUI can receive the access credentials in any designated format, such as a username and password.
At stage 340, the GUI can receive the address of the new host and access credentials. For example, the user can input the IP address or FQDN of the new host and access credentials for authenticating with the new host. The GUI can send the address and access credentials to the application server, which the application server can use to authenticate the user and retrieve the host's image. For example, if the user enters an IP address for the new host, then the application server can make a Hypertext Transfer Protocol (“HTTP”) call with the IP address to contact the new host. If the user provides an FQDN, then the application server can first contact a Domain Name System (“DNS”) server with the FQDN to retrieve its corresponding IP address. The application server can present the access credentials to authenticate the user. If authentication fails, then the GUI can prompt the user accordingly.
At stage 350, the application server can import an image from the new host. For example, after successfully authenticating with the access credentials, the application server can request an image of the new host. If the new host has such capability, then the new host can prepare an image file and send the image file to the application server. Before retrieving the image file, which can be large and require significant bandwidth to retrieve, the application server can first request information about the new host's image, such as the OS version, executables, application data files, installed drivers, and so on. The GUI can also allow the user to customize certain aspects of the image, such as by adding or removing drivers or other components. Then user can then select a button or other mechanism in the GUI indicating that the user has finished reviewing and customizing the image, and the application server can then import the image file from the new host and add the corresponding customizations.
In an example, before importing the image, the application server can verify the new host's certificate. For example, if the new host is not known to the application server, the application server can request the new host's Secure Sockets Layer (“SSL”), Transport Layer Security (“TLS”), or other certificate. If the application server is unable to verify the certificate, then the GUI can notify the user and prompt the user to proceed if the user trust's the certificate or to cancel the process.
The GUI can have an option to make the new host available for future host seeding. For example, the user can select an option that causes the application server to add the new host as an existing host described in
Alternatively, after first accessing the new host with the access credentials, the new host can provide a security certificate that the application server can use to retrieve a new image file. Although this method requires additional time and bandwidth usage, retrieving a new image file can be beneficial when updates or other changes have been applied to the new host since the last image retrieval. The GUI can allow a user to choose between versions when the new host is still available. For example, if the user selects the new host, the GUI can prompt the user to choose between using the older version of the image or retrieving a new version.
At stage 360, the server cluster can be created using an image from the selected existing host. For example, the application server can create a cluster of VMs based on the imported image. The VMs can be installed on host devices in a location designated by the user, such as a specified data center. The application server can add and remove components from the selected image according to the modifications made by the user.
At stage 402, the GUI can receive a selection to import an image from a new host. In response, at stage 404, the GUI can display a prompt for new host information, including an address of the new host and access credentials. The GUI can accept various formats for the new host's address, such as an IP address or an FQDN. The GUI can receive the access credentials in any designated format, such as a username and password.
At stage 406, the user can input the new host information. For example, the user can input the IP address or FQDN and the access credentials. At stage 408, the GUI can send the new host information to the application server. At stage 410, the application server can contact the new host and authenticate using the access credentials. For example, if the user enters an IP address for the new host, then the application server can make an HTTP call with the IP address to contact the new host. If the user provides an FQDN, then the application server can first contact a DNS server with the FQDN to retrieve its corresponding IP address. The application server can provide the access credentials to authenticate. If authentication fails, then the GUI can prompt the user accordingly.
At stage 412, the application server can import the new host's image from the new host. For example, the new host can create an image file and send the file to the application server. Alternatively, stage 412 can occur after stage 420. For example, because an image file can be large and require significant bandwidth to import, the application server can first request only information about the new host's image, such as the OS version, executables, application data files, installed drivers, and so on. At stage 414, the application server can send the image information to the GUI. The GUI can present the image information to the user and require the user to confirm the new host before importing the image file.
The application server can check the security certificate of the new host before allowing the user to create a server cluster based on the new host's image. For example, if the new host is not known to the application server, the application server can request the new host's SSL, TLS, or other certificate. If the application server is unable to verify the certificate, then the GUI can notify the user and prompt the user to proceed if the user trust's the certificate or to cancel the process.
At stage 416, the GUI can display modification options for the image. For example, the GUI can allow the user to modify the image before the server cluster is created. As some examples, the user can add or remove drivers, executables, and so on. The modification options can be displayed in response to the user selecting a selection mechanism in the GUI. When the user selects to modify the image, the GUI can display a window with a list of modifications that can be made. For example, the GUI can display a list of components of the image that can be added, removed, or modified. The GUI can also include a feature that allows the user to add new components to the image, such as new drivers, executables, and applications. For example, the application server can have a library of applications that can be added to an image. These applications, and any other components that can be readily added, can be displayed in the GUI for the user choose. The GUI can also allow a user to upload drivers to be used in addition to, or in lieu of, the drivers in the current image.
At stage 418, the GUI can receive modification input from the user. For example, the user can select components to add or remove, upload any data files, and select any applications or other options to add or remove. At stage 420, the GUI can send the modification input to the application server. For example, the GUI can create a data file, such as an HTML file or a JSON file, that includes the modifications. The GUI can send the file to the application server, such as with an HTTP or API call.
At stage 422, the application server can create the server cluster. For example, the application server can create a cluster of VMs based on the imported image. The VMs can be installed on host devices in a location designated by the user, such as a specified data center. The application server can add and remove components from the selected image according to the modifications made by the user.
The GUI can present multiple options for adding hosts to the identified server cluster. One option can allow the user to add hosts without importing an image. This would cause the application server to create new hosts using the image that the hosts currently in the cluster are already running. Another option can allow the application server to automatically determine the best image to use. For example, the application server can determine what image version the hosts are currently running and then determine where an updated version of the image is available. The application server can check the image versions of other clusters or known existing hosts running the same or similar images. If a higher-versioned image is available from one another existing hosts, then the application server can retrieve its image file and add hosts to the cluster using that image file. The application server can also update the hosts in the server cluster with the update image file so that all hosts are up-to-date and running the same image.
Another option can allow the user to choose a host to import an image from. at stage 520, the user can select this option. In response, the application server can retrieve a list of existing hosts in the system that are available for host seeding. The list of existing hosts can be retained at the application server or, alternatively, in a separate storage device like a database. Image availability can depend on a variety of factors. For example, users can be assigned policies that determine which hosts they can import an image from. Also, admins can designate whether a host's image can be used for host seeding.
At stage 530, the GUI can present a list of existing hosts from which an image can be imported. For example, the GUI can display a list of the existing hosts and information about the host's image. The image information can include the host's name, IP address, hypervisor version, and model, as some examples. The image information can also indicate a cluster that the host belongs to. The GUI can include a filtering tool that allows the user to locate the desired existing host more quickly. For example, the filtering tool can include a text field that actively filters the results based on user input. As an example, the user can input the IP address of the desired existing host. As the user inputs the IP address, the GUI can filter out hosts whose IP address does not match.
At stage 540, the GUI can receive a selection of one of the existing hosts. For example, the user can select a host from the list of existing hosts described above. Before creating a server cluster based on the selected host's image, the GUI can allow the user to customize the image. For example, when the user selects a host, the GUI can make an API call to a retrieve the image information for the selected host. The image information can include information like the image's ID, OS version, executables, application data files, installed drivers, and so on. The GUI can then allow the user to customize certain aspects of the image, such as by adding or removing drivers or other components.
At stage 550, the application server can import an image from the selected host. For example, the application server can instruct the selected host to create an image file and send it to the application server. In one example, the GUI can allow the user to import an image from a new host. For example, the user can provide an IP address or FQDN and access credentials for a new host, and the application server can import an image file from the new host.
At stage 560, the application server can add hosts to the cluster using the imported image. For example, the application server can create a cluster of VMs based on the selected host's image. The VMs can be installed on host devices in a location designated by the user, such as a specified data center. In one example, the GUI can allow the user to modify the image before the hosts are added to the cluster. The application server can add and remove components from the selected image according to the modifications made by the user. The GUI can allow the user to add the selected existing host to the server cluster in certain circumstances. For example, if the existing host is a standalone host (i.e., not part of a server cluster), then the GUI can present an option, such as a toggle button, that the user can select to add the existing host to the new server cluster. The application server can also update the image on hosts already in the cluster based. For example, the application server can update all the hosts in the cluster with the updated version of the image or with a new image selected by the user. This can allow all the hosts in the cluster to be managed by the same image.
A user can use this feature to update images in a server cluster without adding any additional hosts. For example, a newer version of an image used in a server cluster, or an image selected by the user, can be applied to hosts in the cluster. The GUI can allow the user to choose the number of hosts to add to the cluster with zero being an option. By selecting not to add any additional hosts, the application server can update the hosts in the cluster with the updated or selected image.
Another option can allow the user to choose an image to import, which the user can select at stage 604. In response, the GUI can notify the application server at stage 606. Then, at stage 608, the application server can identify existing hosts available for host seeding. The list of existing hosts can be retained at the application server or, alternatively, in a separate storage device like a database. Image availability can depend on a variety of factors. For example, users can be assigned policies that determine which hosts they can import an image from. Also, admins can designate whether a host's image can be used for host seeding.
At stage 610, the application server can send data about the available existing hosts to the GUI. The image information can include the host's name, IP address, hypervisor version, and model, as some examples. The image information can also indicate a cluster that the host belongs to. At stage 612, the GUI can display a list of hosts with available images and their corresponding image information.
At stage 614, the user can select an existing host. In one example, upon receiving a selection, the GUI can display additional information about the corresponding image. In one example, the application server can make an API call to the corresponding host to retrieve the additional image information. The image information can include information like the image's ID, OS version, executables, application data files, installed drivers, and so on. The GUI can also display information about the image currently running on the cluster so that the user can compare.
At stage 616, the GUI can display modification options for the selected host image. For example, the GUI can allow the user to modify the image before the server cluster is created. As some examples, the user can add or remove drivers, executables, and so on. In one example, the GUI can display components present in the existing image that are not preloaded in the new image being imported. The GUI can also allow the user to add all such components, or to individually select components, from the existing image to add to the new image. This can help the user more easily update a cluster to a new image while ensuring that the updated image is not missing any needed components.
At stage 618, the user can select modifications for the image. At stage 620, the GUI can send the image's ID and modifications to the application server. For example, the GUI can create a data file, such as an HTML, file or a JSON file, that includes the modifications. The GUI can send the file to the application server, such as with an HTTP or API call.
At stage 622, the application server can import the image from the selected host. For example, the application server can send instructions to the existing host to create an image file and send it to the application server. Upon receiving the image file, at stage 624, the application server can add the hosts to the server cluster using the imported image. If indicated by the user, the application server can also update the hosts already in the cluster with the new image. The GUI can allow the user to select how many hosts to add to the cluster, including zero. By not adding additional hosts the user can select an image for updating the hosts in the cluster.
The GUI 700 can include a hosting option 720 that allows the user to designate that the hosts in the cluster be managed with a single image. The hosting option 720 can be a toggle mechanism, such as a toggle button or check box. Enabling the hosting option 720 can cause the GUI 700 to display options for managing the cluster with a single image. For example, a first option 722 creates the server cluster using a new image, a second option 724 allows the user to import an image from an existing host, and a third option 726 allows the user to import an image from a new host.
After selecting a method of cluster management, the GUI 700 can proceed to various image pages, depending on which option the user selects. If the user selects the first option 722, then the GUI 700 can display the new image window 728 illustrated in
If the user selects the second option 724 of
If the user selects the third option 726 of
Moving to
The application server 920 can be a physical hardware server or can virtually run as one or more servers running on one or more physical hardware devices. The application server 920 can access information for applying images from one or more databases 930. For example, the database 930 can store hypervisors 932 that the application server 920 can use to create server clusters composed of VMs. The database 930 can also retain a list of existing hosts 934. Existing host 934 can refer to a known host in a system that is available for host seeding. If a user selects an existing host 934 in the GUI 914, then the application server can make an API call to the selected host to retrieve information about the host's image to present to the user. If the user chooses to create a new cluster using the selected host's image, or to apply the host's image to an existing server cluster, then the application server can contact the existing host 934 to retrieve an image file.
If a user chooses to apply an image from a new host 940, then the GUI 914 can prompt the user for access credentials. The application server 920 can contact the new host 940, such as with an HTTP call using an IP address provided by the user, to authenticate with the server, retrieve its security certificate, and retrieve information about its image 942. If the user confirms the image 942 of the new host 940, then the application server 920 can retrieve an image file of the image 942 from the new host 940 and apply the image 942 accordingly.
Other examples of the disclosure will be apparent to those skilled in the art from consideration of the specification and practice of the examples disclosed herein. Though some of the described methods have been presented as a series of steps, it should be appreciated that one or more steps can occur simultaneously, in an overlapping fashion, or in a different order. The order of steps presented are only illustrative of the possibilities and those steps can be executed or performed in any suitable fashion. Moreover, the various features of the examples described here are not mutually exclusive. Rather any feature of any example described here can be incorporated into any other suitable example. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the disclosure being indicated by the following claims.