Data storage systems are arrangements of hardware and software that include storage processors coupled to arrays of non-volatile storage devices, such as magnetic disk drives, electronic flash drives, and/or optical drives, for example. The storage processors service storage requests, arriving from host machines (“hosts”), which specify files or other data elements to be written, read, created, deleted, and so forth. Software running on the storage processors manages incoming storage requests and performs various data processing tasks to organize and secure the data elements stored on the non-volatile storage devices.
Data storage systems commonly store host-accessible file systems and designate such file systems as either thick or thin. As is known, a “thick” file system is one that has a predetermined maximum size that is fully reserved. For example, a file system designated as thick with a maximum size of 100 GB reserves the full 100 GB of storage space for its exclusive use, even if the file system only consumes a fraction of that space. In contrast, a “thin” file system is not fully reserved. Rather, a thin file system may have an initial, default size of a few gigabytes. Reserved space for a thin file system grows in response to demand for additional space, e.g., in response to write requests. If the amount of space used in a thin file system decreases, e.g., on account of file deletions, a data storage system may decrease the amount of space reserved for that file system, such that reserved space for a thin file system both grows and shrinks in response to demand.
Unlike thick file systems, which have space requirements that are fully reserved and known to system administrators, thin file systems are variable in size and can thus present challenges in terms of storage planning. Thin file systems can also present challenges to hosts. For example, consider a host application that writes large amounts of data to a thin file system, such that the file system grows to accommodate the new data. Each time the thin file system receives new data that would cause it to grow beyond its currently-reserved storage space, the file system first obtains a new reservation for more storage space. The thin file system can only grow if the reservation is granted. If the file system grows considerably and then shrinks, e.g., in response to large deletes, the data storage system may reclaim previously reserved but now-unused storage space from the file system, such that the total reserved space of the file system falls to a level that more closely matches the amount of storage space actually used. If the host then sends a request to write new content to the file system that would exceed the currently reserved space, the file system requests a new reservation. But that reservation may be denied if the space is no longer available, e.g., on account of other file systems having consumed the available space. Thus, a host application may have 100 GB of reserved space one day, and then have only 10 GB of reserved space the next day. This discontinuity can be disruptive to host applications, as the applications can quickly run out of space.
In contrast with the above-described approach, which can present challenges for storage planning and can cause disruptions to host applications, an improved technique for managing storage space in a data storage system establishes an MSR (minimum space reservation) for a thin file system. The MSR defines a minimum amount of storage space that is fully reserved for the file system, such that reserved space for the file system does not fall below the level established by the MSR, even if the file system consumes less storage space than the MSR prescribes. With the MSR of a thin file system established, the file system can grow larger than the MSR, obtaining additional reservations as it grows, but it cannot shrink its reserved space to levels below the MSR, even if space below the MSR is not being used. The MSR thus sets a limit on how much a data storage system can shrink a thin file system. Enforcing this limit helps administrators with storage planning and helps to prevent host applications from running out of storage space following large deletions.
Certain embodiments are directed to a method for managing storage space in a data storage system. The method includes establishing an MSR (minimum space reservation) of a thin file system built upon a storage pool in the data storage system. In response to a set of storage requests to the file system to store new data that would cause a size of the file system to exceed the MSR, the method further includes obtaining an additional space guarantee from the storage pool to accommodate the new data. After obtaining the additional space guarantee, data are deleted from the file system such that the size of the file system falls below the MSR. The method then further includes performing a space reclaim operation, the space reclaim operation (i) compacting the file system to a size less than the MSR, (ii) canceling the additional space guarantee such that the storage pool no longer guarantees the additional space for the file system, and (iii) continuing to reserve the full MSR of the file system, even though the size of the file system is smaller than the MSR.
Other embodiments are directed to a data storage system constructed and arranged to perform a method of managing storage space, such as the method described above. Still other embodiments are directed to a computer program product. The computer program product stores instructions which, when executed by control circuitry of a data storage system, cause the data storage system to perform a method of managing storage space, such as the method described above.
The foregoing summary is presented for illustrative purposes to assist the reader in readily grasping example features presented herein; however, the foregoing summary is not intended to set forth required elements or to limit embodiments hereof in any way. One should appreciate that the above-described features can be combined in any manner that makes technological sense, and that all such combinations are intended to be disclosed herein, regardless of whether such combinations are identified explicitly or not.
The foregoing and other features and advantages will be apparent from the following description of particular embodiments of the invention, as illustrated in the accompanying drawings, in which like reference characters refer to the same or similar parts throughout the different views.
Embodiments of the invention will now be described. It should be appreciated that such embodiments are provided by way of example to illustrate certain features and principles of the invention but that the invention hereof is not limited to the particular embodiments described.
An improved technique for managing storage space in a data storage system includes establishing an MSR (minimum space reservation) for a thin file system. The MSR defines a minimum amount of storage space that is fully reserved for the file system, such that reserved space for the file system does not fall below the level established by the MSR, even if the file system consumes less storage space than the MSR prescribes. Providing this limit helps administrators with storage planning and helps to prevent host applications from running out of storage space following large deletions.
The network 114 may be any type of network or combination of networks, such as a storage area network (SAN), a local area network (LAN), a wide area network (WAN), the Internet, and/or some other type of network or combination of networks, for example. The hosts 110 may connect to the SP 120 using various technologies, such as Fibre Channel, iSCSI (Internet small computer system interface), NFS (network file system), and CIFS (common internet file system), for example. Any number of hosts 110 may be provided, using any of the above protocols, some subset thereof, or other protocols besides those shown. As is known, Fibre Channel and iSCSI are block-based protocols, whereas NFS and CIFS are file-based protocols. The SP 120 is configured to receive IO requests 112 according to block-based and/or file-based protocols and to respond to such IO requests 112 by reading or writing the storage 180.
The SP 120 includes one or more communication interfaces 122, a set of processing units 124, and memory 130. The communication interfaces 122 include, for example, SCSI target adapters and network interface adapters for converting electronic and/or optical signals received over the network 114 to electronic form for use by the SP 120. The set of processing units 124 includes one or more processing chips and/or assemblies. In a particular example, the set of processing units 124 includes numerous multi-core CPUs. The memory 130 includes both volatile memory, e.g., RAM (random-access memory), and non-volatile memory, such as one or more ROMs (read-only memory devices), magnetic disk drives, solid state drives, and the like. The set of processing units 124 and the memory 130 together form control circuitry, which is constructed and arranged to carry out various methods and functions as described herein. Also, the memory 130 includes a variety of software constructs realized in the form of executable instructions. When the executable instructions are run by the set of processing units 124, the set of processing units 124 are caused to carry out the operations of the software constructs. Although certain software constructs are specifically shown and described, it is understood that the memory 130 typically includes many other software constructs, which are not shown, such as an operating system, various applications, processes, and daemons.
As further shown in
Sparse volume 160 is constructed from provisioned slices 172a, e.g., slices S1-S4, which have been provisioned to the sparse volume 160 from the storage pool 170. The sparse volume 160 supports the file system 140, with the file system 140 being laid out on the sparse volume 160.
The file system 140 has a physical address range 142, which may extend from zero to some large number. In an example, each address in the physical address range 142 is designated by a file system block number, or “FSBN,” which uniquely identifies that block in the file system 140. A “block” is the smallest unit of allocatable storage space in the file system 140. Several blocks 144 are shown (not to scale). Blocks 144 typically have uniform size, such as 4 KB or 8 KB, for example. The file system 140 and the sparse volume 160 have corresponding structures. For example, each slice-sized region 172b of contiguously-addressable space in the file system 140 corresponds to a respective provisioned slice 172a in the sparse volume 160.
The memory 130 further includes a file system manager 140a and a pool manager 170a. The file system manager 140a manages operations of the file system 140, and the pool manager 170a manages operations of the storage pool 170. One should appreciate that any action described herein as being performed by the file system 140 or by the storage pool 170 generally indicates that the respective action is being performed by the file system manager 140a or by the pool manager 170a, respectively. Thus, the file system 140 and the storage pool 170 may be regarded as structures, whereas the file system manager 140a and pool manager 170a may be regarded as executable components that operate on these structures and/or on behalf of these structures.
The file system manager 140a includes an auto-shrink component 146. The auto-shrink component 146 may be run as a background process or daemon that reclaims free space from the file system 140 (and potentially from many such file systems). As will be described more fully below, the auto-shrink component 146 is configured to compact blocks 144 that are used in a file system into a smaller number of slice-sized regions 172b, such that one or more of the slice-sized regions 172b that previously contained data become free. The auto-shrink component 146 is further configured to identify provisioned slices 172a in the sparse volume 160 that correspond to the freed slice-sized regions 172b of the file system 140 and to return such provisioned slices 172a to the storage pool 170.
The pool manager 170a is configured to provision slices 172 to components requesting storage space and to reclaim slices 172 that are no longer required. The pool manager 170a also keeps track of insurance. Insurance provides a measure of space guarantees made by the storage pool 170, such as insurance granted to thick file systems to cover their maximum predetermined sizes and insurance granted to thin file systems to cover their currently-reserved sizes.
Memory 130 further includes an MSR (minimum space reservation) 150. The MSR 150 defines a lower limit of reserved storage space for the thin file system 140. The MSR 150 may be stored as a persistent data structure backed by the persistent storage 180. The MSR 150 may also have a memory-resident form. Although only a single thin file system 140 and a corresponding MSR 150 are shown, one should appreciate that the data storage system 116 may store many thin file systems and respective MSRs, e.g., one MSR for each thin file system.
In example operation, an administrator using computer 118 operates an administrative program 118a to create and specify settings of file systems in the data storage system 116. For example, the administrator or some other user may operate a GUI (graphical user interface) or a CLI (command line interface) rendered by the administrative program 118a, for entering commands and settings.
Here, the administrator operates the administrative program 118a to send a request 119 to create the thin file system 140. The request 119 includes a setting 119a for specifying a minimum space reservation (MSR) of the new, thin file system 140. The MSR specifies a minimum guaranteed amount of storage space for the thin file system 140. The storage processor (SP) 120 receives the request 119 at a communication interface 122 and initiates further processing.
In response to the request 119, file system manager 140a begins activities to create the new file system 140. For example, the file system manager 140a receives the MSR setting 119a as the value of MSR 150 and sends an insurance request 152 to the pool manager 170a. In an example, the insurance request 152 specifies an amount of storage space equal to the MSR 150. For example, if the setting 119a specified an MSR of N GB, the request 152 would specify N GB of insurance.
The pool manager 170a receives the insurance request 152 and performs a space-testing operation 174 to check for available storage space in the storage pool 170. “Available storage space” is the amount of storage space in the storage pool 170 that is not already reserved by other objects, such as other file systems. Continuing with the example above, the space testing operation 174 checks whether the storage pool 170 has N GB of available (unreserved) space. Insurance reply 154 then provides the result of the space-testing operation 174 back to the file system manager 170a. The result can arrive in the form of a confirmation, which indicates that the requested amount of space is available and has been reserved, or it can arrive in the form of a refusal, which indicates that the requested amount of space is not available. In the event of a confirmation, the file system manager 140a may continue its activities in creating the file system 140, such as by creating the sparse volume 160, creating a container for the file system 140, and formatting metadata. In the event of a refusal, the file system manager 170 may cancel its activities in creating the new file system and may send a reply to the request 119, indicating that the request 119 has failed. The administrator can then try sending another request 119, this time specifying a lower MSR setting 119a.
Once the file system 140 has been created, hosts 110 may issue IO (Input/Output) request 112 directed to the file system 140, e.g., to write new data and to read data. The file system 140 may start out with an amount of data less than the MSR, but it may eventually receive writes that cause it to grow. Once the amount of data in the file system 140 reaches the MSR, the file system 140 requires additional insurance from the storage pool 170 before it can grow any larger. In response to demand for additional storage space, the file system manager 140a issues another insurance request 152, this time seeking additional insurance to accommodate the new data. For example, the file system manager 140a may request an additional two slices 172. The pool manager 172 responds to the new request 152 by performing another space-testing operation 174, this time for reserving two new slices 172, and provides insurance reply 154. In this example, it is assumed that the new insurance request 152 is granted, and that the file system 140 is allowed to grow.
As shown by dimension lines above the file system 140, insuring the MSR 150 requires two slices (S1 and S2), while the additional insurance requires another two slices (S3 and S4). The total insured size of the file system 140 is thus four slices (the numbers of slices in this example is kept small for ease of illustration).
The file system 140 may continue to grow in this manner. It may also shrink. For example, hosts 110 may delete contents from the file system 140, creating holes (unused blocks) within slice-sized regions 172b. Auto-shrink component 146 may run in the background to compact the file system 140 in an effort to free slice-sized regions 172b, and then to return corresponding provisioned slices 172a to the storage pool 170. When slices return to the storage pool 170, the pool manager 170a cancels any additional insurance corresponding to the returned slices. However, in no event is the insurance guarantee of the MSR canceled. Rather, the data storage system continues to enforce the MSR, such that the file system 140 is guaranteed to have at least as much reserved space as the MSR prescribes.
Although the MSR is described above as a setting that accompanies a file-system creation request, an MSR setting may also accompany a request the change one or more settings of a file system that has already been created. For example, the administrator may operate program 118a to increase or decrease the MSR 150 of the file system 140 at any time. A request to increase the MSR of the file system 140 may require the file system manager 140a to send a request 152 for additional insurance, e.g., if the total insured size of the file system 140 is less than the total insurance required to support the new MSR. The request 152 may result in a success or a failure. In the case of success, the MSR 150 is updated to the new value. In the case of failure, the MSR 150 stays the same as before and the data storage system 116 may fail the administrator's request. If the total insured size exceeds the new MSR, then no new insurance request 152 is needed, as the file system 140 already has the total insurance it needs to support the change. In such cases, the SP 120 merely updates the MSR 150 to reflect the new value, which the data storage system 116 enforces going forward.
One consequence of this arrangement is that an administrator can generally change the MSR of the file system 140 to any value that does not exceed the file system's current size, i.e., the amount of storage space actually used to store the file system's data and metadata. Thus, for example, the administrator can simply change the MSR of the file system 140 to the current size (or something smaller) without concern that the change will fail.
As shown in
In
After the auto-shrink component 146 has run, a host 110 may access the file system 140 and detect that the file system 140 is much smaller than it was before (as in
Enforcing the MSR 150 thus has the effect of limiting the amount of reserved storage space that the auto-shrink component 146 can reclaim from the file system 140. Although users may see sudden reductions in reserved space as a result of auto-shrink, they can rest assured that the file system 140 will always be left with at least a minimum known quantity of reserved space, which users can control and rely upon going forward.
When the file system 140 is subject to replication, as in
To avoid such failures, the data storage systems 116 and 316 coordinate to ensure that the MSR 350 of the replica 340 in the data storage system 316 is at least as large as the MSR 150 of the file system 140 in the data storage system 116. In the figure, numerals shown in parentheses indicate an example sequence of operations for ensuring that MSR 350 is at least as large as MSR 150.
At (1), the data storage system 116 receives a request 119 to establish (or change) the MSR of the file system 140. This request is similar to the one described in connection with
At (4), the data storage system 116 sends a request to the second data storage system 316. The request at (4) may be similar to the request 119, in that it specifies a requested MSR. In this case, the request is to establish a value of the MSR 350. At (5), in the second data storage system 316, the file system manager 340a sends an insurance request (like 152) to the pool manager 370a, requesting enough insurance to cover the full MSR as received in the request 119. The pool manager 370a performs a space-testing operation (like 174). If the space-testing operation 174 succeeds, then at (6) the pool manager 370a sends a successful reply (like 154) back to the file system manager 340a.
At (7), the second data storage system 316 confirms that it was able to establish the requested MSR for the replica 340. As both data storage systems 116 and 316 can provide the requested MSR, a response 319 at (8) acknowledges that the request 119 has been granted. One should appreciate that granting the request 119 to establish or update the MSR 150 of the file system 140 is contingent upon both (1) the storage pool 170 being able to insure the MSR 150 and (2) the storage pool 370 being able to insure the same MSR 150. Failure of either storage pool to insure the full MSR 150 may result in a failure of the request 119, such that the response 319 provides a failing result.
Although the sequence depicted in
As is known, a “snap” is a point-in-time version of a data object, which provides a checkpoint from which a data storage system can recover in the event of a failure or problem with a production version of the data object, or for any reason. In an example, the data storage system 116 may have a policy of creating a new snap of the file system 140 once per day. If a user accesses the file system 140 one morning and opens a file that contains a computer virus, which attacks and corrupts other files in the file system 140, the administrator can operate the administrative program 118a to restore from the most recent snap, which then becomes the new production version of the file system 140. As the snap was created prior to the attack, the snap provides a safe point from which to restore and resume operations.
As shown in
As shown in
The lower-deck file system 530 is laid out on a lower-deck sparse volume 520, which includes provisioned slices 512a populated from a lower-deck pool 510. The lower-deck pool 510 contains slices 512, which may be formed from RAID groups. Thus, the arrangement of lower-deck structures 510, 520, and 530 are analogous to structures 170, 160, and 140, respectively, in
In a similar manner, the upper-deck file system 570 is laid out on an upper-deck sparse volume 560, which includes provisioned slices 552a populated from an upper-deck pool 550. The upper-deck pool 550 contains slices 552. Here, the slices 552 are formed by expressing the file 540 as a volume and carving the volume into slices 552.
It can be seen that the arrangement of
Owing to the mapping relationship between the upper-deck file system 570 and the container file 540, the size of the upper-deck file system 570 is merely the file size of the container file 540. The process for reserving space in the upper-deck file system 570 therefore translates to a process for reserving space for the container file 540. A request to establish an MSR 150 of the upper-deck file system 570 may thus be satisfied by insuring the container file 540 in the lower-deck pool 510 to the same extent as the MSR.
For example, assume that a request 119 (
At 610, an MSR (minimum space reservation) 150 is established for a thin file system 140 built upon a storage pool 170 in the data storage system 116. The MSR 150 may be established, for example, in response to a request 119 from an administrative program 118a to create the file system 140 or to change any of its settings.
At 620, in response to a set of storage requests 112 to the file system 140 to store new data that would cause a size of the file system 140 to exceed the MSR 150, an additional space guarantee 210 is obtained from the storage pool 170 to accommodate the new data. For example, writes directed to the file system 140 may cause the file system 140 to grow, triggering the file system manager 140a to send one or more insurance requests 152 to the pool manager 170a.
At 630, after obtaining the additional space guarantee 210, data from the file system 140 are deleted such that the size of the file system 140 falls below the MSR 150.
At 640, a space reclaim operation (e.g., auto-shrink 146) is performed. The space reclaim operation 146 includes (i) compacting the file system 146 to a size less than the MSR 150, (ii) canceling the additional space guarantee 210 such that the storage pool 170 no longer guarantees the additional space for the file system 140, and (iii) continuing to reserve the full MSR 150 of the file system 140, even though the size of the file system 140 is smaller than the MSR 150.
An improved technique has been described for managing storage space in a data storage system 116. The technique includes establishing an MSR (minimum space reservation) 150 for a thin file system 140. The MSR 150 defines a minimum amount of storage space that is fully reserved for the file system 140, such that reserved space for the file system does not fall below the level established by the MSR 150, even if the file system 140 consumes less storage space than the MSR 150 prescribes. Providing this limit helps administrators with storage planning and helps to prevent host applications from running out of storage space following large deletions.
Having described certain embodiments, numerous alternative embodiments or variations can be made. For example, although particular arrangements of storage constructs are shown and described, such as sparse volumes, slices, and the like, these are shown by way of example and should not be construed as limiting.
Also, while the auto-shrink component 146 is described as a background process or daemon for reclaiming storage space, this is merely an example, as other methods for reclaiming unused storage space may be employed. One alternative would be to perform inline reclamation, which would respond directly to requests to delete contents by consolidating space.
Further, although features are shown and described with reference to particular embodiments hereof, such features may be included and hereby are included in any of the disclosed embodiments and their variants. Thus, it is understood that features disclosed in connection with any embodiment are included as variants of any other embodiment.
Further still, the improvement or portions thereof may be embodied as a computer program product including one or more non-transient, computer-readable storage media, such as a magnetic disk, magnetic tape, compact disk, DVD, optical disk, flash drive, solid state drive, SD (Secure Digital) chip or device, Application Specific Integrated Circuit (ASIC), Field Programmable Gate Array (FPGA), and/or the like (shown by way of example as medium 650 in
As used throughout this document, the words “comprising,” “including,” “containing,” and “having” are intended to set forth certain items, steps, elements, or aspects of something in an open-ended fashion. Also, as used herein and unless a specific statement is made to the contrary, the word “set” means one or more of something. This is the case regardless of whether the phrase “set of” is followed by a singular or plural object and regardless of whether it is conjugated with a singular or plural verb. Further, although ordinal expressions, such as “first,” “second,” “third,” and so on, may be used as adjectives herein, such ordinal expressions are used for identification purposes and, unless specifically indicated, are not intended to imply any ordering or sequence. Thus, for example, a “second” event may take place before or after a “first event,” or even if no first event ever occurs. In addition, an identification herein of a particular element, feature, or act as being a “first” such element, feature, or act should not be construed as requiring that there must also be a “second” or other such element, feature or act. Rather, the “first” item may be the only one. Although certain embodiments are disclosed herein, it is understood that these are provided by way of example only and that the invention is not limited to these particular embodiments.
Those skilled in the art will therefore understand that various changes in form and detail may be made to the embodiments disclosed herein without departing from the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
7467276 | Kahn | Dec 2008 | B1 |
8284198 | Hackworth | Oct 2012 | B1 |
8364858 | Martin | Jan 2013 | B1 |
8515904 | Dwyer, III | Aug 2013 | B1 |
8819362 | Duprey | Aug 2014 | B1 |
8838887 | Burke | Sep 2014 | B1 |
8898402 | Stronge | Nov 2014 | B1 |
8959305 | Lecrone | Feb 2015 | B1 |
8976636 | Martin | Mar 2015 | B1 |
8996837 | Bono | Mar 2015 | B1 |
9092290 | Bono | Jul 2015 | B1 |
9122697 | Bono | Sep 2015 | B1 |
9122712 | Bono | Sep 2015 | B1 |
9176681 | Xu | Nov 2015 | B1 |
9256603 | Bono | Feb 2016 | B1 |
9256614 | Bono | Feb 2016 | B1 |
9256629 | Bono | Feb 2016 | B1 |
9304999 | Bono | Apr 2016 | B1 |
9305009 | Bono | Apr 2016 | B1 |
9305071 | Bono | Apr 2016 | B1 |
9323655 | Sahin | Apr 2016 | B1 |
9329803 | Bono | May 2016 | B1 |
9330155 | Bono | May 2016 | B1 |
9378219 | Bono | Jun 2016 | B1 |
9378261 | Bono | Jun 2016 | B1 |
9400741 | Bono | Jul 2016 | B1 |
9400792 | Bono | Jul 2016 | B1 |
9424117 | Bono | Aug 2016 | B1 |
9477431 | Chen | Oct 2016 | B1 |
9507787 | Bono | Nov 2016 | B1 |
9507887 | Wang | Nov 2016 | B1 |
9524233 | Venkatasubramanian | Dec 2016 | B2 |
9535630 | Bono | Jan 2017 | B1 |
9558111 | Balcha | Jan 2017 | B1 |
9569455 | Bono | Feb 2017 | B1 |
9594514 | Bono | Mar 2017 | B1 |
9778996 | Bono | Oct 2017 | B1 |
9805105 | Bono | Oct 2017 | B1 |
9842117 | Zhou | Dec 2017 | B1 |
9846544 | Bassov | Dec 2017 | B1 |
9864753 | Armangau | Jan 2018 | B1 |
9870366 | Duan | Jan 2018 | B1 |
9880777 | Bono | Jan 2018 | B1 |
9881014 | Bono | Jan 2018 | B1 |
9916102 | Bassov | Mar 2018 | B1 |
9916202 | Seela | Mar 2018 | B1 |
9916312 | Haase | Mar 2018 | B1 |
9940331 | Bono | Apr 2018 | B1 |
9965381 | Sahin | May 2018 | B1 |
9983942 | Seela | May 2018 | B1 |
10013217 | Bono | Jul 2018 | B1 |
10013425 | Bassov | Jul 2018 | B1 |
10037251 | Bono | Jul 2018 | B1 |
10048885 | Bono | Aug 2018 | B1 |
10089316 | Haase | Oct 2018 | B1 |
10095425 | Martin | Oct 2018 | B1 |
10114754 | Pendharkar | Oct 2018 | B1 |
10268693 | Nanda | Apr 2019 | B1 |
10289690 | Bono | May 2019 | B1 |
10346360 | Basov | Jul 2019 | B1 |
10409496 | Si | Sep 2019 | B1 |
10409687 | Bono | Sep 2019 | B1 |
10409768 | Kuang | Sep 2019 | B2 |
10409776 | Bassov | Sep 2019 | B1 |
10447524 | Bono | Oct 2019 | B1 |
10521398 | Forrester | Dec 2019 | B1 |
10592469 | Bassov | Mar 2020 | B1 |
10613787 | Yu | Apr 2020 | B2 |
10671309 | Glynn | Jun 2020 | B1 |
10789017 | Bono | Sep 2020 | B1 |
10838634 | Bassov | Nov 2020 | B1 |
10983964 | Bono | Apr 2021 | B1 |
11100050 | Zhang | Aug 2021 | B1 |
20050193023 | Ismail | Sep 2005 | A1 |
20050234824 | Gill | Oct 2005 | A1 |
20070260830 | Faibish | Nov 2007 | A1 |
20070260842 | Faibish | Nov 2007 | A1 |
20080005468 | Faibish | Jan 2008 | A1 |
20090218922 | Chinuki | Sep 2009 | A1 |
20090300023 | Vaghani | Dec 2009 | A1 |
20110060887 | Thatcher | Mar 2011 | A1 |
20110153977 | Root | Jun 2011 | A1 |
20110283342 | Yamada | Nov 2011 | A1 |
20110296133 | Flynn | Dec 2011 | A1 |
20120011340 | Flynn | Jan 2012 | A1 |
20120166751 | Matsumoto | Jun 2012 | A1 |
20120239729 | Hefter | Sep 2012 | A1 |
20130117526 | Florendo | May 2013 | A1 |
20140258670 | Venkatasubramanian | Sep 2014 | A1 |
20140298317 | Devine | Oct 2014 | A1 |
20150234841 | Hebert | Aug 2015 | A1 |
20170075708 | Dalal | Mar 2017 | A1 |
20170075779 | Grimaldi | Mar 2017 | A1 |
20170075781 | Bennett, Jr. | Mar 2017 | A1 |
20170090766 | Gong | Mar 2017 | A1 |
20170177238 | Tati | Jun 2017 | A1 |
20170228206 | Bungert | Aug 2017 | A1 |
20170316027 | Mondal | Nov 2017 | A1 |
20180095955 | Kuang | Apr 2018 | A1 |
20180307537 | Chen | Oct 2018 | A1 |
20190129626 | Armangau | May 2019 | A1 |
20210034520 | Davenport | Feb 2021 | A1 |
Entry |
---|
EqualLogic, About thin provisioning, 2010, Dell, Version 5.0, pp. 1-5 (Year: 2010). |
Eric Slack, Is All Thin Provisioning the Same, Jun. 4, 2013, StorageSwiss.com, pp. 1-5 (Year: 2013). |
“EMC CLARiiON Reserved LUN Pool Configuration Considerations; Best Practices Planning”, Sep. 2010, 23 pages. |