This disclosure relates in general to the field of communications and, more particularly, to implementing IPv6 based storage systems and for supporting gigantic and distributed storage space.
The estimated total amount of digital data generated in 2013 was approximately 3.5 zettabytes (3.5 billion terabytes). By 2020, it is estimated that the world will generate 40 zettabytes of data annually; roughly the equivalent of one million photographs or 1500 High Definition (“HD”) movies, for every single person on the planet. Existing storage systems utilize collections of local storage devices (e.g., disks) that may be grouped in different arrangements to create, for example, RAID configurations. This technique has worked relatively well, but while the various arrangements of local storage devices differ in detail, they share a number of deficiencies. These deficiencies are due primarily to a reliance on hardware storage devices, resulting in a number of limitations and technical tradeoffs that render such systems non-optimal for creating massively distributed gigantic storage units.
In particular, multi-disk configurations rely on local physical storage devices combined with controllers and servers. Currently, individual disk size is limited to 10 TB; grouping many disks together in the same place is good for maintaining good performance but results in concerns regarding availability. Additionally, multi-disk hardware controllers are limited in both capacity as well as in the number of hard disks that may be connected to them. Other limitations result from the fact that the need for sophisticated replication strategies to provide high data resiliency and availability and server load scaling leads to the deployment of custom, heavyweight approaches. Moreover, partly due to the complexity of their management, data storage systems are usually located in fairly centralized locations in the network, such as data centers, such that the majority of data traffic originates from this limited number of locations. Finally, bringing in any significant additional data storage usually requires repackaging of the whole system in a format adapted to the new data storage system.
To provide a more complete understanding of the present disclosure and features and advantages thereof, reference is made to the following description, taken in conjunction with the accompanying figures, wherein like reference numerals represent like parts, in which:
A method is provided in one example embodiment and includes, for each of a plurality of individual storage units collectively comprising a virtual storage unit, mapping an internal address of the storage unit to a unique IP address, wherein each of the storage units comprises a block of storage on one of a plurality of physical storage devices and wherein the IP address includes a virtual storage unit number identifying the virtual storage unit; receiving from a client a request to perform an operation on at least one of the data storage units, wherein the request identifies the internal address of the at least one of the data storage units; translating the internal address of the at least one of the data storage unit to the unique IP address of the at least one of the data storage units; and performing the requested operation on the at least one of the data storage units.
A purpose of embodiments of the disclosure is to define a method as well as a set of atomic operations for managing massively distributed data storage systems. Another purpose is to create a high-level abstraction on top of distributed data storage, enabling easy control and concealing the underlying complexity. Certain embodiments relate to a distributed storage system far larger than currently available storage systems (e.g., in the range of 1,000 s of zettabytes). Embodiments of the disclosure may leverage IPv6 properties and may be applicable in data center and/or public networks. An embodiment of the disclosure also relates to a new approach for transparently implementing redundancy as well as replication mechanisms. An embodiment of the disclosure further relates to replacing protocols such as iSCSI or HyperSCSI.
The introduction of IPv6 architectures enables revisitation of the myriad design challenges described hereinabove. In particular, the shift from centralized data storage system and single-point access to a massively distributed approach at the inter-networking layer makes possible the design of massive data storage systems. Similarly, the shift from a centralized to a massively distributed approach makes possible the design of more optimal redundant systems. However, utilizing the properties of a modern IPv6 architecture alone to achieve a simpler, higher efficiency, and more scalable data storage system may not simplify the management of the resulting system. Centralized data storage systems, such as Storage Area Network (“SAN”) or Network Attached Storage (“NAS”), are relatively easy to manage, whereas managing a truly distributed-in-the-network data storage system of a comparable or even far bigger global size creates many additional problems to solve. An advantage of distributed data systems is that they enable keeping data safe and always available.
Logical Block Addressing (“LBA”) blocks mapping 4 kilobyte (“KB”) disk block size have become a de facto industry standard. Assuming a 4 KB block size, the total LBA addressing space is about 75 zettabytes (“ZB”). Building a 75 ZB space with the 10 TB disks currently available would require 750 million disk units.
In one aspect of embodiments for implementing IPv6-based distributed storage space in accordance with features described herein, a 4 KB storage unit is mapped to an IPv6, or simply v6, address. These v6 addresses may be routable or link local addresses, depending on the visibility to be given to the 4 KB storage space. It is assumed that it is possible to either read or write the 4 KB data associated with the v6 address. On a managed network, Maximum Transmission Unit (“MTU”) size could also be set to 4 KB, which would allow mapping of a storage unit onto a single packet thus enabling better performances.
In another aspect of embodiments for implementing IPv6-based distributed storage space in accordance with features described herein, it will be recognized that defining a v6 prefix using embodiments described herein is the equivalent of defining a disk in the LBA world. For instance a /64 prefix may be used to define something equivalent to the maximum size that a physical disk could potentially have in the future. As a result, the current physical limitations on disk size may be surpassed and an even bigger storage space may be defined using the embodiments described herein. This aspect may be used to enable creation of virtual disk space of various sizes. In particular, creating a super-giant contiguous storage space might not be the most convenient for certain situations. In such situations, a larger or smaller prefix could be defined. For example, assigning a /56 prefix to storage would allow creation of 16,777,216 storage spaces of 1 Exabyte each. It is therefore easy to define many different contiguous storage spaces each of them having very different sizes.
In certain aspects, the mapping between v6 addresses representing 4 KB addressable storage units and real physical endpoints is neither defined nor dictated by embodiments described herein. A physical device can therefore host several 4 KB storage units, each of which may be accessible through its own v6 address. In yet another aspect, selecting the device containing the requested 4 KB storage unit is managed by a network-forwarding plane. To optionally simplify this aspect, it may be assumed that 4 KB storage units hosted on the same device have consecutive addresses. The 4 KB storage units may therefore be totally distributed across the network and still be seen as a continuous super large LBA-like storage unit. This enables definition of a kind of contiguous address space, which can also be seen as a device local prefix.
Based on the above, the following terms may be defined:
Storage Domain: Storage domain may be defined by a v6 prefix. This prefix could be virtually of any size (e.g., /64 or /56) depending on the targeted applications.
Storage Space: Storage space may be defined by the remaining address bits (e.g. 72 least significant bits (“LSBs”)).
Storage Address Space: Storage address space is the list of contiguous v6 addresses from a storage space. By convention, the first address is always StorageSpaceStartAddressPrefix:0.
Virtual Unit: A storage space is equivalent to very large LBA address space. Each storage space may be divided in smaller units called virtual units. A virtual unit can be defined by a number of most significant bits (“MSBs”) from the storage address. For example, 10 bits can be allocated for virtual units numbering. To keep things simple, all virtual units should be the same size. A virtual unit therefore also defines a prefix (e.g. /66) that can be used to address storage units from the particular virtual unit. Having virtual units of different sizes is technically possible, but could lead to wasting addresses, since each v6 address from one storage space can't belong to more than one virtual unit.
Based on the foregoing concepts, it is apparent that virtual units are analogous to more conventional hardware disk drives. A virtual unit can be identified as soon as its corresponding prefix is known. In the illustrated embodiment, the virtual unit prefix results from a concatenation of the storage domain prefix and the virtual unit number. As illustrated in
The mapping between the unit address space and the physical devices containing the corresponding storage units may be defined by the network topology, thereby enabling the corresponding physical storage to be transparently distributed on several network nodes. A virtual unit is said to be fully accessible as long as any one of its constituents (i.e., the storage units) is accessible. Since a virtual unit may be physically distributed on many physical machines across the network, there is a good chance that at least one of the machines will be down or inaccessible, compromising the accessibility of the entire virtual unit. Based on this notion, it is clear that statistically most of the time a virtual unit will be not accessible.
Alternatively, assuming that a storage device contains several virtual units, it becomes possible to define different RAID or Just a Bunch Of Disks (“JBOD”) configurations as is done with real physical HDDs. However, RAID (apart from RAID 0) has been designed to guarantee data accessibility when one or more disks are not accessible or even broken. Because of the distributed nature of virtual units, as described above, on average all disks from the RAID will be inaccessible such that the RAID will not work at all. This raises some issues with regard to virtual unit accessibility. One way to address these issues is to manage replication at the storage unit level and not at the virtual unit level. This may be a built-in feature comparable to what optical disks (CD, DVD, BR, etc.) achieve internally and transparently.
To implement replication at the storage unit level, the m MSBs from the unit address space 18 are used. It may also be possible to use the m LSBs instead, but presumably use of the MSBs provides better storage unit replica distribution across the network based on the assumption that, on average, there is a good chance that a physical machine may host consecutive addresses from the unit address space. Another advantage of this approach is that it maintains the internal unit address space continuous, thus maintaining a direct mapping to the LBA world.
Management of storage unit replicas could be performed as a network function and thus be performed transparently to the application. Referring to
As a result, two consecutives addresses from the storage address space and belonging to the same virtual unit do not represent two consecutives storage units. However, this is not a problem since, replications bits aside, the internal unit address space is still continuous (but smaller). In other words, a virtual unit contains (or internally supports) some replication mechanism, which can stay hidden to the application as long as the virtual unit exposes a reduced address range.
The fact that replicas of the same storage units are deliberately distributed across the network makes any virtual unit globally eventually consistent, which in turn makes read-modify-write then re-read sequence of disk I/O operations potentially difficult to synchronize. In essence, this is similar to what occurs in a RAID system, in which all replicas must be written before declaring the LBA block finally written. This may be accomplished using a storage unit versioning technique or journaling function to maintain files internal consistency for read and modify operations. In certain embodiments, this may be performed as a virtual unit internal feature.
In some embodiments, the global virtual unit availability depends on several availability of each of these physical devices, the number of replicas for each storage unit, and the network itself. Each of these parameters may be adjusted, depending on the targeted application. Internally replicated virtual units can be combined together to create a RAID system, for example.
The issue of disk partitioning in the context of an IPv6-based distributed storage space in accordance with embodiments described herein will now be addressed. In the conventional LBA world, disks are often split into partitions. Although there are some commonly used standards, the manner in which disk partitions are managed is highly operating system dependent. LBA numbering translation is another common feature disk drivers support. As a result, within a partition the LBA logical address of the first block is always 0. In one case, a partition will be defined by the address of its first storage unit in the unit address space range. Symmetrically adding the partition logical address of any partition storage to the address of the first storage unit of the partition will give the absolute address of the same storage unit within the virtual unit address space. This is very similar to what a classical disk driver does.
The issue of filesystems support in the context of an IPv6-based distributed storage space in accordance with embodiments described herein will now be addressed. Since a virtual unit may be assimilated to a LBA disk (regardless of the management of replicas), a classical filesystem may be implemented by replacing the classical HDD driver by some virtual unit network driver (“VUND”). This enables definition of a number of relevant equivalencies. First, a hard disk drive (“HDD”) is equivalent to a virtual unit. Second, an HDD LBA block is equivalent to one address from the unit address space (not including the MSB replications bits), or a storage unit. Since replication can be seen as an internal virtual unit mechanism, any HDD LBA block address will have the replication bits set to a fixed and constant value (e.g. to 0). An HDD LBA block having the address n will have the following v6 equivalent address:
StorageDomainPrefix:VirtualUnit:Replication(0):n
Finally, a storage domain is equivalent to a forest of internally replicated as well as spread across the network HDDs.
In another aspect of an IPv6-based distributed storage space in accordance with embodiments described herein, to maintain compatibility with existing systems, storage unit replicas (when they exist) will remain hidden to the application (e.g., the filesystem). To achieve this, replication bits from the storage unit full v6 address will be artificially set to 0. What happens underneath is implementation-dependent, as detailed below.
Any classical filesystem (Ext4, NTFS, etc.) essentially writes and reads LBA blocks (from 0 to n) within a partition. The disk driver is responsible for translating this partition internal addressing in some LBA addressing on the right disk. Similarly, the VUND translates the partition internal addressing in the corresponding storage unit network addressing. The VUND may also support some RAID configuration at the same time without the application (e.g., the filesystem) even noticing.
The VUND will now be addressed in greater detail.
It will be recognized that, as compared to a local disk drive (e.g., HDD driver 46 connected to local disk 47), certain aspects of the performance of distributed storage may not be optimal for certain applications. The effects may be mitigated by maintaining the machines hosting the storage units in a data center topologically close to the machines running the different filesystem applications (e.g., filesystems FS1-FSn). However in implementations in which the storage units are truly distributed across a wide (potentially public) network, certain applications may be targeted. Such applications are generally those that require large data volume, high data redundancy, high data availability, and simultaneous multi-access, but that do not require complete and instantaneous consistency across replicas or very high I/O throughput.
Embodiments of the disclosure also enable other models in which data needs to be shared between different applications or entities. For instance, embodiments of the disclosure make possible the creation of a super large in-the-network-caching system. The in-the-network characteristic of such a caching system does not mean that the physical caches are physically part of the network gears themselves; rather, that the fact that the whole cache is accessible via v6 addressing makes the actual deployment transparent to the application. Additionally, due to distribution of storage units across the network, it also possible to envisage creation of specific filesystems in which the VUND internally manages a replication management in a transparent manner (Disk Compatibility mode). Additionally, the filesystem may embody characteristics such as encryption of all storage units that contain data, as well as storage of filesystem control structures (inodes, directories, bitmaps, etc.) and file data in different and separated virtual units. Filesystem characteristics may also include that the virtual unit that contains the filesystem control structures may be locally hosted on a fully secured network (e.g., a company LAN); the filesystem control structures may also be encrypted. Finally, the virtual unit containing file data may be outsourced and hosted on servers running in different clouds, for example. Structure may be protected in different data centers. In this manner, user data stored in the filesystem is difficult, if not impossible, to access as long as the filesystem structure can be protected against malicious attacks.
Separating filesystem control structures from file data in different storage units enables data to be fully secured in the file system and render filesystem reverse engineering virtually impossible. This further enables user data to be fully secured in a super large and redundant filesystem without the need to fully secure the whole storage.
Use of the VUND in RAW mode allows revisitation of numerous implementation paradigms. As an example, databases, such as a Cassandra cluster, for example, may benefit from embodiments of the disclosure, since the cluster would become a purely logical view fully independent from the physical implementation. It could also greatly contribute to simplify the implementation of the internal replication mechanism of the Cassandra cluster. Another possible implementation of embodiments of the disclosure may be to implement map reduce framework radically differently. Embodiments of the disclosure can also be used as a replacement for iSCSI protocol, which is commonly used to access a Storage Area Network (“SAN”) in data centers. In order to ensure performances comparable to existing SAN, it would make sense to deploy the corresponding storage domain(s) in some physically separated network.
The default 4K storage unit size is employed in embodiments described herein to simplify the compatibility of the disclosed embodiments with existing storage systems; however, it will be recognized that any storage unit size may be utilized. The storage unit size could be a storage domain or virtual unit parameter. In this manner, the total addressable storage size becomes virtually infinite. The ability to define storage units of any size enables the storage unit size to be deemed equal to the filesystem cluster size (e.g. 64 KB for ReFS), which would greatly increase filesystem performances. In one embodiment, the 4K default size is necessary for supporting Disk Compatibility mode described above, but is not necessary for any other type of application. One possible extension to embodiments described herein would be to use a v6/SR approach to implement replicas management.
Embodiments of the disclosure revisit the concept of “network storage” and propose a new implementation of this concept. It is differentiated by, among other things, its capacity to support current size storage space, as well as virtually limitless storage space. Embodiments of the disclosure also revisit the concept of disk, arrays of disks (e.g., RAID), and network area network (e.g., SAN) systems. The embodiments brings a lot of flexibility as well as internal flexible replication mechanism working at the storage unit level. This latter mechanism when controlled by the application also allows revisiting the implementation of new databases (Cassandra) or distributed filesystem (Hadoop) implementations.
Embodiments of the disclosure can also be used to implement almost all existing storage systems as well as the associated applications (filesystems, etc.) but can also support new category of applications, such as big data framework or dedicated database without any storage space limitation. Embodiments of the disclosure leverage the v6 address model and may benefit from additional v6 mechanisms, such as segment routing, to implement some storage management internal features. Embodiments of the disclosure leverage IPv6 patterns to (re)implement all storage (such as disks, RAID, SAN, filesystem) and distributed database paradigms (Cassandra, Hadoop) in a unified network built-in design.
Potential advantages for certain embodiments described herein may, but are not limited to, one or more of the following. Certain embodiments may enable support for super large storage address space at least far bigger than what can be achieved with today technologies. Certain embodiments may offer a natural support for gigantic Berkeley (UFSx) or IBM (GPFS) filesystems. Certain embodiments may support replication at the storage unit that cannot be achieved with classical approaches, such as RAID, which are managing redundancy at HDD level. Certain embodiments enable revisitation of some large modern database implementation as well as other frameworks (e.g. map/reduce). Certain embodiments enable transparent distribution of the physical storage (as well as associated replicas) in different places, thus making the whole storage more resilient to issues such as data center outages, for example. The mapping between the v6 addresses used to access individual storage units and the corresponding physical locations can be defined by the network physical topology and is therefore far more flexible than traditional approaches in which physical locations are dictated by other physical constraints. Additionally, certain embodiments can be seen as more powerful and more flexible alternative to iSCSI protocol.
Embodiments of the disclosure could be used in a variety of implementations including, for example, in data centers to implement large data storage systems; as an infrastructure to support very large exotic filesystems; to protect privacy data when stored in a public cloud or a publicly accessible public storage infrastructure; to implement resilient systems for storing data; and to implement SAN in an alternative manner.
Throughout this disclosure, “virtual disk,” “pseudo-disk”, and/or “virtual HDD” refer to the equivalent of the LBA address space exposed by classical HDD. The main difference is that physical HDD exposes a limited LBA address range driven by its internal capacity whereas embodiments of the disclosure enables potential extension of the LBA address space beyond 64 bits.
In one approach, scalability derives from the virtual disk itself. Embodiments described herein creates what is equivalent to a single HDD having a capacity of several Exabytes also managing internal as well as transparent 4K pseudo LBA blocks replication mechanism. Rather than representing a piece of a file, each 4K block comprises a “network equivalent” of a classical HDD LBA block. As a consequence of the above, any type of existing filesystem such as ext3, HDFS or even a FAT32 can sit on top this “virtual drive” mechanism without even noticing.
Retrieving content happens in the exact same way it happens for disk attached to a computer, such as a local laptop, except that the SATA disk driver interacts not with a real physical HDD but rather to a collection of servers, each of which is responsible for a subpart of the global virtual disk.
As opposed to conventional approaches, replication is not managed by a filesystem or by a distributed filesystem, such as Hadoop, but is rather managed at the block storage level. One possible technique for implementing the replication mechanism is basically a brute force approach in which each 4K storage block is replicated on different servers. In this technique, the MSBs of the address right after the replication bits can be viewed as a prefix for a replicas family. Consistency is maintained between replicas as follows.
With regard to a WRITE operation, as will be described in greater detail below, a 4K block (or multi-block) write operation is launched on all replicas in parallel. The VUND adds a timestamp alongside the data to write. The WRITE operation is considered complete as soon as at least some (e.g., one, a quorum, or all) of the replicas are updated. Servers hosting replicas of the same block(s) are constantly communicating to keep all replicas up-to-date. In certain embodiments, this is achieved using a variant of GOSSIP. Briefly, if a server hosting a replica misses a write operation because it was down or simply unreachable or because of a time-out, the server will compare its own timestamp to timestamps from other severs. The server or servers hosting the data most recent timestamp wins. With regard to a READ operation, as will also be described in greater detail below, the VUND initiates parallel READ operations on all replicas and selects the one having the most recent timestamp. This mechanism is partially inspired by that employed in connection with optical disks (e.g., CD-ROM, DVD-ROM), in which the same block is replicated in different places on the disk to accommodate the risk of scratches. With four replicas, the probability of inconsistent data (i.e., not being able to read back what has been previously written) is about 10−30, which is better than what today's physical HDD or RAID can provide.
In distributed filesystem or database approaches, such as Hadoop or Cassandra, latency is highly dependent on the cluster configuration. For instance, on a Cassandra ring of 10 nodes with a replication factor of 4, there are 6 chances out of 10 that the required data is not on the node used to access the data, thereby leading to additional data transfers between nodes to make the data available from the node used by the application for accessing the Cassandra database. In certain embodiments described herein, latency is almost constant since for accessing 4K block(s) pertaining to a file the sequence is always the same:
(local IO operation)→(access storage server(s))→(server(s) access(es) its/their local storage)→(data transfer back to VUND)→(VUND copies data to the filesystem buffer cache)
Operations designated (access storage server(s)) and (data transfer back to VUND) are network transfers for which the latency in a data center is known and almost constant. Embodiments described herein are primarily designed to support applications in which very large storage space is required and where data integrity is key but without the cost of managing data backups. One such application is long-term storage of video assets. This could be used by an origin server to e.g. store all the video chunks (different qualities, etc.) coming out from a video encoding factory. Another such application is document archiving. Yet another such application is re-implementing distributed database designs, such as Cassandra clusters.
Embodiments of the disclosure are also a replacement of the traditional implementation of a disk driver. Briefly, the VUND translates any access to an LBA name space in network accesses in a fully transparent way. The VUND therefore does not “discover” the disk/network; the only thing the driver needs to know is a v6 prefix representing the virtual unit (see
Each server hosting one replica family (e.g. replication bits set to 10) from a subpart of the overall virtual disk can be seen as a prefix (e.g. a /120). As soon as there is a route in the data center for each of those prefixes, the virtual disk is accessible and the VUND just ignores where the servers physically are.
The VUND achieves translation between disk I/O request initiated by a filesystem and requests to IPv6 address representing the disk block(s) by prepending the corresponding prefix. This prefix used for initiating the network communication with the server hosting the requested block also comprises the replications bits. In other words, the northbound VUND interface is a classical disk driver interface and the southbound interface is the v6 IP stack.
Classical disk drivers can initiate a multi-blocks I/O for consecutive LBA blocks. The VUND as well as the distributed storage servers also supports multi-block I/O operations. The only additional complexity is when the requested blocks range crosses server boundaries but this is addressed by the protocol deployed between the VUND and the servers.
The VUND emulates a real disk driver northbound interface, which is never directly used by filesystems as such. For instance, in Linux kernel all disk I/O operations are initiated by the buffer cache, which in turn can be used by several filesystems of different types (POSIX or not). The POSIX semantic is guaranteed by a POSIX compliant filesystem (e.g. EXT3) but this has nothing to do with the underlying storage I/O system. As a result, almost any type of filesystem can sit on top of the distributed storage.
In an alternative embodiment, instead of mapping to an LBA, a storage device presenting a (key,value) pair based API would be used instead. An example of such a device is the Kinetic HDD available from Seagate Technology LLC. The Kinetic HDD has a key size of 4 KB. In the alternative embodiment, the key would be mapped into a v6 prefix. By embedding either the key itself or the prefix of the key into the IPv6 header, routing and policy decisions, as well as how the data should be stored, could be made in transit without having to perform deep packet inspection on the contents of the data itself. For example, multiple packets each with the same source and destination IP addresses could have different key values (A1, B1, C1) and could therefore be treated differently. A #####=Gold, B ####=Silver, C #####=Bronze. Additional security could be implemented by the network such that source X could be forbidden from writing to key values A00000-A99999), or that source Y could only be allowed to write to key values starting with C0000-00025.
In one example, by embedding the key of a (key,value) pair storage system into the IPv6 header, the network could make routing and policy based decisions not otherwise possible with existing data transfer methods. This alternative embodiment could enable M devices writing to N storage end points through the synergy of IPv6 transport with (key,value) pair storage devices. It can enable the network to make intelligent network and storage decisions based upon the IPv6 header. It provides a foundation for how Internet of Things (“IoT”) based infrastructure (e.g., parking meters, sensors for which M is a sufficiently large number) can talk directly to the data store without having to traverse a large and costly infrastructure (webservers, load balancers, application servers, storage arrays).
In operation, one possible implementation may include mapping between the unit address space and the physical devices containing the corresponding storage units being defined by the network topology, thereby allowing transparent distribution of the corresponding physical storage on several network nodes.
Referring now to
In step 64, if the GET_TIMESTAMPS reply contains fewer timestamps than the requested number of timestamps, the client resends the GET_TIMESTAMPS request for the remaining timestamps to the IPv6 address of the replica of the first remaining timestamp. This happens only when the requested blocks (multi-blocks operation) are not hosted in the same server, meaning that the v6 address range corresponds to more than one server. In step 66, upon receipt of all of the timestamps, the client sends a GET_DATA request to the most up-to-date replica (i.e., the one with the most recent timestamp) (
TLV details are as follows:
TYPE: 1 BYTE
LENGTH: 8 BYTES (BE integer)
VALUE: $LENGTH BYTES
For a GET_TIMESTAMPS request TLV, VALUE may be the number #N of requested blocks (8 BYTES, BE integer). For a GET_TIMESTAMPS reply TLV, VALUE may be the number #N of returned blocks (8 BYTES, BE integer)+N*8 BYTES corresponding to the timestamps. For a GET_DATA request TLV, VALUE may be the number #N of requested blocks (8 BYTES, BE integer). For a GET_DATA reply TLV, VALUE may be the number #N of returned blocks (8 BYTES, BE integer)+N*BLOCK_SIZE BYTES corresponding to the data. For a SET_BLOCKS request TLV, VALUE may be the number #N of blocks to write (8 BYTES, BE integer)+N*(8+BLOCK_SIZE) corresponding to the list of (timestamps, data) couples. For a SET_BLOCKS reply TLV, VALUE may be the number #N of blocks actually written (8 BYTES, BE integer).
As previously noted, the protocol for managing the replication mechanism (i.e., the server-to-server protocol) may be implemented on top of UDP. The protocol is geared toward detecting inconsistencies between LBA block replicas stored in two storage nodes. To achieve this, embodiments described herein can detect and track inconsistencies across a large-sized Merkle Tree. The Merkle tree itself is a representation of all LBA blocks hosted in servers. To simplify the design, it is assumed that replicas #n of all blocks hosted in a single server are also hosted in a single server. In other words, if a server hosts N blocks and if the replication factor is 2, then the replicas for these N blocks are also all hosted in one unique server. The same principle applies regardless of the replication factor.
Consequently, if the replication factor is R, there will be R(R−1)/2 running instances of this protocol per group of storage servers. A group of storage servers is the list of storage servers hosting a set of blocks plus their corresponding replicas so if R=4, each group of servers contains four servers, the virtual disk space being itself distributed across several server groups.
Between two nodes from any given server group, each of the nodes maintains a binary hash tree (Merkle tree) used for synchronization purposes and a table containing cache entries (referred to as “the cache”). Each cache entry consists of a node identifier (“nid”) that uniquely identifies a node in the Merkle tree, the corresponding LOCAL hash, a cache entry status identifier (e.g., IDLE, RECOVERY or EXPIRED), and an expiry timer. Referring now to
The cache update routine is as follows. When the update routine is triggered, all the EXPIRED entries are deleted. If there is only a root entry left in the cache, its state is changed to IDLE. All the IDLE entries in the cache are sent to the peer. When a peer node gets a message, each entry in the message that does not correspond to a root node is placed in the cache (if it is not already there). If the received hash is the same as the local one, the entry is marked as EXPIRED; if the entry is a leaf, synchronization is triggered and the entry placed in RECOVERY mode; otherwise, the entry is marked as EXPIRED and two child entries are created in the cache and placed in IDLE state. The expiry timers of both child entries are started. The update routine is triggered.
For any root entry present in the received message, if the received hash is different, the entry in the cache is placed in RECOVERY state, its two children are added to the cache in the IDLE state, and the expiry timers of the children are started. The update routine is triggered. When a leaf is synchronized, the corresponding cache entry is placed in EXPIRED state and the whole branch of the Merkle tree is updated from the newly synchronized leaf up to the root. If the cache only contains a root entry, the update routine is triggered. When an expiry timer expires, the corresponding entry is placed in EXPIRED state.
Turning to
Processor 132, which may also be referred to as a central processing unit (“CPU”), can include any general or special-purpose processor capable of executing machine readable instructions and performing operations on data as instructed by the machine readable instructions. Main memory 133 may be directly accessible to processor 132 for accessing machine instructions and may be in the form of random access memory (“RAM”) or any type of dynamic storage (e.g., dynamic random access memory (“DRAM”)). Secondary storage 134 can be any non-volatile memory such as a hard disk, which is capable of storing electronic data including executable software files. Externally stored electronic data may be provided to computer 130 through one or more removable media drives 138, which may be configured to receive any type of external media such as compact discs (“CDs”), digital video discs (“DVDs”), flash drives, external hard drives, etc.
Wireless and wired network interfaces 135 and 136 can be provided to enable electronic communication between machine 130 and other machines via networks. In one example, wireless network interface 135 could include a wireless network controller (“WNIC”) with suitable transmitting and receiving components, such as transceivers, for wirelessly communicating within a network. Wired network interface 136 can enable machine 130 to physically connect to a network by a wire line such as an Ethernet cable. Both wireless and wired network interfaces 135 and 136 may be configured to facilitate communications using suitable communication protocols such as, for example, Internet Protocol Suite (“TCP/IP”). Machine 130 is shown with both wireless and wired network interfaces 135 and 136 for illustrative purposes only. While one or more wireless and hardwire interfaces may be provided in machine 130, or externally connected to machine 130, only one connection option is needed to enable connection of machine 130 to a network.
A user interface 137 may be provided in some machines to allow a user to interact with the machine 130. User interface 137 could include a display device such as a graphical display device (e.g., plasma display panel (“PDP”), a liquid crystal display (“LCD”), a cathode ray tube (“CRT”), etc.). In addition, any appropriate input mechanism may also be included such as a keyboard, a touch screen, a mouse, a trackball, voice recognition, touch pad, etc.
Removable media drive 138 represents a drive configured to receive any type of external computer-readable media (e.g., computer-readable medium 139). Instructions embodying the activities or functions described herein may be stored on one or more external computer-readable media. Additionally, such instructions may also, or alternatively, reside at least partially within a memory element (e.g., in main memory 133 or cache memory of processor 132) of machine 130 during execution, or within a non-volatile memory element (e.g., secondary storage 134) of machine 130. Accordingly, other memory elements of machine 130 also constitute computer-readable media. Thus, “computer-readable medium” is meant to include any medium that is capable of storing instructions for execution by machine 130 that cause the machine to perform any one or more of the activities disclosed herein.
Not shown in
The elements, shown and/or described with reference to machine 130, are intended for illustrative purposes and are not meant to imply architectural limitations of machines such as those utilized in accordance with the present disclosure. In addition, each machine, may include more or fewer components where appropriate and based on particular needs. As used herein in this Specification, the term “machine” is meant to encompass any computing device or network element such as servers, routers, personal computers, client computers, network appliances, switches, bridges, gateways, processors, load balancers, wireless LAN controllers, firewalls, or any other suitable device, component, element, or object operable to affect or process electronic information in a network environment.
In example implementations, at least some portions of the activities described herein may be implemented in software in, for example, devices 12, nodes of IP network 14, client 16, and distributed storage driver 18. In some embodiments, this software could be received or downloaded from a web server, provided on computer-readable media, or configured by a manufacturer of a particular element in order to provide this system in accordance with features of embodiments described herein. In some embodiments, one or more of these features may be implemented in hardware, provided external to these elements, or consolidated in any appropriate manner to achieve the intended functionality.
In one example implementation, the system and architecture discussed herein includes network elements or computing devices, which may include any suitable hardware, software, components, modules, or objects that facilitate the operations thereof, as well as suitable interfaces for receiving, transmitting, and/or otherwise communicating data or information in a network environment. This may be inclusive of appropriate algorithms and communication protocols that allow for the effective exchange of data or information.
Furthermore, in the embodiments of the system and architecture described and shown herein, processors and memory elements associated with the various network elements may be removed, or otherwise consolidated such that a single processor and a single memory location are responsible for certain activities. Alternatively, certain processing functions could be separated and separate processors and/or physical machines could implement various functionalities. In a general sense, the arrangements depicted in the FIGURES may be more logical in their representations, whereas a physical architecture may include various permutations, combinations, and/or hybrids of these elements. It is imperative to note that countless possible design configurations can be used to achieve the operational objectives outlined here. Accordingly, the associated infrastructure has a myriad of substitute arrangements, design choices, device possibilities, hardware configurations, software implementations, equipment options, etc.
This includes at least some of the memory elements being able to store instructions (e.g., software, logic, code, etc.) that are executed to carry out the activities described in this Specification. A processor can execute any type of instructions associated with the data to achieve the operations detailed herein in this Specification. In one example, one or more processors could transform an element or an article (e.g., data) from one state or thing to another state or thing. In another example, the activities outlined herein may be implemented with fixed logic or programmable logic (e.g., software/computer instructions executed by a processor) and the elements identified herein could be some type of a programmable processor, programmable digital logic (e.g., a field programmable gate array (“FPGA”), an erasable programmable read only memory (“EPROM”), an electrically erasable programmable read only memory (“EEPROM”)), an ASIC that includes digital logic, software, code, electronic instructions, flash memory, optical disks, CD-ROMs, DVD ROMs, magnetic or optical cards, other types of machine-readable mediums suitable for storing electronic instructions, or any suitable combination thereof.
Components of the system and architecture may keep information in any suitable type of memory (e.g., random access memory (“RAM”), read-only memory (“ROM”), erasable programmable ROM (“EPROM”), electrically erasable programmable ROM (“EEPROM”), etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs. Any of the memory items discussed herein should be construed as being encompassed within the broad term “memory element.” The information being read, used, tracked, sent, transmitted, communicated, or received by system 10 could be provided in any database, register, queue, table, cache, control list, or other storage structure, all of which can be referenced at any suitable timeframe. Any such storage options may be included within the broad term “memory element” as used herein. Similarly, any of the potential processing elements and modules described in this Specification should be construed as being encompassed within the broad term “processor.”
Note that with the numerous examples provided herein, interaction may be described in terms of two, three, four, or more network elements. However, this has been done for purposes of clarity and example only. It should be appreciated that the system can be consolidated in any suitable manner. Along similar design alternatives, any of the illustrated computers, modules, components, and elements of the FIGURES may be combined in various possible configurations, all of which are clearly within the broad scope of this Specification. In certain cases, it may be easier to describe one or more of the functionalities of a given set of flows by only referencing a limited number of network elements. It should be appreciated that the system as shown in the FIGURES and its teachings are readily scalable and can accommodate a large number of components, as well as more complicated/sophisticated arrangements and configurations. Accordingly, the examples provided should not limit the scope or inhibit the broad teachings of the system as potentially applied to a myriad of other architectures.
It is also important to note that the operations and steps described with reference to the preceding FIGURES illustrate only some of the possible scenarios that may be executed by, or within, the system. Some of these operations may be deleted or removed where appropriate, or these steps may be modified or changed considerably without departing from the scope of the discussed concepts. In addition, the timing of these operations may be altered considerably and still achieve the results taught in this disclosure. The preceding operational flows have been offered for purposes of example and discussion. Substantial flexibility is provided by the system in that any suitable arrangements, chronologies, configurations, and timing mechanisms may be provided without departing from the teachings of the discussed concepts.
In the foregoing description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the disclosed embodiments. It will be apparent to one skilled in the art, however, that the disclosed embodiments may be practiced without these specific details. In other instances, structure and devices are shown in block diagram form in order to avoid obscuring the disclosed embodiments. In addition, references in the Specification to “one embodiment”, “example embodiment”, “an embodiment”, “another embodiment”, “some embodiments”, “various embodiments”, “other embodiments”, “alternative embodiment”, etc. are intended to mean that any features (e.g., elements, structures, modules, components, steps, operations, characteristics, etc.) associated with such embodiments are included in one or more embodiments of the present disclosure.
Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims. In order to assist the United States Patent and Trademark Office (USPTO) and, additionally, any readers of any patent issued on this application in interpreting the claims appended hereto, Applicant wishes to note that the Applicant: (a) does not intend any of the appended claims to invoke paragraph six (6) of 35 U.S.C. Section 112 as it exists on the date of the filing hereof unless the words “means for” or “step for” are specifically used in the particular claims; and (b) does not intend, by any statement in the specification, to limit this disclosure in any way that is not otherwise reflected in the appended claims.
This application claims the benefit of priority under 35 U.S.C. § 119(e) to U.S. Provisional Application Ser. No. 62/173,854, entitled “APPARATUS, SYSTEM, AND METHOD FOR MAPPING IMPLEMENTING IPV6 BASED STORAGE SYSTEM AND FOR SUPPORTING GIGANTIC AND DISTRIBUTED STORAGE SPACE,” filed Jun. 10, 2015, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4688695 | Hirohata | Aug 1987 | A |
5263003 | Cowles et al. | Nov 1993 | A |
5339445 | Gasztonyi | Aug 1994 | A |
5430859 | Norman et al. | Jul 1995 | A |
5457746 | Dolphin | Oct 1995 | A |
5535336 | Smith et al. | Jul 1996 | A |
5588012 | Oizumi | Dec 1996 | A |
5617421 | Chin et al. | Apr 1997 | A |
5680579 | Young et al. | Oct 1997 | A |
5690194 | Parker et al. | Nov 1997 | A |
5740171 | Mazzola et al. | Apr 1998 | A |
5742604 | Edsall et al. | Apr 1998 | A |
5764636 | Edsall | Jun 1998 | A |
5809285 | Hilland | Sep 1998 | A |
5812814 | Sukegawa | Sep 1998 | A |
5812950 | Tom | Sep 1998 | A |
5838970 | Thomas | Nov 1998 | A |
5999930 | Wolff | Dec 1999 | A |
6035105 | McCloghrie et al. | Mar 2000 | A |
6043777 | Bergman et al. | Mar 2000 | A |
6101497 | Ofek | Aug 2000 | A |
6148414 | Brown et al. | Nov 2000 | A |
6185203 | Berman | Feb 2001 | B1 |
6188694 | Fine et al. | Feb 2001 | B1 |
6202135 | Kedem et al. | Mar 2001 | B1 |
6208649 | Kloth | Mar 2001 | B1 |
6209059 | Ofer et al. | Mar 2001 | B1 |
6219699 | McCloghrie et al. | Apr 2001 | B1 |
6219753 | Richardson | Apr 2001 | B1 |
6223250 | Yokono | Apr 2001 | B1 |
6226771 | Hilla et al. | May 2001 | B1 |
6260120 | Blumenau et al. | Jul 2001 | B1 |
6266705 | Ullum et al. | Jul 2001 | B1 |
6269381 | St. Pierre et al. | Jul 2001 | B1 |
6269431 | Dunham | Jul 2001 | B1 |
6295575 | Blumenau et al. | Sep 2001 | B1 |
6400730 | Latif et al. | Jun 2002 | B1 |
6408406 | Parris | Jun 2002 | B1 |
6542909 | Tamer et al. | Apr 2003 | B1 |
6542961 | Matsunami et al. | Apr 2003 | B1 |
6553390 | Gross et al. | Apr 2003 | B1 |
6564252 | Hickman et al. | May 2003 | B1 |
6647474 | Yanai et al. | Nov 2003 | B2 |
6675258 | Bramhall et al. | Jan 2004 | B1 |
6683883 | Czeiger et al. | Jan 2004 | B1 |
6694413 | Mimatsu et al. | Feb 2004 | B1 |
6708227 | Cabrera et al. | Mar 2004 | B1 |
6715007 | Williams et al. | Mar 2004 | B1 |
6728791 | Young | Apr 2004 | B1 |
6772231 | Reuter et al. | Aug 2004 | B2 |
6820099 | Huber et al. | Nov 2004 | B1 |
6847647 | Wrenn | Jan 2005 | B1 |
6848759 | Doornbos et al. | Feb 2005 | B2 |
6850955 | Sonoda et al. | Feb 2005 | B2 |
6876656 | Brewer et al. | Apr 2005 | B2 |
6880062 | Ibrahim et al. | Apr 2005 | B1 |
6898670 | Nahum | May 2005 | B2 |
6907419 | Pesola et al. | Jun 2005 | B1 |
6912668 | Brown et al. | Jun 2005 | B1 |
6952734 | Gunlock et al. | Oct 2005 | B1 |
6976090 | Ben-Shaul et al. | Dec 2005 | B2 |
6978300 | Beukema et al. | Dec 2005 | B1 |
6983303 | Pellegrino et al. | Jan 2006 | B2 |
6986015 | Testardi | Jan 2006 | B2 |
6986069 | Oehler et al. | Jan 2006 | B2 |
7051056 | Rodriguez-Rivera et al. | May 2006 | B2 |
7069465 | Chu et al. | Jun 2006 | B2 |
7073017 | Yamamoto | Jul 2006 | B2 |
7096341 | DeTar, Jr. | Aug 2006 | B1 |
7108339 | Berger | Sep 2006 | B2 |
7149858 | Kiselev | Dec 2006 | B1 |
7171514 | Coronado et al. | Jan 2007 | B2 |
7171668 | Molloy et al. | Jan 2007 | B2 |
7174354 | Andreasson | Feb 2007 | B2 |
7200144 | Terrell et al. | Apr 2007 | B2 |
7222255 | Claessens et al. | May 2007 | B1 |
7237045 | Beckmann et al. | Jun 2007 | B2 |
7240188 | Takata et al. | Jul 2007 | B2 |
7246260 | Brown et al. | Jul 2007 | B2 |
7266718 | Idei et al. | Sep 2007 | B2 |
7269168 | Roy et al. | Sep 2007 | B2 |
7277431 | Walter et al. | Oct 2007 | B2 |
7277948 | Igarashi et al. | Oct 2007 | B2 |
7305658 | Hamilton et al. | Dec 2007 | B1 |
7328434 | Swanson et al. | Feb 2008 | B2 |
7340555 | Ashmore et al. | Mar 2008 | B2 |
7346751 | Prahlad et al. | Mar 2008 | B2 |
7352706 | Klotz et al. | Apr 2008 | B2 |
7353305 | Pangal et al. | Apr 2008 | B2 |
7359321 | Sindhu et al. | Apr 2008 | B1 |
7383381 | Faulkner et al. | Jun 2008 | B1 |
7403987 | Marinelli et al. | Jul 2008 | B1 |
7433326 | Desai et al. | Oct 2008 | B2 |
7433948 | Edsall | Oct 2008 | B2 |
7434105 | Rodriguez-Rivera et al. | Oct 2008 | B1 |
7441154 | Klotz et al. | Oct 2008 | B2 |
7447839 | Uppala | Nov 2008 | B2 |
7487321 | Muthiah et al. | Feb 2009 | B2 |
7500053 | Kavuri et al. | Mar 2009 | B1 |
7512744 | Banga | Mar 2009 | B2 |
7542681 | Cornell et al. | Jun 2009 | B2 |
7558872 | Senevirathne et al. | Jul 2009 | B1 |
7587570 | Sarkar et al. | Sep 2009 | B2 |
7631023 | Kaiser et al. | Dec 2009 | B1 |
7643505 | Colloff | Jan 2010 | B1 |
7654625 | Amann et al. | Feb 2010 | B2 |
7657796 | Kaiser et al. | Feb 2010 | B1 |
7668981 | Nagineni et al. | Feb 2010 | B1 |
7669071 | Cochran et al. | Feb 2010 | B2 |
7689384 | Becker | Mar 2010 | B1 |
7694092 | Mizuno | Apr 2010 | B2 |
7697554 | Ofer et al. | Apr 2010 | B1 |
7706303 | Bose et al. | Apr 2010 | B2 |
7707481 | Kirschner et al. | Apr 2010 | B2 |
7716648 | Vaidyanathan et al. | May 2010 | B2 |
7752360 | Galles | Jul 2010 | B2 |
7757059 | Ofer et al. | Jul 2010 | B1 |
7774329 | Peddy et al. | Aug 2010 | B1 |
7774839 | Nazzal | Aug 2010 | B2 |
7793138 | Rastogi et al. | Sep 2010 | B2 |
7840730 | D'Amato et al. | Nov 2010 | B2 |
7843906 | Chidambaram et al. | Nov 2010 | B1 |
7895428 | Boland, IV et al. | Feb 2011 | B2 |
7904599 | Bennett | Mar 2011 | B1 |
7930494 | Goheer et al. | Apr 2011 | B1 |
7975175 | Votta et al. | Jul 2011 | B2 |
7979670 | Saliba et al. | Jul 2011 | B2 |
7984259 | English | Jul 2011 | B1 |
8031703 | Gottumukkula et al. | Oct 2011 | B2 |
8032621 | Upalekar et al. | Oct 2011 | B1 |
8051197 | Mullendore et al. | Nov 2011 | B2 |
8086755 | Duffy, IV et al. | Dec 2011 | B2 |
8161134 | Mishra et al. | Apr 2012 | B2 |
8196018 | Forhan et al. | Jun 2012 | B2 |
8205951 | Boks | Jun 2012 | B2 |
8218538 | Chidambaram et al. | Jul 2012 | B1 |
8230066 | Heil | Jul 2012 | B2 |
8234377 | Cohn | Jul 2012 | B2 |
8266238 | Zimmer et al. | Sep 2012 | B2 |
8272104 | Chen et al. | Sep 2012 | B2 |
8274993 | Sharma et al. | Sep 2012 | B2 |
8290919 | Kelly et al. | Oct 2012 | B1 |
8297722 | Chambers et al. | Oct 2012 | B2 |
8301746 | Head et al. | Oct 2012 | B2 |
8335231 | Kloth et al. | Dec 2012 | B2 |
8341121 | Claudatos et al. | Dec 2012 | B1 |
8345692 | Smith | Jan 2013 | B2 |
8352941 | Protopopov et al. | Jan 2013 | B1 |
8392760 | Kandula et al. | Mar 2013 | B2 |
8442059 | de la Iglesia et al. | May 2013 | B1 |
8479211 | Marshall et al. | Jul 2013 | B1 |
8495356 | Ashok et al. | Jul 2013 | B2 |
8514868 | Hill | Aug 2013 | B2 |
8532108 | Li et al. | Sep 2013 | B2 |
8560663 | Baucke et al. | Oct 2013 | B2 |
8619599 | Even | Dec 2013 | B1 |
8626891 | Guru et al. | Jan 2014 | B2 |
8630983 | Sengupta et al. | Jan 2014 | B2 |
8660129 | Brendel et al. | Feb 2014 | B1 |
8661299 | Ip | Feb 2014 | B1 |
8677485 | Sharma et al. | Mar 2014 | B2 |
8683296 | Anderson et al. | Mar 2014 | B2 |
8706772 | Hartig et al. | Apr 2014 | B2 |
8719804 | Jain | May 2014 | B2 |
8725854 | Edsall | May 2014 | B2 |
8768981 | Milne et al. | Jul 2014 | B1 |
8775773 | Acharya et al. | Jul 2014 | B2 |
8793372 | Ashok et al. | Jul 2014 | B2 |
8805918 | Chandrasekaran et al. | Aug 2014 | B1 |
8805951 | Faibish et al. | Aug 2014 | B1 |
8832330 | Lancaster | Sep 2014 | B1 |
8855116 | Rosset et al. | Oct 2014 | B2 |
8856339 | Mestery et al. | Oct 2014 | B2 |
8868474 | Leung et al. | Oct 2014 | B2 |
8887286 | Dupont et al. | Nov 2014 | B2 |
8898385 | Jayaraman et al. | Nov 2014 | B2 |
8909928 | Ahmad et al. | Dec 2014 | B2 |
8918510 | Gmach et al. | Dec 2014 | B2 |
8918586 | Todd et al. | Dec 2014 | B1 |
8924720 | Raghuram et al. | Dec 2014 | B2 |
8930747 | Levijarvi et al. | Jan 2015 | B2 |
8935500 | Gulati et al. | Jan 2015 | B1 |
8949677 | Brundage et al. | Feb 2015 | B1 |
8996837 | Bono et al. | Mar 2015 | B1 |
9003086 | Schuller et al. | Apr 2015 | B1 |
9007922 | Mittal et al. | Apr 2015 | B1 |
9009427 | Sharma et al. | Apr 2015 | B2 |
9009704 | McGrath et al. | Apr 2015 | B2 |
9075638 | Barnett et al. | Jul 2015 | B2 |
9141554 | Candelaria | Sep 2015 | B1 |
9141785 | Mukkara et al. | Sep 2015 | B2 |
9164795 | Vincent | Oct 2015 | B1 |
9176677 | Fradkin et al. | Nov 2015 | B1 |
9201704 | Chang et al. | Dec 2015 | B2 |
9203784 | Chang et al. | Dec 2015 | B2 |
9207882 | Rosset et al. | Dec 2015 | B2 |
9207929 | Katsura | Dec 2015 | B2 |
9213612 | Candelaria | Dec 2015 | B2 |
9223564 | Munireddy et al. | Dec 2015 | B2 |
9223634 | Chang et al. | Dec 2015 | B2 |
9244761 | Yekhanin et al. | Jan 2016 | B2 |
9250969 | Lager-Cavilla et al. | Feb 2016 | B2 |
9264494 | Factor et al. | Feb 2016 | B2 |
9270754 | Iyengar et al. | Feb 2016 | B2 |
9280487 | Candelaria | Mar 2016 | B2 |
9304815 | Vasanth et al. | Apr 2016 | B1 |
9313048 | Chang et al. | Apr 2016 | B2 |
9374270 | Nakil et al. | Jun 2016 | B2 |
9378060 | Jansson et al. | Jun 2016 | B2 |
9396251 | Boudreau et al. | Jul 2016 | B1 |
9448877 | Candelaria | Sep 2016 | B2 |
9471348 | Zuo et al. | Oct 2016 | B2 |
9501473 | Kong et al. | Nov 2016 | B1 |
9503523 | Rosset et al. | Nov 2016 | B2 |
9565110 | Mullendore et al. | Feb 2017 | B2 |
9575828 | Agarwal et al. | Feb 2017 | B2 |
9582377 | Dhoolam | Feb 2017 | B1 |
9614763 | Dong et al. | Apr 2017 | B2 |
9658868 | Hill | May 2017 | B2 |
9658876 | Chang et al. | May 2017 | B2 |
9733868 | Chandrasekaran et al. | Aug 2017 | B2 |
9763518 | Charest et al. | Sep 2017 | B2 |
9830240 | George et al. | Nov 2017 | B2 |
9853873 | Dasu et al. | Dec 2017 | B2 |
20020049980 | Hoang | Apr 2002 | A1 |
20020053009 | Selkirk et al. | May 2002 | A1 |
20020073276 | Howard et al. | Jun 2002 | A1 |
20020083120 | Soltis | Jun 2002 | A1 |
20020095547 | Watanabe et al. | Jul 2002 | A1 |
20020103889 | Markson et al. | Aug 2002 | A1 |
20020103943 | Lo et al. | Aug 2002 | A1 |
20020112113 | Karpoff et al. | Aug 2002 | A1 |
20020120741 | Webb et al. | Aug 2002 | A1 |
20020138675 | Mann | Sep 2002 | A1 |
20020156971 | Jones et al. | Oct 2002 | A1 |
20030023885 | Potter et al. | Jan 2003 | A1 |
20030026267 | Oberman et al. | Feb 2003 | A1 |
20030055933 | Ishizaki et al. | Mar 2003 | A1 |
20030056126 | O'Connor et al. | Mar 2003 | A1 |
20030065986 | Fraenkel et al. | Apr 2003 | A1 |
20030084359 | Bresniker et al. | May 2003 | A1 |
20030118053 | Edsall et al. | Jun 2003 | A1 |
20030131105 | Czeiger et al. | Jul 2003 | A1 |
20030131165 | Asano et al. | Jul 2003 | A1 |
20030131182 | Kumar et al. | Jul 2003 | A1 |
20030140134 | Swanson et al. | Jul 2003 | A1 |
20030140210 | Testardi | Jul 2003 | A1 |
20030149763 | Heitman et al. | Aug 2003 | A1 |
20030154271 | Baldwin et al. | Aug 2003 | A1 |
20030159058 | Eguchi et al. | Aug 2003 | A1 |
20030174725 | Shankar | Sep 2003 | A1 |
20030189395 | Doornbos et al. | Oct 2003 | A1 |
20030210686 | Terrell et al. | Nov 2003 | A1 |
20040024961 | Cochran et al. | Feb 2004 | A1 |
20040030857 | Krakirian et al. | Feb 2004 | A1 |
20040039939 | Cox et al. | Feb 2004 | A1 |
20040054776 | Klotz et al. | Mar 2004 | A1 |
20040057389 | Klotz et al. | Mar 2004 | A1 |
20040059807 | Klotz et al. | Mar 2004 | A1 |
20040088574 | Walter et al. | May 2004 | A1 |
20040117438 | Considine et al. | Jun 2004 | A1 |
20040123029 | Dalai et al. | Jun 2004 | A1 |
20040128470 | Hetzler et al. | Jul 2004 | A1 |
20040128540 | Roskind | Jul 2004 | A1 |
20040153863 | Klotz et al. | Aug 2004 | A1 |
20040190901 | Fang | Sep 2004 | A1 |
20040215749 | Tsao | Oct 2004 | A1 |
20040230848 | Mayo et al. | Nov 2004 | A1 |
20040250034 | Yagawa et al. | Dec 2004 | A1 |
20050033936 | Nakano et al. | Feb 2005 | A1 |
20050036499 | Dutt et al. | Feb 2005 | A1 |
20050050211 | Kaul et al. | Mar 2005 | A1 |
20050050270 | Horn et al. | Mar 2005 | A1 |
20050053073 | Kloth et al. | Mar 2005 | A1 |
20050055428 | Terai et al. | Mar 2005 | A1 |
20050060574 | Klotz et al. | Mar 2005 | A1 |
20050060598 | Klotz et al. | Mar 2005 | A1 |
20050071851 | Opheim | Mar 2005 | A1 |
20050076113 | Klotz et al. | Apr 2005 | A1 |
20050091426 | Horn et al. | Apr 2005 | A1 |
20050114615 | Ogasawara et al. | May 2005 | A1 |
20050117522 | Basavaiah et al. | Jun 2005 | A1 |
20050117562 | Wrenn | Jun 2005 | A1 |
20050138287 | Ogasawara et al. | Jun 2005 | A1 |
20050169188 | Cometto et al. | Aug 2005 | A1 |
20050185597 | Le et al. | Aug 2005 | A1 |
20050188170 | Yamamoto | Aug 2005 | A1 |
20050198523 | Shanbhag et al. | Sep 2005 | A1 |
20050235072 | Smith et al. | Oct 2005 | A1 |
20050283658 | Clark et al. | Dec 2005 | A1 |
20060015861 | Takata et al. | Jan 2006 | A1 |
20060015928 | Setty et al. | Jan 2006 | A1 |
20060034302 | Peterson | Feb 2006 | A1 |
20060045021 | Deragon et al. | Mar 2006 | A1 |
20060075191 | Lolayekar et al. | Apr 2006 | A1 |
20060098672 | Schzukin et al. | May 2006 | A1 |
20060117099 | Mogul | Jun 2006 | A1 |
20060136684 | Le et al. | Jun 2006 | A1 |
20060184287 | Belady et al. | Aug 2006 | A1 |
20060198319 | Schondelmayer et al. | Sep 2006 | A1 |
20060215297 | Kikuchi | Sep 2006 | A1 |
20060230227 | Ogasawara et al. | Oct 2006 | A1 |
20060242332 | Johnsen et al. | Oct 2006 | A1 |
20060251111 | Kloth et al. | Nov 2006 | A1 |
20070005297 | Beresniewicz et al. | Jan 2007 | A1 |
20070022087 | Bahar | Jan 2007 | A1 |
20070067593 | Satoyama et al. | Mar 2007 | A1 |
20070079068 | Draggon | Apr 2007 | A1 |
20070091903 | Atkinson | Apr 2007 | A1 |
20070094465 | Sharma et al. | Apr 2007 | A1 |
20070101202 | Garbow | May 2007 | A1 |
20070121519 | Cuni et al. | May 2007 | A1 |
20070136541 | Herz et al. | Jun 2007 | A1 |
20070162969 | Becker | Jul 2007 | A1 |
20070211640 | Palacharla et al. | Sep 2007 | A1 |
20070214316 | Kim | Sep 2007 | A1 |
20070250838 | Belady et al. | Oct 2007 | A1 |
20070258380 | Chamdani et al. | Nov 2007 | A1 |
20070263545 | Foster et al. | Nov 2007 | A1 |
20070276884 | Hara et al. | Nov 2007 | A1 |
20070283059 | Ho et al. | Dec 2007 | A1 |
20080016412 | White et al. | Jan 2008 | A1 |
20080034149 | Sheen | Feb 2008 | A1 |
20080052459 | Chang et al. | Feb 2008 | A1 |
20080059698 | Kabir et al. | Mar 2008 | A1 |
20080114933 | Ogasawara et al. | May 2008 | A1 |
20080126509 | Subrannanian et al. | May 2008 | A1 |
20080126734 | Murase | May 2008 | A1 |
20080126844 | Morita | May 2008 | A1 |
20080168304 | Flynn et al. | Jul 2008 | A1 |
20080201616 | Ashmore | Aug 2008 | A1 |
20080244184 | Lewis et al. | Oct 2008 | A1 |
20080256082 | Davies et al. | Oct 2008 | A1 |
20080267217 | Colville et al. | Oct 2008 | A1 |
20080288661 | Galles | Nov 2008 | A1 |
20080294888 | Ando et al. | Nov 2008 | A1 |
20090063766 | Matsumura et al. | Mar 2009 | A1 |
20090083484 | Basham et al. | Mar 2009 | A1 |
20090089567 | Boland, IV et al. | Apr 2009 | A1 |
20090094380 | Qiu et al. | Apr 2009 | A1 |
20090094664 | Butler et al. | Apr 2009 | A1 |
20090125694 | Innan et al. | May 2009 | A1 |
20090193223 | Saliba et al. | Jul 2009 | A1 |
20090201926 | Kagan et al. | Aug 2009 | A1 |
20090222733 | Basham et al. | Sep 2009 | A1 |
20090240873 | Yu et al. | Sep 2009 | A1 |
20090282471 | Green et al. | Nov 2009 | A1 |
20090323706 | Germain et al. | Dec 2009 | A1 |
20100011365 | Gerovac et al. | Jan 2010 | A1 |
20100030995 | Wang et al. | Feb 2010 | A1 |
20100046378 | Knapp et al. | Feb 2010 | A1 |
20100083055 | Ozonat | Apr 2010 | A1 |
20100174968 | Charles et al. | Jul 2010 | A1 |
20100241807 | Wu | Sep 2010 | A1 |
20100318609 | Lahiri et al. | Dec 2010 | A1 |
20100318837 | Murphy et al. | Dec 2010 | A1 |
20110010394 | Carew et al. | Jan 2011 | A1 |
20110022691 | Banerjee et al. | Jan 2011 | A1 |
20110029824 | Schöler et al. | Feb 2011 | A1 |
20110035494 | Pandey et al. | Feb 2011 | A1 |
20110075667 | Li et al. | Mar 2011 | A1 |
20110087848 | Trent | Apr 2011 | A1 |
20110119556 | de Buen | May 2011 | A1 |
20110142053 | Van Der Merwe et al. | Jun 2011 | A1 |
20110161496 | Nicklin | Jun 2011 | A1 |
20110173303 | Rider | Jul 2011 | A1 |
20110228679 | Varma et al. | Sep 2011 | A1 |
20110231899 | Pulier et al. | Sep 2011 | A1 |
20110239039 | Dieffenbach et al. | Sep 2011 | A1 |
20110252274 | Kawaguchi et al. | Oct 2011 | A1 |
20110255540 | Mizrahi et al. | Oct 2011 | A1 |
20110276584 | Cotner et al. | Nov 2011 | A1 |
20110276675 | Singh et al. | Nov 2011 | A1 |
20110276951 | Jain | Nov 2011 | A1 |
20110299539 | Rajagopal et al. | Dec 2011 | A1 |
20110307450 | Hahn et al. | Dec 2011 | A1 |
20110313973 | Srivas et al. | Dec 2011 | A1 |
20120023319 | Chin et al. | Jan 2012 | A1 |
20120030401 | Cowan et al. | Feb 2012 | A1 |
20120054367 | Ramakrishnan et al. | Mar 2012 | A1 |
20120072578 | Alam | Mar 2012 | A1 |
20120072985 | Davne et al. | Mar 2012 | A1 |
20120075999 | Ko et al. | Mar 2012 | A1 |
20120084445 | Brock et al. | Apr 2012 | A1 |
20120084782 | Chou et al. | Apr 2012 | A1 |
20120096134 | Suit | Apr 2012 | A1 |
20120130874 | Mane et al. | May 2012 | A1 |
20120131174 | Ferris et al. | May 2012 | A1 |
20120134672 | Banerjee | May 2012 | A1 |
20120144014 | Natham et al. | Jun 2012 | A1 |
20120159112 | Tokusho et al. | Jun 2012 | A1 |
20120167094 | Suit | Jun 2012 | A1 |
20120173581 | Hartig et al. | Jul 2012 | A1 |
20120173589 | Kwon et al. | Jul 2012 | A1 |
20120177039 | Berman | Jul 2012 | A1 |
20120177041 | Berman | Jul 2012 | A1 |
20120177042 | Berman | Jul 2012 | A1 |
20120177043 | Berman | Jul 2012 | A1 |
20120177044 | Berman | Jul 2012 | A1 |
20120177045 | Berman | Jul 2012 | A1 |
20120177370 | Berman | Jul 2012 | A1 |
20120179909 | Sagi et al. | Jul 2012 | A1 |
20120201138 | Yu et al. | Aug 2012 | A1 |
20120210041 | Flynn et al. | Aug 2012 | A1 |
20120254440 | Wang | Oct 2012 | A1 |
20120257501 | Kucharczyk | Oct 2012 | A1 |
20120265976 | Spiers et al. | Oct 2012 | A1 |
20120281706 | Agarwal et al. | Nov 2012 | A1 |
20120297088 | Wang et al. | Nov 2012 | A1 |
20120303618 | Dutta et al. | Nov 2012 | A1 |
20120311106 | Morgan | Dec 2012 | A1 |
20120311568 | Jansen | Dec 2012 | A1 |
20120320788 | Venkataramanan et al. | Dec 2012 | A1 |
20120324114 | Dutta et al. | Dec 2012 | A1 |
20120331119 | Bose et al. | Dec 2012 | A1 |
20130003737 | Sinicrope | Jan 2013 | A1 |
20130013664 | Baird et al. | Jan 2013 | A1 |
20130028135 | Berman | Jan 2013 | A1 |
20130036212 | Jibbe et al. | Feb 2013 | A1 |
20130036213 | Hasan et al. | Feb 2013 | A1 |
20130036449 | Mukkara et al. | Feb 2013 | A1 |
20130054888 | Bhat et al. | Feb 2013 | A1 |
20130061089 | Valiyaparambil et al. | Mar 2013 | A1 |
20130061111 | Sarcone | Mar 2013 | A1 |
20130067162 | Jayaraman et al. | Mar 2013 | A1 |
20130080823 | Roth et al. | Mar 2013 | A1 |
20130086340 | Fleming et al. | Apr 2013 | A1 |
20130100858 | Kamath et al. | Apr 2013 | A1 |
20130111540 | Sabin | May 2013 | A1 |
20130138816 | Kuo et al. | May 2013 | A1 |
20130138836 | Cohen et al. | May 2013 | A1 |
20130139138 | Kakos | May 2013 | A1 |
20130144933 | Hinni et al. | Jun 2013 | A1 |
20130152076 | Patel | Jun 2013 | A1 |
20130152175 | Hromoko et al. | Jun 2013 | A1 |
20130163426 | Beliveau et al. | Jun 2013 | A1 |
20130163606 | Bagepalli et al. | Jun 2013 | A1 |
20130179941 | McGloin et al. | Jul 2013 | A1 |
20130182712 | Aguayo et al. | Jul 2013 | A1 |
20130185433 | Zhu et al. | Jul 2013 | A1 |
20130191106 | Kephart et al. | Jul 2013 | A1 |
20130198730 | Munireddy et al. | Aug 2013 | A1 |
20130208888 | Agrawal et al. | Aug 2013 | A1 |
20130212130 | Rahnama | Aug 2013 | A1 |
20130223236 | Dickey | Aug 2013 | A1 |
20130238641 | Mandelstein et al. | Sep 2013 | A1 |
20130266307 | Garg et al. | Oct 2013 | A1 |
20130268922 | Tiwari et al. | Oct 2013 | A1 |
20130275470 | Cao et al. | Oct 2013 | A1 |
20130297655 | Narasayya et al. | Nov 2013 | A1 |
20130297769 | Chang et al. | Nov 2013 | A1 |
20130297855 | Gupta | Nov 2013 | A1 |
20130304970 | Parizi | Nov 2013 | A1 |
20130318134 | Bolik et al. | Nov 2013 | A1 |
20130318288 | Khan et al. | Nov 2013 | A1 |
20140006708 | Huynh et al. | Jan 2014 | A1 |
20140016493 | Johnsson et al. | Jan 2014 | A1 |
20140019684 | Wei et al. | Jan 2014 | A1 |
20140025770 | Warfield et al. | Jan 2014 | A1 |
20140029441 | Nydell | Jan 2014 | A1 |
20140029442 | Wallman | Jan 2014 | A1 |
20140039683 | Zimmermann et al. | Feb 2014 | A1 |
20140040473 | Ho et al. | Feb 2014 | A1 |
20140040883 | Tompkins | Feb 2014 | A1 |
20140047201 | Mehta | Feb 2014 | A1 |
20140053264 | Dubrovsky et al. | Feb 2014 | A1 |
20140059187 | Rosset et al. | Feb 2014 | A1 |
20140059266 | Ben-Michael et al. | Feb 2014 | A1 |
20140086253 | Yong | Mar 2014 | A1 |
20140089273 | Borshack et al. | Mar 2014 | A1 |
20140095556 | Lee et al. | Apr 2014 | A1 |
20140096249 | Dupont et al. | Apr 2014 | A1 |
20140105009 | Vos et al. | Apr 2014 | A1 |
20140108474 | David et al. | Apr 2014 | A1 |
20140109071 | Ding et al. | Apr 2014 | A1 |
20140112122 | Kapadia et al. | Apr 2014 | A1 |
20140123207 | Agarwal et al. | May 2014 | A1 |
20140156557 | Zeng et al. | Jun 2014 | A1 |
20140164666 | Yand | Jun 2014 | A1 |
20140164866 | Bolotov et al. | Jun 2014 | A1 |
20140172371 | Zhu et al. | Jun 2014 | A1 |
20140173060 | Jubran et al. | Jun 2014 | A1 |
20140173195 | Rosset et al. | Jun 2014 | A1 |
20140173579 | McDonald et al. | Jun 2014 | A1 |
20140189278 | Peng | Jul 2014 | A1 |
20140198794 | Mehta et al. | Jul 2014 | A1 |
20140211661 | Gorkemli et al. | Jul 2014 | A1 |
20140215119 | Fujii | Jul 2014 | A1 |
20140215265 | Mohanta et al. | Jul 2014 | A1 |
20140215590 | Brand | Jul 2014 | A1 |
20140219086 | Cantu′ et al. | Aug 2014 | A1 |
20140222953 | Karve et al. | Aug 2014 | A1 |
20140229482 | Milenova | Aug 2014 | A1 |
20140229790 | Goss et al. | Aug 2014 | A1 |
20140244585 | Sivasubramanian et al. | Aug 2014 | A1 |
20140244897 | Goss et al. | Aug 2014 | A1 |
20140245435 | Belenky | Aug 2014 | A1 |
20140269390 | Ciodaru et al. | Sep 2014 | A1 |
20140281700 | Nagesharao et al. | Sep 2014 | A1 |
20140297941 | Rajani et al. | Oct 2014 | A1 |
20140307578 | DeSanti | Oct 2014 | A1 |
20140317206 | Lomelino et al. | Oct 2014 | A1 |
20140324862 | Bingham et al. | Oct 2014 | A1 |
20140325208 | Resch et al. | Oct 2014 | A1 |
20140331276 | Frascadore et al. | Nov 2014 | A1 |
20140348166 | Yang et al. | Nov 2014 | A1 |
20140355450 | Bhikkaji et al. | Dec 2014 | A1 |
20140366155 | Chang et al. | Dec 2014 | A1 |
20140376550 | Khan | Dec 2014 | A1 |
20150003450 | Salam et al. | Jan 2015 | A1 |
20150003458 | Li et al. | Jan 2015 | A1 |
20150003463 | Li et al. | Jan 2015 | A1 |
20150010001 | Duda et al. | Jan 2015 | A1 |
20150016461 | Qiang | Jan 2015 | A1 |
20150030024 | Venkataswami et al. | Jan 2015 | A1 |
20150046123 | Kato | Feb 2015 | A1 |
20150063353 | Kapadia et al. | Mar 2015 | A1 |
20150067001 | Koltsidas | Mar 2015 | A1 |
20150082432 | Eaton et al. | Mar 2015 | A1 |
20150092824 | Wicker, Jr. et al. | Apr 2015 | A1 |
20150113223 | Brown | Apr 2015 | A1 |
20150120907 | Niestemski et al. | Apr 2015 | A1 |
20150121131 | Kiselev et al. | Apr 2015 | A1 |
20150127979 | Doppalapudi | May 2015 | A1 |
20150142840 | Baldwin et al. | May 2015 | A1 |
20150169313 | Katsura | Jun 2015 | A1 |
20150180672 | Kuwata | Jun 2015 | A1 |
20150207763 | Bertran Ortiz et al. | Jun 2015 | A1 |
20150205974 | Talley et al. | Jul 2015 | A1 |
20150222444 | Sarkar | Aug 2015 | A1 |
20150229546 | Somaiya et al. | Aug 2015 | A1 |
20150248366 | Bergsten et al. | Sep 2015 | A1 |
20150248418 | Bhardwaj et al. | Sep 2015 | A1 |
20150254003 | Lee et al. | Sep 2015 | A1 |
20150254088 | Chou et al. | Sep 2015 | A1 |
20150261446 | Lee | Sep 2015 | A1 |
20150263993 | Kuch et al. | Sep 2015 | A1 |
20150269048 | Marr et al. | Sep 2015 | A1 |
20150277804 | Arnold et al. | Oct 2015 | A1 |
20150281067 | Wu | Oct 2015 | A1 |
20150303949 | Jafarkhani et al. | Oct 2015 | A1 |
20150341237 | Cuni et al. | Nov 2015 | A1 |
20150341239 | Bertran Ortiz et al. | Nov 2015 | A1 |
20150358136 | Medard | Dec 2015 | A1 |
20150379150 | Duda | Dec 2015 | A1 |
20160004611 | Lakshman | Jan 2016 | A1 |
20160011936 | Luby | Jan 2016 | A1 |
20160011942 | Golbourn et al. | Jan 2016 | A1 |
20160054922 | Awasthi et al. | Feb 2016 | A1 |
20160062820 | Jones et al. | Mar 2016 | A1 |
20160070652 | Sundararaman | Mar 2016 | A1 |
20160087885 | Tripathi et al. | Mar 2016 | A1 |
20160088083 | Bharadwaj et al. | Mar 2016 | A1 |
20160119159 | Zhao et al. | Apr 2016 | A1 |
20160119421 | Semke | Apr 2016 | A1 |
20160139820 | Fluman et al. | May 2016 | A1 |
20160149639 | Pham et al. | May 2016 | A1 |
20160205189 | Mopur et al. | Jul 2016 | A1 |
20160210161 | Rosset et al. | Jul 2016 | A1 |
20160231928 | Lewis et al. | Aug 2016 | A1 |
20160274926 | Narasimhamurthy et al. | Sep 2016 | A1 |
20160285760 | Dong | Sep 2016 | A1 |
20160292359 | Tellis et al. | Oct 2016 | A1 |
20160294983 | Kliteynik et al. | Oct 2016 | A1 |
20160334998 | George et al. | Nov 2016 | A1 |
20160366094 | Mason | Dec 2016 | A1 |
20160378624 | Jenkins, Jr. et al. | Dec 2016 | A1 |
20160380694 | Guduru | Dec 2016 | A1 |
20170010874 | Rosset | Jan 2017 | A1 |
20170010930 | Dutta et al. | Jan 2017 | A1 |
20170019475 | Metz et al. | Jan 2017 | A1 |
20170068630 | Iskandar et al. | Mar 2017 | A1 |
20170168970 | Sajeepa et al. | Jun 2017 | A1 |
20170177860 | Suarez et al. | Jun 2017 | A1 |
20170212858 | Chu et al. | Jul 2017 | A1 |
20170273019 | Park | Sep 2017 | A1 |
20170277655 | Das et al. | Sep 2017 | A1 |
20170337097 | Sipos et al. | Nov 2017 | A1 |
20170340113 | Charest et al. | Nov 2017 | A1 |
20170371558 | George et al. | Dec 2017 | A1 |
20180097707 | Wright et al. | Apr 2018 | A1 |
Number | Date | Country |
---|---|---|
2228719 | Sep 2010 | EP |
2439637 | Apr 2012 | EP |
2680155 | Jan 2014 | EP |
2350028 | May 2001 | GB |
2000-242434 | Sep 2000 | JP |
1566104 | Jan 2017 | TW |
WO 2004077214 | Sep 2004 | WO |
WO 2016003408 | Jan 2016 | WO |
WO 2016003489 | Jan 2016 | WO |
Entry |
---|
Author Unknown, “5 Benefits of a Storage Gateway in the Cloud,” Blog, TwinStrata, Inc., posted Jul. 10, 2012, 4 pages, https://web.archive.org/web/20120725092619/http://blog.twinstrata.com/2012/07/10//5-benefits-of-a-storage-gateway-in-the-cloud. |
Author Unknown, “Configuration Interface for IBM System Storage DS5000, IBM DS4000, and IBM DS3000 Systems,” IBM SAN Volume Controller Version 7.1, IBM® System Storage® SAN Volume Controller Information Center, Jun. 16, 2013, 3 pages. |
Author Unknown, “Coraid EtherCloud, Software-Defined Storage with Scale-Out Infrastructure,” Solution Brief, 2013, 2 pages, Coraid, Redwood City, California, U.S.A. |
Author Unknown, “Coraid Virtual DAS (VDAS) Technology: Eliminate Tradeoffs between DAS and Networked Storage,” Coraid Technology Brief, © 2013 Cora id, Inc., Published on or about Mar. 20, 2013, 2 pages. |
Author Unknown, “Creating Performance-based SAN SLAs Using Finisar's NetWisdom” May 2006, 7 pages, Finisar Corporation, Sunnyvale, California, U.S.A. |
Author Unknown, “Data Center, Metro Cloud Connectivity: Integrated Metro SAN Connectivity in 16 Gbps Switches,” Brocade Communication Systems, Inc., Apr. 2011, 14 pages. |
Author Unknown, “Data Center, SAN Fabric Administration Best Practices Guide, Support Perspective,” Brocade Communication Systems, Inc., May 2013, 21 pages. |
Author Unknown, “delphi—Save a CRC value in a file, without altering the actual CRC Checksum?” Stack Overflow, stackoverflow.com, Dec. 23, 2011, XP055130879, 3 pages http://stackoverflow.com/questions/8608219/save-a-crc-value-in-a-file-wihout-altering-the-actual-crc-checksum. |
Author Unknown, “EMC Unisphere: Innovative Approach to Managing Low-End and Midrange Storage; Redefining Simplicity in the Entry-Level and Midrange Storage Markets,” Data Sheet, EMC Corporation; published on or about Jan. 4, 2013 [Retrieved and printed Sep. 12, 2013] 6 pages http://www.emc.com/storage/vnx/unisphere.htm. |
Author Unknown, “HP XP Array Manager Software—Overview & Features,” Storage Device Management Software; Hewlett-Packard Development Company, 3 pages; © 2013 Hewlett-Packard Development Company, L.P. |
Author Unknown, “Joint Cisco and VMWare Solution for Optimizing Virtual Desktop Delivery: Data Center 3.0: Solutions to Accelerate Data Center Virtualization,” Cisco Systems, Inc. and VMware, Inc., Sep. 2008, 10 pages. |
Author Unknown, “Network Transformation with Software-Defined Networking and Ethernet Fabrics,” Positioning Paper, 2012, 6 pages, Brocade Communications Systems. |
Author Unknown, “Recreating Real Application Traffic in Junosphere Lab,” Solution Brief, Juniper Networks, Dec. 2011, 3 pages. |
Author Unknown, “Shunra for HP Softwarer,” Enabiling Confidence in Application Performance Before Deployment, 2010, 2 pages. |
Author Unknown, “Software Defined Networking: The New Norm for Networks,” White Paper, Open Networking Foundation, Apr. 13, 2012, 12 pages. |
Author Unknown, “Software Defined Storage Networks An Introduction,” White Paper, Doc# 01-000030-001 Rev. A, Dec. 12, 2012, 8 pages; Jeda Networks, Newport Beach, California, U.S.A. |
Author Unknown, “Standard RAID Levels,” Wikipedia, the Free Encyclopedia, last updated Jul. 18, 2014, 7 pages; http://en.wikipedia.org/wiki/Standard_RAID_levels. |
Author Unknown, “Storage Infrastructure for the Cloud,” Solution Brief, © 2012, 3 pages; coraid, Redwood City, California, U.S.A. |
Author Unknown, “Storage Area Network—NPIV: Emulex Virtual HBA and Brocade, Proven Interoperability and Proven Solution,” Technical Brief, Apr. 2008, 4 pages, Emulex and Brocade Communications Systems. |
Author Unknown, “The Fundamentals of Software-Defined Storage, Simplicity at Scale for Cloud-Architectures” Solution Brief, 2013, 3 pages; Coraid, Redwood City, California, U.S.A. |
Author Unknown, “VirtualWisdom® SAN Performance Probe Family Models: Probe FC8, HD, and HD48,” Virtual Instruments Data Sheet, Apr. 2014 Virtual Instruments. All Rights Reserved; 4 pages. |
Author Unknown, “Xgig Analyzer: Quick Start Feature Guide 4.0,” Feb. 2008, 24 pages, Finisar Corporation, Sunnyvale, California, U.S.A. |
Author Unknown, “Sun Storage Common Array Manager Installation and Setup Guide,” Software Installation and Setup Guide Version 6.7.x 821-1362-10, Appendix D: Configuring In-Band Management, Sun Oracle; retrieved and printed Sep. 12, 2013, 15 pages. |
Author Unknown, “Vblock Solution for SAP: Simplified Provisioning for Operation Efficiency,” VCE White Paper, VCE—The Virtual Computing Environment Company, Aug. 2011, 11 pages. |
Berman, Stuart, et al., “Start-Up Jeda Networks in Software Defined Storage Network Technology,” Press Release, Feb. 25, 2013, 2 pages, http://www.storagenewsletter.com/news/startups/jeda-networks. |
Borovick, Lucinda, et al., “White Paper, Architecting the Network for the Cloud,” IDC Analyze the Future, Jan. 2011, pp. 1-8. |
Chakrabarti, Kaushik, et al., “Locally Adaptive Dimensionality Reduction for Indexing Large Time Series Databases,” ACM Transactions on Database Systems, vol. 27, No. 2, Jun. 2009, pp. 188-228. |
Chandola, Varun, et al., “A Gaussian Process Based Online Change Detection Algorithm for Monitoring Periodic Time Series,” Proceedings of the Eleventh SIAM International Conference on Data Mining, SDM 2011, Apr. 28-30, 2011, 12 pages. |
Cisco Systems, Inc. “N-Port Virtualization in the Data Center,” Cisco White Paper, Cisco Systems, Inc., Mar. 2008, 7 pages. |
Cisco Systems, Inc., “Best Practices in Deploying Cisco Nexus 1000V Series Switches on Cisco UCS B and C Series Cisco UCS Manager Servers,” White Paper, Cisco Systems, Inc., Apr. 2011, 36 pages. |
Cisco Systems, Inc., “Cisco Prime Data Center Network Manager 6.1,” At-A-Glance, © 2012, 3 pages. |
Cisco Systems, Inc., “Cisco Prime Data Center Network Manager,” Release 6.1 Datasheet, © 2012, 10 pages. |
Cisco Systems, Inc., “Cisco Unified Network Services: Overcome Obstacles to Cloud-Ready Deployments,” White Paper, Cisco Systems, Inc., Jan. 2011, 6 pages. |
Clarke, Alan, et al., “Open Data Center Alliance Usage: Virtual Machine (VM) Interoperability in a Hybrid Cloud Environment Rev. 1.2,” Open Data Center Alliance, Inc., 2013, pp. 1-18. |
Cummings, Roger, et al., Fibre Channel—Fabric Generic Requirements (FC-FG), Dec. 4, 1996, 33 pages, American National Standards Institute, Inc., New York, New York, U.S.A. |
Farber, Franz, et al. “An In-Memory Database System for Multi-Tenant Applications,” Proceedings of 14th Business, Technology and Web (BTW) Conference on Database Systems for Business, Technology, and Web, Feb. 28 to Mar. 4, 2011, 17 pages, University of Kaiserslautern, Germany. |
Guo, Chang Jie, et al., “IBM Resarch Report: Data Integration and Composite Business Services, Part 3, Building a Multi-Tenant Data Tier with with [sic] Access Control and Security,” RC24426 (C0711-037), Nov. 19, 2007, 20 pages, IBM. |
Hatzieleftheriou, Andromachi, et al., “Host-side Filesystem Journaling for Durable Shared Storage,” 13th USENIX Conference on File and Storage Technologies (FAST '15), Feb. 16-19, 2015, 9 pages; https://www.usenix.org/system/files/conference/fast15/fast15-paper-hatzieleftheriou.pdf. |
Hedayat, K., et al., “A Two-Way Active Measurement Protocol (TWAMP),” Network Working Group, RFC 5357, Oct. 2008, 26 pages. |
Horn, C., et al., “Online anomaly detection with expert system feedback in social networks,” 2011 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), May 22-27, 2011, 2 pages, Prague; [Abstract only]. |
Hosterman, Cody, et al., “Using EMC Symmetrix Storage inVMware vSph ere Environments,” Version 8.0, EMC2Techbooks, EMC Corporation; published on or about Jul. 8, 2008, 314 pages; [Retrieved and printed Sep. 12, 2013]. |
Hu, Yuchong, et al., “Cooperative Recovery of Distributed Storage Systems from Multiple Losses with Network Coding,” University of Science & Technology Of China, Feb. 2010, 9 pages. |
Keogh, Eamonn, et al., “Dimensionality Reduction for Fast Similarity Search in Large Time Series Databases,” KAIS Long Paper submitted May 16, 2000; 19 pages. |
Kolyshkin, Kirill, “Virtualization in Linux,” Sep. 1, 2006, pp. 1-5. |
Kovar, Joseph F., “Startup Jeda Networks Takes SDN Approach To Storage Networks,” CRN Press Release, Feb. 22, 2013, 1 page, http://www.crn.com/240149244/printablearticle.htm. |
Lampson, Butler, W., et al., “Crash Recovery in a Distributed Data Storage System,” Jun. 1, 1979, 28 pages. |
Lewis, Michael E., et al., “Design of an Advanced Development Model Optical Disk-Based Redundant Array of Independent Disks (RAID) High Speed Mass Storage Subsystem,” Final Technical Report, Oct. 1997, pp. 1-211. |
Lin, Jessica, “Finding Motifs in Time Series,” SIGKDD'02 Jul. 23,-26, 2002, 11 pages, Edmonton, Alberta, Canada. |
Linthicum, David, “VM Import could be a game changer for hybrid clouds”, InfoWorld, Dec. 23, 2010, 4 pages. |
Long, Abraham Jr., “Modeling the Reliability of RAID Sets,” Dell Power Solutions, May 2008, 4 pages. |
Ma, AO, et al., “RAIDShield: Characterizing, Monitoring, and Proactively Protecting Against Disk Failures,” FAST '15, 13th USENIX Conference on File and Storage Technologies, Feb. 16-19, 2015, 17 pages, Santa Clara, California, U.S.A. |
Mahalingam, M., et al., “Virtual eXtensible Local Area Network (VXLAN): A Framework for Overlaying Virtualized Layer 2 Networks over Layer 3 Networks,” Independent Submission, RFC 7348, Aug. 2014, 22 pages; http://www.hjp.at/doc/rfc/rfc7348.html. |
McQuerry, Steve, “Cisco UCS M-Series Modular Servers for Cloud-Scale Workloads,” White Paper, Cisco Systems, Inc., Sep. 2014, 11 pages. |
Monia, Charles, et al., IFCP—A Protocol for Internet Fibre Channel Networking, draft-monia-ips-ifcp-00.txt, Dec. 12, 2000, 6 pages. |
Mueen, Abdullah, et al., “Online Discovery and Maintenance of Time Series Motifs,” KDD'10 The 16th ACM SIGKDD International Conference on Knowledge Discovery and Data Mining, Jul. 25-28, 2010, 10 pages, Washington, DC, U.S.A. |
Muglia, Bob, “Decoding SDN,” Jan. 14, 2013, Juniper Networks, pp. 1-7, http://forums.juniper.net/t5/The-New-Network/Decoding-SDN/ba-p/174651. |
Murray, Joseph F., et al., “Machine Learning Methods for Predicting Failures in Hard Drives: A Multiple-Instance Application,” Journal of Machine Learning Research 6 (2005), pp. 783-816; May 2005, 34 pages. |
Nelson, Mark, “File Verification Using CRC,” Dr. Dobb's Journal, May 1, 1992, pp. 1-18, XP055130883. |
Pace, Alberto, “Technologies for Large Data Management in Scientific Computing,” International Journal of Modern Physics C., vol. 25, No. 2, Feb. 2014, 72 pages. |
Pinheiro, Eduardo, et al., “Failure Trends in a Large Disk Drive Population,” FAST '07, 5th USENIX Conference on File and Storage Technologies, Feb. 13-16, 2007, 13 pages, San Jose, California, U.S.A. |
Raginsky, Maxim, et al., “Sequential Anomaly Detection in the Presence of Noise and Limited Feedback,” arXiv:0911.2904v4 [cs.LG] Mar. 13, 2012, 19 pages. |
Saidi, Ali G., et al., “Performance Validation of Network-Intensive Workloads on a Full-System Simulator,” Interaction between Operating System and Computer Architecture Workshop, (IOSCA 2005), Austin, Texas, Oct. 2005, 10 pages. |
Sajassi, A., et al., “BGP MPLS Based Ethernet VPN,” Network Working Group, Oct. 18, 2014, 52 pages. |
Sajassi, Ali, et al., “A Network Virtualization Overlay Solution using EVPN,” L2VPN Workgroup, Nov. 10, 2014, 24 pages; http://tools.ietf.org/pdf/draft-ietf-bess-evpn-overlay-00.pdf. |
Sajassi, Ali, et al., “Integrated Routing and Bridging in EVPN,” L2VPN Workgroup, Nov. 11, 2014, 26 pages; http://tools.ietf.org/pdf/draft-ietf-bess-evpn-inter-subnet-forwarding-00.pdf. |
Schroeder, Bianca, et al., “Disk failures in the real world: What does an MTTF of 1,000,000 hours mean to you?” FAST '07: 5th USENIX Conference on File And Storage Technologies, Feb. 13-16, 2007, 16 pages, San Jose, California, U.S.A. |
Shue, David, et al., “Performance Isolation and Fairness for Multi-Tenant Cloud Storage,” USENIX Association, 10th USENIX Symposium on Operating Systems Design Implementation (OSDI '12), 2012, 14 pages; https://www.usenix.org/system/files/conference/osdi12/osdi12-final-215.pdf. |
Staimer, Marc, “Inside Cisco Systems' Unified Computing System,” Dragon Slayer Consulting, Jul. 2009, 5 pages. |
Swami, Vijay, “Simplifying SAN Management for VMWare Boot from SAN, Utilizing Cisco UCS and Palo,” posted May 31, 2011, 6 pages. |
Tate, Jon, et al., “Introduction to Storage Area Networks and System Networking,” Dec. 2017, 302 pages, ibm.com/redbooks. |
Vuppala, Vibhavasu, et al., “Layer-3 Switching Using Virtual Network Ports,” Computer Communications and Networks, 1999, Proceedings, Eight International Conference in Boston, MA, USA, Oct. 11-13, 1999, Piscataway, NJ, USA, IEEE, ISBN: 0-7803-5794-9, pp. 642-648. |
Wang, Feng, et al. “OBFS: A File System for Object-Based Storage Devices,” Storage System Research Center, MSST. vol. 4., Apr. 2004, 18 pages. |
Weil, Sage A., “Ceph: Reliable, Scalable, and High-Performance Distributed Storage,” Dec. 2007, 239 pages, University of California, Santa Cruz. |
Weil, Sage A., et al. “CRUSH: Controlled, Scalable, Decentralized Placement of Replicated Data.” Proceedings of the 2006 ACM/IEEE conference on Supercomputing. ACM, Nov. 11, 2006, 12 pages. |
Weil, Sage A., et al. “Ceph: A Scalable, High-performance Distributed File System,” Proceedings of the 7th symposium on Operating systems design and implementation. USENIX Association, Nov. 6, 2006, 14 pages. |
Wu, Joel, et al., “The Design, and Implementation of AQuA: An Adaptive Quality of Service Aware Object-Based Storage Device,” Department of Computer Science, MSST, May 17, 2006, 25 pages; http://storageconference.us/2006/Presentations/30Wu.pdf. |
Xue, Chendi, et al. “A Standard framework for Ceph performance profiling with latency breakdown,” Ceph, Jun. 30, 2015, 3 pages. |
Zhou, Zihan, et al., “Stable Principal Component Pursuit,” arXiv:1001.2363v1 [cs.IT], Jan. 14, 2010, 5 pages. |
Zhu, Yunfeng, et al., “A Cost-based Heterogeneous Recovery Scheme for Distributed Storage Systems with RAID-6 Codes,” University of Science & Technology Of China, 2012, 12 pages. |
Aweya, James, et al., “Multi-level active queue management with dynamic thresholds,” Elsevier, Computer Communications 25 (2002) pp. 756-771. |
Petersen, Chris, “Introducing Lightning: A flexible NVMe JBOF,” Mar. 9, 2016, 6 pages. |
Stamey, John, et al., “Client-Side Dynamic Metadata in Web 2.0,” SIGDOC '07, Oct. 22-24, 2007, pp. 155-161. |
Number | Date | Country | |
---|---|---|---|
20160366094 A1 | Dec 2016 | US |
Number | Date | Country | |
---|---|---|---|
62173854 | Jun 2015 | US |