LOCALLY PROVIDING CLOUD STORAGE ARRAY SERVICES
Locally providing cloud storage array services for a storage array of a data center when the storage array is not connected to a remote cloud-based storage array services provider includes initiating, by a primary storage array, one or more cloud storage array services and locally providing the cloud storage array services. Such local providing of the cloud storage array services also includes generating, by the cloud storage array services, metadata describing one or more real-time storage array characteristics and presenting the metadata to a user through a local area network.
This application is a continuation application of and claims priority from U.S. patent application Ser. No. 14/721,571, filed on May 26, 2015.
BACKGROUND1. Field of Technology
The field of technology is data processing, or, more specifically, methods, apparatus, and products for providing cloud storage array services for a storage array of a data center when the storage array is not connected to a remote cloud-based storage array services provider.
2. Description of Related Art
Data centers may include many computing components including servers, network devices, and storage arrays. As the need for storage of large amounts of data and efficient access to that data increases, storage array technology is advancing. Such storage arrays may provide persistent storage for any number of computing devices in a data center. Given that many data centers provide services to many different users, various considerations must be taken into account to provide efficient, useful, and secure access to and administration of storage arrays. Various management tools, reporting services, and the like may be implemented for storage array through cloud-based service providers. In some implementations, however, such cloud-based service providers may be unavailable, either by design or through a loss of connection.
SUMMARYMethods, apparatus, and products for locally providing cloud storage array services for a storage array of a data center when the storage array is not connected to a remote cloud-based storage array services provider are disclosed in this specification. Providing such cloud storage array services in accordance with embodiments of the present invention includes: initiating, by a primary storage array, one or more cloud storage array services; and locally providing the cloud storage array services including: generating, by the cloud storage array services, metadata describing one or more real-time storage array characteristics; and presenting the metadata to a user through a local area network.
The foregoing and other objects, features and advantages of the invention will be apparent from the following more particular descriptions of exemplary embodiments of the invention as illustrated in the accompanying drawings wherein like reference numbers generally represent like parts of exemplary embodiments of the invention.
Exemplary methods, apparatus, and products for providing cloud storage array services for a storage array of a data center when the storage array is not connected to a remote cloud-based storage array services provider in accordance with the present invention are described with reference to the accompanying drawings, beginning with
Although in many cases such ‘cloud’ environments or systems are accessible via the Internet, readers of skill in the art will recognize that any system that abstracts the use of shared resources to provide services to a user through any network may be considered a cloud-based system.
The computing devices (164-170) in the example of
The local area network (160) of
The example storage arrays (102, 104) of
Each storage controller (106, 112) may be implemented in a variety of ways, including as an FPGA (Field Programmable Gate Array), a PLC (Programmable Logic Chip), an ASIC (Application Specific Integrated Circuit), or computing device that includes discrete components such as a central processing unit, computer memory, and various adapters. Each storage controller (106, 112) may, for example, include a data communications adapter configured to support communications via the SAN (158) and the LAN (160). For clarity, only one of the storage controllers (112) in the example of
Each write buffer device (148, 152) may be configured to receive, from the storage controller (106, 112), data to be stored in the storage devices (146). Such data may originate from any one of the computing devices (164-170). In the example of
A ‘storage device’ as the term is used in this specification refers to any device configured to record data persistently. The term ‘persistently’ as used here refers to a device's ability to maintain recorded data after loss of a power source. Examples of storage devices may include mechanical, spinning hard disk drives, Solid-state drives (“Flash drives”), and the like.
In addition to being coupled to the computing devices through the SAN (158), the storage arrays may also be coupled to the computing devices through the LAN (160) and to one or more cloud service providers through the Internet (172). One example cloud service in
In some instances, the storage arrays (102, 104) may be disconnected from the storage array services provider (176). Various reasons may exist for such a disconnect. For example, a loss of data communications connection between the storage array and the storage array services provider (176) may occur. In high-security data centers, as another example, the storage arrays (102, 104) may never be connected to the storage array services provider at all. In such situations, users may still desire the services provided by the storage array services provider. To that end, the system of
Prior to presentation, the metadata may be processed and analyzed. Such analysis processing and analysis may also be included in the presentation of the metadata to the user through the LAN (160). That is, ‘presenting the metadata’ is not limited to presenting the metadata in its original form. The metadata may be formatted, processed, analyzed, and otherwise altered for purposes of presentation.
As mentioned above, one example in which cloud storage array services are provided locally in accordance with embodiments of the present invention includes when a loss of data communications occurs. To that end, the primary storage array (180), through the storage array services module (182) may be configured to detect a data communications connection between the primary storage array (180) and a remote cloud-based storage array services provider (176). Here, a ‘heartbeat’ signal may be used to ensure that the data communications connection between the primary storage array (180) and the cloud-based storage array services provider (176) is maintained. Such a ‘heartbeat’ may be a periodic ping of the storage array services provider. As long as the ping is returned, the storage array services module (182) may infer that the data communications connection between the storage array services provider (176) and the primary storage array (180) has not been lost. In such an embodiment, the cloud-based storage array services provider (176) may provide the cloud storage array services remotely, rather than the storage array services module (182).
Further, while the data communications connection between the primary storage array (180) and the storage array services provider (176) is active, the storage array services module (182) may periodically retrieve, from the remote cloud-based storage array services provider (176), a current configuration of the cloud storage array services and the a current configuration of the plurality of storage arrays (102, 104) in the data center. The term ‘current configuration of the cloud storage array services’ may include any data related to the execution of the services including, for example, a list of the types of services to be executed, the executable computer program instructions of the services themselves, updates to the executable computer program instructions of the services, data used to seed the services, data describing the format of presenting the results of the services, and so on. The term ‘current configuration of the plurality of storage arrays’ refers to any data describing each of the storage arrays of the data center including: storage capabilities of each storage array; data communications capabilities, endpoints, and present connectivity of each storage array; one or more identifiers of the storage array or the array's components; a listing of components of the storage array; an identification of logical volumes maintained by the storage array; and the like. By periodically updating these current configurations, the storage array services module (182) may be primed to locally provide the cloud storage array services upon a loss of data communications between the primary storage array (180) and the storage array services provider (176).
The storage array services module (182) may later detect loss of the data communications connection between the primary storage array and the remote cloud-based storage array services provider. The storage array services module (182) may detect such a loss of communications when a predefined number of pings of the heartbeat signal are not returned. Responsive to detecting the loss of communications between the primary storage array (180) and the storage array services provider (176), the storage array services provider may then initiate the cloud storage array services (184).
In embodiments in which multiple storage arrays are included in the data center, each storage array may be independently coupled for data communications to the cloud-based storage array services provider (176). In such embodiments, each storage array is generally unaware of the other storage arrays at least for purposes of participating in storage array services offered by the cloud-based storage array services provider (176). In such an embodiment, the cloud-based storage array services provider may expose a REST (Representational State Transition) API (Application Programming Interface), or the like, to the storage arrays to carry out data communications between a storage array service and a storage array. REST APIs generally utilize HTTP commands and a domain as the basis for data communications to between two endpoints. To that end, upon a loss of communications with the cloud-based storage array services provider (176), the primary storage array (180) may initiate the one or more cloud storage array services (184) by altering a local DNS (Domain Name Service) record such that the domain originally utilized by the cloud-based storage array services provider (176) redirects to an IP address of the primary storage array. In this way, any communications that would normally be addressed to the cloud-based storage array services provider from any storage array in the data center are now redirected to the primary storage array (180).
In such an embodiment in which multiple storage arrays are located within a single data center, generating metadata describing one or more real-time storage array characteristics may also include generating metadata describing one or more real-time storage array characteristics of each of the plurality of the storage arrays; and aggregating, for presentation to the user, the metadata of each of the plurality of storage arrays.
Although the example of
In embodiments in which workload characteristics are utilized to select a host for the cloud-based storage array services, the primary storage array (180) may also be configured to detect a change in workload characteristics of each of the plurality of storage arrays. Such a change may be detected in a variety of ways including, for example, by detecting a failure of a storage array, by periodically retrieving workload characteristics, and so on. Upon detecting the change, the primary storage array (180) may then re-select one of the storage arrays to host the one or more cloud storage array services in dependence upon the changed workload characteristics. In this way, hosting of the services may be dynamically reassigned when workload changes amongst the storage arrays.
In embodiments in which a storage array other than the primary storage array (180) is selected to host the cloud-based storage array services, the primary storage array may operate as a proxy for the selected storage array. In such an embodiment, presenting the metadata to a user through a local area network may include presenting the metadata through the proxy of the primary storage array. The primary storage array (180) may operate as a proxy in different ways. In one way, the primary storage array receives only the final aggregated results for presentation to the user through the local area network (160). That is, the selected storage array actually hosting the cloud-based storage array services (184) may perform the services, collecting metadata from all storage arrays, aggregate the metadata into a single result and pass that result on to the primary storage array for presentation to a user. In another example, the selected storage array may execute the cloud-based storage array services and each storage array may pass its metadata directly to the primary storage array. In such an embodiment, the primary storage array may aggregate and process the metadata of each storage array prior to presenting the aggregated and processed metadata to a user through the LAN (160).
The arrangement of computing devices, storage arrays, cloud-based service providers, networks and other devices making up the exemplary system illustrated in
Locally providing cloud storage array services in accordance with embodiments of the present invention is generally implemented with computers. In the system of
The primary storage array (202) of
Here, the user may receive or view the metadata (226) through a client-side array services module (228) stored in RAM (238) of a client-side user computer (204). In the example of
In some embodiments, prior to the storage array services module (182) initiating cloud storage array services (184) locally, such cloud storage array services may be provided remotely via the storage array services provider (176). In such an embodiment, the cloud storage array services (184) may be stored in RAM (24) of the storage array services provider (176) and be accessible via an API exposed by the storage array services provider via data communications over the Internet (172) or some other wide-area network.
Turning back to the components of the primary storage array (202), also stored in RAM (214) is an operating system (234). Examples of operating systems useful in primary storage arrays configured for locally providing cloud storage array services according to embodiments of the present invention include UNIX™, Linux™, Microsoft Windows™, and others as will occur to those of skill in the art. The operating system (234), the storage array services module (182), the cloud storage array services (184) and the metadata (226) in the example of
The primary storage array (202) of
The example primary storage array (202) of
The exemplary primary storage array (202) of
The example of
The processor (314) is also coupled for data communications through PCIe (Peripheral Component Interface express) links (308, 310, 312, 322) to several Fibre Channel host bus adapters (302, 304), an Ethernet adapter (306), and a PCIe switch (324). The Fibre Channel host bus adapters (308, 310) may couple the storage controller to a storage area network, such the SAN (158) depicted in the example of
Readers of skill in the art will recognize that these components, protocols, adapters, and architectures are for illustration only, not limitation. Such a storage controller may be implemented in a variety of different ways. Each such way is well within the scope of the present invention.
For further explanation,
The method of
Presenting (408) metadata (226) locally to a user may be carried out by sending the data through the local area network (160) to a client-side array services module for presentation in a GUI (Graphical User Interface) (410). A client-side array services module (228) is a module of automated computing machinery comprising computer hardware, computer software, or a combination of computer hardware and software that is configured to receive and present in a GUI metadata from cloud storage array services. One example of a client-side array services module (228) may be a web browser and the GUI (410) may be a webpage hosted by the primary storage array (202). In another example, the client-side array services module (228) may be implemented as an application for a mobile device. These are but a few of many possible implementations of a client-side array services module (228) that may be configured to receive and present metadata to a user.
For further explanation,
The method of
While the data communications connection is active, the method of
Also while the data communications connection between the primary storage array (202) and the remote cloud based storage array services provider (176) is active, the method of
The method of
For further explanation,
The method of
For further explanation,
The method of
The method of
The method of
Exemplary embodiments of the present invention are described largely in the context of a fully functional computer system. Readers of skill in the art will recognize, however, that the present invention also may be embodied in a computer program product disposed upon computer readable media for use with any suitable data processing system. Such computer readable storage media may be any transitory or non-transitory media. Examples of such media include storage media for machine-readable information, including magnetic media, optical media, or other suitable media. Examples of such media also include magnetic disks in hard drives or diskettes, compact disks for optical drives, magnetic tape, and others as will occur to those of skill in the art. Persons skilled in the art will immediately recognize that any computer system having suitable programming means will be capable of executing the steps of the method of the invention as embodied in a computer program product. Persons skilled in the art will recognize also that, although some of the exemplary embodiments described in this specification are oriented to software installed and executing on computer hardware, nevertheless, alternative embodiments implemented as firmware, as hardware, or as an aggregation of hardware and software are well within the scope of embodiments of the present invention.
It will be understood from the foregoing description that modifications and changes may be made in various embodiments of the present invention without departing from its true spirit. The descriptions in this specification are for purposes of illustration only and are not to be construed in a limiting sense. The scope of the present invention is limited only by the language of the following claims.
Claims
1. A method comprising:
- detecting, by the local storage array, loss of a data communications connection between the local storage array and a remote cloud based storage array services provider;
- initiating, by a local storage array, one or more cloud storage array services to execute on the local storage array; and
- locally providing the cloud storage array services for the local storage array responsive to detecting the loss of data communications between the local storage array and the remote cloud based storage array services provider, and wherein locally providing the cloud storage array services includes: generating, by the cloud storage array services, metadata describing one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array; and presenting the metadata describing the one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array.
2. The method of claim 1,
- wherein: initiating the one or more cloud storage array services by the local storage array further comprises initiating the one or more cloud storage array services by the local storage array only in response to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider.
3. The method of claim 2, wherein the data center further comprises a plurality of storage arrays, including the local storage array and the method further comprises:
- prior to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider: periodically retrieving, by the local storage array from the remote cloud-based storage array services provider, a current configuration of the one or more cloud storage array services and the plurality of storage arrays; and
- subsequent to detecting the loss of the data communications connection between the local storage array and the remote cloud-based storage array services provider: locally providing the one or more cloud storage array services according to the current configuration retrieved from the remote cloud-based storage array services provider, wherein the current configuration of the one or more cloud storage array services includes one or more of: any data related to the execution of the services including list of the types of one or more cloud storage array services to be executed; executable computer program instructions of the one or more cloud storage array services; updates to the executable computer program instruction of the one or more cloud storage array services; data used to seed the services; and data describing a format of presenting results of the one or more cloud storage array services.
4. The method of claim 1, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and generating, by the cloud storage array services, metadata describing one or more real-time storage array characteristics further comprises:
- generating metadata describing one or more real-time storage array characteristics of each of the plurality of the storage arrays; and
- aggregating, for presentation to the user, the metadata of each of the plurality of storage arrays.
5. The method of claim 1, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and initiating the one or more cloud storage array services further comprises:
- selecting, by the local storage array in dependence upon workload characteristics of each of the plurality of storage arrays, one of the plurality of storage arrays to host the one or more cloud storage array services.
6. The method of claim 5, further comprising:
- detecting, by the local storage array, a change in workload characteristics of each of the plurality of storage arrays; and
- re-selecting one of the plurality of storage arrays to host the one or more cloud storage array services in dependence upon the changed workload characteristics.
7. The method of claim 5,further comprising:
- operating, by the local storage array, as a proxy for the selected storage array when the selected storage array is not the local storage array; and
- presenting the metadata to a user through a local area network further comprises presenting the metadata through the proxy of the local storage array.
8. An apparatus comprising a computer processor and a computer memory operatively coupled to the computer processor, where the computer memory includes computer program instructions that, when executed by the computer processor, cause the apparatus to carry out the steps of:
- detecting, by the local storage array, loss of a data communications connection between the local storage array and a remote cloud based storage array services provider;
- initiating, by the local storage array, one or more cloud storage array services to execute on the local storage array; and
- locally providing the cloud storage array services for the local storage array responsive to detecting the loss of data communications between the local storage array and the remote cloud based storage array services provider, and wherein locally providing the cloud storage array services includes: generating, by the cloud storage array services, metadata describing one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array; and presenting the metadata describing the one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array.
9. The apparatus of claim 8,
- wherein:
- initiating the one or more cloud storage array services by the local storage array further comprises initiating the one or more cloud storage array services by the local storage array only in response to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider.
10. The apparatus of claim 9, wherein the data center further comprises a plurality of storage arrays, including the local storage array and the apparatus further comprises computer program instructions that, when executed by the computer processor, cause the apparatus to carry out the steps of:
- prior to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider:
- periodically retrieving, by the local storage array from the remote cloud-based storage array services provider, a current configuration of the cloud storage array services and the plurality of storage arrays.
11. The apparatus of claim 8, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and generating, by the cloud storage array services, metadata describing one or more real-time storage array characteristics further comprises:
- generating metadata describing one or more real-time storage array characteristics of each of the plurality of the storage arrays; and
- aggregating, for presentation to the user, the metadata of each of the plurality of storage arrays.
12. The apparatus of claim 8, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and initiating the one or more cloud storage array services further comprises:
- selecting, by the local storage array in dependence upon workload characteristics of each of the plurality of storage arrays, one of the plurality of storage arrays to host the one or more cloud storage array services.
13. The apparatus of claim 12, further comprising computer program instructions that, when executed by the computer processor, cause the apparatus to carry out the steps of:
- detecting, by the local storage array, a change in workload characteristics of each of the plurality of storage arrays; and
- re-selecting one of the plurality of storage arrays to host the one or more cloud storage array services in dependence upon the changed workload characteristics.
14. The apparatus of claim 12, further comprising computer program instructions that, when executed by the computer processor, cause the apparatus to carry out the steps of:
- operating, by the local storage array, as a proxy for the selected storage array when the selected storage array is not the local storage array; and
- presenting the metadata to a user through a local area network further comprises presenting the metadata through the proxy of the local storage array.
15. A computer program product stored on a non-transitory computer readable medium, the computer program product comprising computer program instructions that, when executed, cause a computer to carry out the steps of:
- detecting, by a local storage array, loss of a data communications connection between the local storage array and a remote cloud based storage array services provider;
- initiating, by the local storage array, one or more cloud storage array services to execute on the local storage array; and
- locally providing the cloud storage array services for the local storage array responsive to detecting the loss of data communications between the local storage array and the remote cloud based storage array services provider, and wherein locally providing the cloud storage array services includes: generating, by the cloud storage array services, metadata describing one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array; and presenting the metadata describing the one or more storage array characteristics of the one or more cloud storage array services executing on the local storage array.
16. The computer program product of claim 15, further comprising computer program instructions that, when executed, cause the computer to carry out the steps of:
- detecting, by the local storage array prior to initiating the cloud storage array services by the local storage array, a data communications connection between the local storage array and a remote cloud-based storage array services provider, wherein the remote cloud-based storage array services provider provides the one or more cloud storage array services; and
- detecting, by the local storage array, loss of the data communications connection between the local storage array and the remote cloud-based storage array services provider, wherein:
- initiating the one or more cloud storage array services by the local storage array further comprises initiating the one or more cloud storage array services by the local storage array only in response to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider.
17. The computer program product of claim 16, wherein the data center further comprises a plurality of storage arrays, including the local storage array further comprising computer program instructions that, when executed, cause the computer to carry out the steps of:
- prior to detecting the loss of the data communications connection between the local storage array and the remote, cloud-based storage array services provider:
- periodically retrieving, by the local storage array from the remote cloud-based storage array services provider, a current configuration of the cloud storage array services and the plurality of storage arrays.
18. The computer program product of claim 15, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and generating, by the cloud storage array services, metadata describing one or more real-time storage array characteristics further comprises:
- generating metadata describing one or more real-time storage array characteristics of each of the plurality of the storage arrays; and
- aggregating, for presentation to the user, the metadata of each of the plurality of storage arrays.
19. The computer program product of claim 15, wherein the data center further comprises a plurality of storage arrays, including the local storage array, and initiating the one or more cloud storage array services further comprises:
- selecting, by the local storage array in dependence upon workload characteristics of each of the plurality of storage arrays, one of the plurality of storage arrays to host the one or more cloud storage array services.
20. The computer program product of claim 19, further comprising computer program instructions that, when executed, cause the computer to carry out the steps of:
- detecting, by the local storage array, a change in workload characteristics of each of the plurality of storage arrays; and
- re-selecting one of the plurality of storage arrays to host the one or more cloud storage array services in dependence upon the changed workload characteristics.
Type: Application
Filed: Jun 11, 2015
Publication Date: Dec 1, 2016
Inventors: BENJAMIN P. BOROWIEC (SANTA CLARA, CA), TERENCE W. NOONAN (VADNAIS HEIGHTS, MN)
Application Number: 14/736,549