The disclosed technology relates generally to systems with multiple virtual storage processors, and more specifically to technology for providing automatic configuration of multiple virtual storage processors in a virtual storage appliance.
Data storage appliances (“storage appliances”) may be arrangements of hardware and software that include non-volatile data storage devices (e.g. electronic flash drives, magnetic disk drives, and/or optical drives) that are used to provide non-volatile storage for processing I/O (Input/Output) requests (i.e. writes and/or reads) that are received from one or more applications. The I/O requests that are processed by a storage appliance may include block I/O requests as well as file I/O requests. The I/O requests indicate data that is stored in storage objects (e.g. block based and/or file based storage objects) that are maintained within the storage appliance. The storage appliance performs various data storage services that organize and secure data received from the applications.
Cloud computing technology is often relied on to meet the computing needs of users and organizations. In a cloud computing environment, applications that issue I/O requests may execute in virtual machines that run on one or more hypervisors executing on one or more host computers. In such contexts, it is sometimes desirable for storage appliances to also be virtualized, e.g. as virtual storage appliances (VSAs) that also execute in virtual machines. It may further be desirable to provide high availability by combining multiple (e.g. two or more) virtual storage processors within a virtual storage appliance, so that a non-failing virtual storage processor can be used to seamlessly continue the processing of I/O requests in the event of a failure occurring in one of the other virtual storage processors, and such that the continuous processing of I/O requests is not significantly interrupted or delayed.
The hypervisor or hypervisors on which the virtual storage appliance executes provide virtual hardware resources, including virtual data storage resources that are consumed by the virtual storage processors while they process I/O requests. The properties of the virtual resources provided by a hypervisor may vary depending on the specific configuration and/or capabilities of the underlying hardware resources on which the hypervisor operates. For example, one hypervisor may operate using underlying non-volatile data storage devices that provide data redundancy protection, e.g. by way of Redundant Array of Independent Disks (RAID) technology or the like implemented within the non-volatile data storage devices. In such a configuration, the virtual resources provided by the hypervisor are allocated from non-volatile data storage devices that provide data redundancy protection. In contrast, another hypervisor may operate using underlying non-volatile data storage devices that do not provide data redundancy protection. In that type of configuration, the virtual resources provided by the hypervisor are not allocated from non-volatile data storage devices that provide data redundancy protection. Without knowledge of such properties of the virtual resources provided by the hypervisor, the virtual storage processors cannot be correctly configured for all hypervisor configurations on which the virtual storage appliance may be deployed. For example, if virtual storage processors are statically configured to always provide RAID data protection with regard to the data stored in the storage objects that they make accessible to consumer applications, regardless of the properties of the virtual resources provided to the virtual storage processors by the hypervisor, then any virtual storage processors that are deployed on hypervisors that provide virtual resources from underlying non-volatile data storage devices with RAID protection may be considered inefficient and wasteful, because of the duplicative and/or unneeded RAID protection that they provide. Alternatively, if virtual storage processors are statically configured to not provide RAID data protection, e.g. based on an assumption that the underlying non-volatile data storage devices used by the hypervisor do provide data redundancy protection, deployment of virtual storage processors on hypervisors that use underlying non-volatile data storage devices that are not configured to provide RAID data protection would potentially result in a level of data protection that is considered lower than is desirable or expected. While data redundancy protection is one example of a data service that may or may not be provided by underlying non-volatile data storage devices, other examples of a data service that may or may not be provided by underlying non-volatile data storage devices include data deduplication, data compression, and/or data encryption.
Other technical problems may also occur when deploying a virtual storage appliance having multiple virtual storage processors in a virtualized execution environment. For example, multiple virtual storage processors may require the capability to communicate privately with each other, e.g. in order to provide high availability to the application(s) issuing I/O requests. In non-virtualized environments, in which multiple physical storage processors communicate within a physical data storage appliance in order to provide high availability, such private intra-storage appliance communication may be provided using a dedicated communication media that physically interconnects the multiple physical storage appliances. However, in a virtualized execution environment in which each one of the multiple virtual storage processors is embodied as virtual machine, no such dedicated physical communication media is available to provide private intra-storage appliance communications.
Technology is disclosed herein that addresses the above described and other technical problems of previous solutions. In the disclosed technology, a virtual storage appliance having multiple virtual storage processors is installed in a virtualized execution environment. Each one of the virtual storage processors may be a virtual machine that executes in the virtualized execution environment. At the time the virtual storage appliance is installed, properties of virtual resources provided by the virtualized execution environment to the virtual storage processors are obtained. The virtual resources are subsequently consumed by the virtual storage processors while processing Input/Output (I/O) requests received from at least one application. The virtual storage processors are automatically configured in response to the properties of the virtual resources provided by the virtualized execution environment.
In some embodiments, a virtual private network may be created between the virtual storage processors within the virtualized execution environment. The virtual private network enables the virtual storage processors to securely share data with each other. The data shared between the virtual storage processors over the virtual private network may be used, by one of the virtual storage processors that continues functioning after another one of the virtual storage processors fails, in order to continue processing I/O requests received from the application on the one of the virtual storage processors that continues functioning after the failure.
In some embodiments, the properties of the virtual resources provided by the virtualized execution environment that are obtained at the time the virtual storage appliance is installed may include an indication of whether the virtual resources provided by the virtualized execution environment to the virtual storage processors are allocated from one or more physical hardware non-volatile data storage devices that provide data redundancy protection.
In some embodiments, the properties that are obtained at the time the virtual storage appliance is installed may include an indication that the virtual resources provided by the virtualized execution environment to the virtual storage processors are allocated from one or more physical hardware non-volatile data storage devices that do not provide data redundancy protection. In such embodiments, the virtual storage processors, in response to the indication that the virtual resources provided by the virtualized execution environment to the virtual storage processors are allocated from one or more physical hardware non-volatile data storage devices that do not provide data redundancy protection, the virtual storage processors may be automatically configured at least in part by configuring a software stack in each virtual storage processor that processes I/O requests received from the application such that the software stack provides data redundancy protection for data received from the consumer application.
In some embodiments, the properties that are obtained at the time the virtual storage appliance is installed include an indication that the virtual resources provided by the virtualized execution environment to the virtual storage processors are allocated from one or more physical hardware non-volatile data storage devices that do provide data redundancy protection. In such embodiments, in response to the indication that the virtual resources provided by the virtualized execution environment to the virtual storage processors are allocated from one or more physical hardware non-volatile data storage devices that do provide data redundancy protection, the virtual storage processors may be automatically configured at least in part by configuring a software stack in each virtual storage processor that processes I/O requests received from the application such that the software stack does not provide data redundancy protection for data received from the consumer application.
In some embodiments, a cache of data received from the application may be replicated on each one of the virtual storage processors. In such embodiments, the replication of the cache of data received from the application on each one of the virtual storage processors may be performed over the virtual private network created between the virtual storage processors.
In some embodiments, the virtual resources provided by the virtualized execution environment to the virtual storage processors may be consumed by the virtual storage processors at least in part while the virtual storage processors process both block I/O requests and file I/O requests that are received by the virtual storage processors from the consumer application.
In some embodiments, the application may be a virtual machine that executes in the virtualized execution environment.
Embodiments of the disclosed technology may provide significant improvements over previous technologies. For example, embodiments of the disclosed technology enable multiple virtual storage processors to be automatically configured based on the properties of the virtual resources provided by one or more hypervisors in a virtualized execution environment, thus avoiding inefficient and/or wasteful configurations, while also avoiding the undesirable result of providing less data services (e.g. a lower level of protection) than is expected. In addition, some embodiments may advantageously provide secure communications within the virtual storage appliance communication by creating a virtual private network between the multiple virtual storage processors, since dedicated hardware interconnect(s) between virtual storage processors may not be available in virtualized execution environments.
The foregoing and other objects, features and advantages will be apparent from the following description of particular embodiments of the disclosed technology, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed on illustrating the principles of various embodiments of the disclosed technology.
Embodiments of the invention will now be described. The embodiments described herein are only examples of how features and principles of the invention may be embodied. The invention itself is accordingly broader than the specific examples described below.
The disclosed technology includes a virtual storage appliance having multiple virtual storage processors. The virtual storage appliance is installed in a virtualized execution environment. The virtualized execution environment may include or consist of one or more hypervisors executing on one or more host server computers, and the multiple virtual storage processors may each execute as a virtual machine within the virtualized execution environment. At the time the virtual storage appliance is installed (e.g. at the time the virtual storage appliance is first booted up in the virtualized execution environment), the virtual storage processors obtain properties of virtual resources that are provided by the virtualized execution environment to the virtual storage processors. The properties of the virtual resources may, for example, reflect the configuration and/or capabilities of non-volatile data storage devices from which the virtual resources are allocated. The virtual storage processors subsequently consume the virtual resources provided by the virtualized execution environment while processing Input/Output (I/O) requests that are received by the virtual storage processors from at least one consumer application, e.g. by storing data received in write I/O requests received from the application in portions of non-volatile data storage allocated to the virtual resources provided to the virtual storage processors by the virtualized execution environment. The virtual storage processors are automatically configured in response to the properties of the virtual resources provided by the virtualized execution environment that are obtained at the time the virtual storage appliance is installed. In some embodiments, a virtual private network may be created between the virtual storage processors within the virtualized execution environment, in order for the virtual storage processors to securely share data with each other that may be used by one of the virtual storage processors that continues functioning after another one of the virtual storage processors fails, in order to seamlessly continue the processing of I/O requests received from the application on the one of the virtual storage processors that continues functioning after the failure.
Non-Volatile Data Storage Devices 106 may include or consist of some number of physical hardware disk drives. The disk drives in Non-Volatile Data Storage Devices 106 may include magnetic disk drives, electronic flash drives, optical drives, and/or other types of non-volatile data storage drives or devices. Non-Volatile Data Storage Devices 106 may further include communication interfaces, e.g. network interface adapters, SCSI targets, etc., that enable Non-Volatile Data Storage Devices 106 to be accessed by Host Computers 100 over one or more computer and/or communication networks. Non-Volatile Data Storage Devices 106 may or may not be capable of and/or configured to provide various types of data services with regard to the data stored on the disks within Non-Volatile Data Storage Devices 106, and accordingly for data that is stored on the Virtual Resources 112 that are allocated by Virtualized Execution Environment 110 from Non-Volatile Data Storage Devices 106. For example, Non-Volatile Data Storage Devices 106 may be configured to provide data redundancy protection. For example, in some configurations, Non-Volatile Data Storage Devices 106 may include data redundancy protection for the data written by Host Computers 100 to the physical disks within Non-Volatile Data Storage Devices 106, and accordingly for data stored on the Virtual Resources 112, e.g. by way of Redundant Array of Independent Disks (RAID) technology or the like that is provided within the Non-Volatile Data Storage Device 106. Other examples of data services that may or may not be provided by Non-Volatile Data Storage Devices 106 include data deduplication, data compression, and/or data encryption.
As shown in
The virtual machines that execute on Virtualized Execution Environment 110 include multiple virtual storage processors within the Virtual Storage Appliance 175. For example, as shown in
The virtual machines that execute on Virtualized Execution Environment 110 also include one or more applications that consume data storage services that are provided by the virtual storage processors in Virtual Storage Appliance 175. For example, as shown in
For example, the I/O request processing stack in each one of Virtual SP-1116 and Virtual SP-2118 may provide layers of program logic for processing and/or supporting the processing of I/O Requests 152. Those of I/O Requests 152 that are directed to and received by Virtual SP-1116 may be processed by I/O Request Processing Stack 126, and those of I/O Requests 152 that are directed to and received by Virtual SP-2118 may be processed by I/O Request Processing Stack 140. In some configurations, I/O Requests 152 may be distributed across both Virtual SP-1116 and Virtual SP-2118 while Virtual SP-1116 and Virtual SP-2118 are both functional, e.g. in order to provide load balancing. In the event that one of either Virtual SP-1116 or Virtual SP-2118 individually fails, the other virtual storage processor that remains functional continues to process I/O Requests 152 without interruption, thereby providing high availability of data storage services from Virtual Storage Appliance 175 to Data Storage Service Consumer Application(s) 150. Alternatively, I/O Requests 152 may be initially processed by Virtual SP-1116, until Virtual SP-1116 fails, after which Virtual SP-2118 seamlessly continues the processing of I/O Requests 152 without interruption of data storage services provided by Virtual Storage Appliance 175 to Data Storage Service Consumer Application(s) 150.
I/O requests received by Virtual SP-1116 and processed by I/O Request Processing Stack 126, and I/O requests received by Virtual SP-2118 and processed by I/O Request Processing Stack 140 may include I/O read requests and I/O write requests directed to various types of block data objects that are provided by Virtual SP-1116 and/or Virtual SP-2118 to Data Storage Service Consumer Application(s) 150 using portions of non-volatile data storage that are allocated from Virtual Resources 112. Such block data objects may include or consist of logical disks (e.g. logical units sometimes referred to as LUNs) and/or block-based virtual volumes (VVols) that are accessed by Data Storage Service Consumer Application(s) 150.
I/O requests received by Virtual SP-1116 and processed by I/O Request Processing Stack 126, and I/O requests received by Virtual SP-2118 and processed by I/O Request Processing Stack 140 may also or alternatively include I/O read requests and I/O write that are directed to file data objects provided by Virtual SP-1116 and/or Virtual SP-2118 to Data Storage Service Consumer Application(s) 150 using non-volatile data storage allocated from Virtual Resources 112, such as files or file systems that are accessed by Data Storage Service Consumer Application(s) 150.
At the time that Virtual Storage Appliance 175 is installed, properties of Virtual Resources 112 are obtained. For example, at the time Virtual Storage Appliance 175 is first booted up on Virtualized Execution Environment 110, Virtual SP-1116 and/or Virtual SP-2118 may issue a query to obtain some number of relevant properties of Virtual Resources 112, as illustrated by Query 130. For example, the query may be issued by Virtual SP-1116 and/or Virtual SP-2118 to the Virtualized Execution Environment 110, as shown in
The Virtual Resources 112 provided by Virtualized Execution Environment 110 to Virtual SP-1116 and Virtual SP-2118 are subsequently consumed by Virtual SP-1116 and/or Virtual SP-2118 while Virtual SP-1116 and/or Virtual SP-2118 process I/O Requests 152 that are received by Virtual SP-1116 and/or Virtual SP-2118 from Data Storage Service Consumer Application(s) 150. For example, I/O Request Processing Stack 126 in Virtual SP-1116 and/or I/O Request Processing Stack 140 in Virtual SP-2118 may allocate non-volatile data storage from one or more of Virtual Disks 114 and/or other specific types of data storage resources in Virtual Resources 112 for use in one or more data objects, and then store data into those data objects that is indicated by some number of write requests within I/O Requests 152 while processing those write requests.
Further at the time that Virtual Storage Appliance 175 is installed (e.g. at the time that Virtual Storage Appliance 175 is first booted up on Virtualized Execution Environment 110), I/O Request Processing Stack 126 and/or I/O Request Processing Stack 140 are automatically configured in response to the properties of Virtual Resources 112 that are provided to Virtual SP-1116 and/or Virtual SP-2118, e.g. by Virtualized Execution Environment 110. For example, Configuration Logic 124 may configure I/O Request Processing Stack 126 based on the Virtual Resource Properties 132, and/or Configuration Logic 138 may configure I/O Request Processing Stack 140 based on Virtual Resource Properties 132, also at the time that Virtual Storage Appliance 175 is installed. For example, in the event that Virtual Resource Properties 132 indicates that a specific data service (e.g. data redundancy protection, data deduplication, data compression, or data encryption) is not provided by Non-Volatile Data Storage Devices 106, then Configuration Logic 124 may configure I/O Request Processing Stack 126 to include and/or execute program logic that provides that data service for data indicated by I/O Requests 152 that are directed to and processed by Virtual SP-1116, and/or Configuration Logic 138 may configure I/O Request Processing Stack 140 to include and/or execute program logic that provides that data service for data indicated by I/O Requests 152 that are directed to and processed by Virtual SP-2118.
In some embodiments, one or more virtual private networks may be created between Virtual SP-1116 and Virtual SP-2118 within the Virtualized Execution Environment 110, shown for purposes of illustration in
In some embodiments, a cache of data received from Data Storage Service Consumer Application(s) 150 may be replicated between Virtual SP-1116 and Virtual SP-2118, such that I/O Request Processing Stack 126 and I/O Request Processing Stack 140 each maintain an identical cache. In some embodiments, the cache may be replicated between Virtual SP-1116 and Virtual SP-2118 over VLAN(s) 128. The replicated cache may store data indicated by write requests in I/O Requests 152. Each such write request may specify a data object, and indicate (or include) host I/O data that is to be written to the specified data object. For each one of the write requests, the indicated data may initially be stored in the replicated cache on both Virtual SP-1116 and Virtual SP-2118 when the write request is received by Virtual SP-1116 or Virtual SP-2118. Virtual SP-1116 and/or Virtual SP-2118 may then provide an acknowledgment to Data Storage Service Consumer Application(s) 150 once the data indicated by the write request has been securely stored in the replicated cache, indicating successful completion of the write request. In addition, in some embodiments, data indicated for retrieval by one or more read requests in I/O Requests 152 may also be accumulated over time in the replicated cache. By replicating the cache in both Virtual SP-1116 and Virtual SP-2118 over VLAN(S) 152, embodiments of the disclosed technology provide for rapid failover between Virtual SP-1116 and Virtual SP-2118 in the event of a failure of one of Virtual SP-1116 or Virtual SP-2118, without interrupting the processing of I/O Requests 152.
VLAN(s) 128 may also be used to share other types of data between Virtual SP-1116 and Virtual SP-2118. For example, in some embodiments, Failure Detection Logic 122 and Failure Detection Logic 136 may operate to periodically send heartbeat signals to each other over VLAN(s) 128 in order for Virtual SP-1116 and Virtual SP-2118 to detect when the other virtual storage processor has failed. In such embodiments, for example, if Failure Detection Logic 136 does not receive a heartbeat signal from Failure Detection Logic 122 within some predetermined period of time, then Failure Detection Logic 136 detects that Virtual SP-2118 has failed, and that accordingly Virtual SP-2118 should process all of I/O Requests 152 going forward. Similarly, in another example, if Failure Detection Logic 122 does not receive a heartbeat signal from Failure Detection Logic 136 within some predetermined period of time, then Failure Detection Logic 122 may detect that Virtual SP-2118 has failed, and that accordingly Virtual SP-1116 should process all of I/O Requests 152 going forward.
As shown in
In another example, Virtual Resource Properties 132 may include an indication that Virtual Resources 112 are allocated from non-volatile data storage devices that do provide data redundancy protection, e.g. an indication that Non-Volatile Data Storage Devices 106 do provide data redundancy protection. In response to an indication in Virtual Resource Properties 132 that Virtual Resources 112 are allocated from non-volatile data storage devices that do provide data redundancy protection, Configuration Logic 124 may configure I/O Request Processing Stack 126 such that I/O Request Processing Stack 126 does not include or execute program logic that provides data redundancy protection (e.g. RAID protection) for data indicated by write requests in I/O Requests 152 that are processed by Virtual SP-1116. Similarly, in response to an indication in Virtual Resource Properties 132 that Virtual Resources 112 are allocated from non-volatile data storage devices that do provide data redundancy protection, Configuration Logic 138 may configure I/O Request Processing Stack 140 such that I/O Request Processing Stack 140 does not include or execute program logic that provides data redundancy protection (e.g. RAID protection) for data indicated by write requests in I/O Requests 152 that are processed by Virtual SP-2118.
While the preceding examples were with regard to use cases in which the disclosed technology detects whether Non-Volatile Data Storage Devices 106 either provide or do not provide a data redundancy protection data service, and in which the disclosed technology configures the I/O request processing stacks in Virtual SP-1116 and Virtual SP-2118 accordingly, the disclose technology may alternatively, or in addition, be embodied to operate in response to indications in Virtual Resource Properties 132 as to whether Virtual Resources 112 are allocated from non-volatile data storage devices that provide other data services, e.g. data deduplication, data compression, and/or data encryption. Accordingly, in some embodiments, configuration logic in Virtual SP-1116 and/or Virtual SP-2118 may operate responsive to an indication in Virtual Resource Properties 132 that Non-Volatile Data Storage Devices 106 do not provide data deduplication, data compression, and/or data encryption, by configuring the I/O request processing stack (e.g. I/O Request Processing Stack 126 and/or I/O Request Processing Stack 140) to include and/or execute program logic that provides that data service or data services that are not provided by Non-Volatile Data Storage Devices 106 for data indicated by write requests in I/O Requests 152 that are processed by the respective one of Virtual SP-1116 and/or Virtual SP-2118. In such embodiments, configuration logic in Virtual SP-1116 and/or Virtual SP-2118 may operate responsive to an indication in Virtual Resource Properties 132 that Non-Volatile Data Storage Devices 106 do provide data deduplication, data compression, or data encryption, by configuring the I/O request processing stack (e.g. I/O Request Processing Stack 126 and/or I/O Request Processing Stack 140) to not include or execute program logic that provides the data service or data services that are provided by Non-Volatile Data Storage Devices 106 for data indicated by write requests in I/O Requests 152 that are processed by the respective one of Virtual SP-1116 and/or Virtual SP-2118.
As shown in the example of
As also shown in
At step 402, at the time the virtual storage appliance is installed, properties of virtual resources provided by the virtualized execution environment to the virtual storage processors are obtained. The virtual resources are subsequently consumed by the virtual storage processors while the virtual storage processors process Input/Output (I/O) requests received from at least one application.
At step 404, the virtual storage processors are automatically configured in response to the properties of the virtual resources provided by the virtualized execution environment.
As will be appreciated by those skilled in the art, the technologies disclosed herein may be embodied as a system, method or computer program product. Accordingly, each specific feature of the present disclosure may be embodied using hardware, software (including firmware, resident software, micro-code, etc.) or a combination of software and hardware. Furthermore, the technologies disclosed herein may take the form of a computer program product embodied in one or more non-transitory computer readable storage medium(s) having computer readable program code stored thereon for causing a processor and/or computer system to perform the techniques of the present disclosure.
Any combination of one or more computer readable storage medium(s) may be utilized. The computer readable storage medium may be, for example, but not limited to, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any non-transitory tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
The figures include block diagram and flowchart illustrations of methods, apparatus(s) and computer program products according to one or more embodiments of the invention. It will be understood that each block in such figures, and combinations of these blocks, can be implemented by computer program instructions. These computer program instructions may be executed on processing circuitry to form specialized hardware. These computer program instructions may further be loaded onto a computer or other programmable data processing apparatus to produce a machine, such that the instructions which execute on the computer or other programmable data processing apparatus create means for implementing the functions specified in the block or blocks. These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the block or blocks. The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the block or blocks.
Those skilled in the art will readily appreciate that programs defining the functions of the present invention can be delivered to a computer in many forms; including, but not limited to: (a) information permanently stored on non-writable storage media (e.g. read only memory devices within a computer such as ROM or CD-ROM disks readable by a computer I/O attachment); or (b) information alterably stored on writable storage media.
While the invention is described through the above exemplary embodiments, it will be understood by those of ordinary skill in the art that modification to and variation of the illustrated embodiments may be made without departing from the inventive concepts herein disclosed.