Nothing Special   »   [go: up one dir, main page]

US20050144199A2 - Distributed Network Storage System With Virtualization - Google Patents

Distributed Network Storage System With Virtualization Download PDF

Info

Publication number
US20050144199A2
US20050144199A2 US10/708,867 US70886704A US2005144199A2 US 20050144199 A2 US20050144199 A2 US 20050144199A2 US 70886704 A US70886704 A US 70886704A US 2005144199 A2 US2005144199 A2 US 2005144199A2
Authority
US
United States
Prior art keywords
storage
data
server
servers
management
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US10/708,867
Other versions
US20050010618A1 (en
US7200664B2 (en
Inventor
Mark Hayden
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Hewlett Packard Enterprise Development LP
Original Assignee
Lefthand Networks Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Lefthand Networks Inc filed Critical Lefthand Networks Inc
Priority to US10/708,867 priority Critical patent/US7200664B2/en
Publication of US20050010618A1 publication Critical patent/US20050010618A1/en
Publication of US20050144199A2 publication Critical patent/US20050144199A2/en
Application granted granted Critical
Publication of US7200664B2 publication Critical patent/US7200664B2/en
Assigned to HEWLETT-PACKARD COMPANY reassignment HEWLETT-PACKARD COMPANY MERGER (SEE DOCUMENT FOR DETAILS). Assignors: LEFTHAND NETWORKS, INC.
Assigned to HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P. reassignment HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HEWLETT-PACKARD COMPANY
Assigned to HEWLETT-PACKARD COMPANY reassignment HEWLETT-PACKARD COMPANY MERGER (SEE DOCUMENT FOR DETAILS). Assignors: LEFTHAND NETWORKS, INC.
Assigned to LEFTHAND NETWORKS, INC reassignment LEFTHAND NETWORKS, INC MERGER (SEE DOCUMENT FOR DETAILS). Assignors: LAKERS ACQUISITION CORPORATION
Assigned to HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP reassignment HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.
Adjusted expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/173Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1097Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/167Interprocessor communication using a common memory, e.g. mailbox
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F2003/0697Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers device management, e.g. handlers, drivers, I/O schedulers
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99944Object-oriented database structure
    • Y10S707/99945Object-oriented database structure processing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99948Application of database or data structure, e.g. distributed, multimedia, or image

Definitions

  • the present invention relates to data storage and, in particular, to the distribution of data storage over a computer network.
  • a conventional networked computer system is comprised of a number of computers that each have an operating system, a network for communicating data between the computers, and at least one data storage device that is attached to at least one of the computers but not directly attached to the network.
  • the transfer of data between the data storage device and a computer in the system other than the computer with which the device is associated requires that the operating system of the computer with which the data storage device is associated to devote a certain amount of time to the processing of the data transfer.
  • the operating system of the computer is typically servicing requests from various applications (e.g., a word processing application) executing on the computer, the operating system typically is only able to devote a limited amount of time to the processing of the data transfer.
  • data storage devices were developed that directly attached to a network, i.e., network data storage devices. Due to this direct attachment, any computer in a networked computer system is able to directly communicate with the network storage device.
  • a further advent has been the development of distributed network data storage in which two or more network data storage devices are utilized and a mechanism exists for defining a logical volume, i.e., a unit of data storage that physically extends over the two or more data storage devices. Consequently, to computers in a networked computer system, the logical volume appears to be a single storage device.
  • An example of a network computer system that employs distributed network storage is comprised of: (a) two fibre channel disk drives; (b) a computer; and (c) a network for facilitating data transfers between the drives and the computer.
  • the computer comprises a driver (a program that allows an operating system to communicate with a device) for each of the drives and a logical volume manager that controls the drivers so as to define a logical or virtual volume that extends over the two fibre channel disk drives.
  • the present invention is directed to a system for use in achieving distributed network data storage in a network and that provides the flexibility to achieve additional functionality, such as the ability to scale the data storage, stripe data, replicate data, migrate data, snapshot data, and provide shared access.
  • the system is comprised of a storage server system that is, in turn, comprised of one or more data storage servers which provide data storage and data transfer capability for application clients in a networked computer system.
  • An application client is a computer in a networked computer system that is or will execute a particular application program (e.g., a data base management program) that requires or will likely require data storage and transfer capability.
  • a data storage server is comprised of a data storage device (e.g., a disk drive) and a network interface for communicating, via a network, with an application client and a management storage server.
  • the system is further comprised of a management storage server system that is, in turn, comprised of one or more management storage servers which each provide certain storage management functionality relative to any application clients and the storage server system.
  • a management data storage server is comprised of a network interface for communicating, via a network, with an application client and the storage servers in the storage system.
  • a management data storage server is further comprised of a data storage device (e.g., a disk drive or tape drive).
  • Each of the management storage servers comprises a data storage configuration identifier that is used to coordinate the operation of the storage servers.
  • the value of the identifier is indicative of an allocation of data storage within the storage server system at a particular point in time. In one embodiment, the value is a time stamp. Other types of values are feasible.
  • the allocation of data storage within the storage server system comprises defining any number virtual or logical volumes that are each distributed over one or more of the storage servers.
  • Each of the management storage servers is capable of providing a first value for the identifier to an application client. For example, a management storage server provides a first value for the identifier to an application client as part of the allocation of data storage to the application client. Further, each of the management storage servers is capable of providing an updated value for the identifier to each of the storage servers after there is a change in allocation of data storage within the storage server system.
  • the storage servers use the identifier in deciding whether or not to carry out a data related request from an application client.
  • a data related request that a storage server receives from an application client comprises the most recent value of the data storage configuration identifier in the application client's possession.
  • the storage server compares the most recent value of the identifier in its possession to the value of the identifier associated with the received request. If the values are the same, both the application client and the storage server understand the data storage allocation to be the same. In this case, the storage server proceeds with the processing of the data related request. If, however, the value of the identifier in the storage servers possession and the value of the identifier associated with the request are different, the application client and the storage server understand the data allocation to be different.
  • the application client is operating based upon an out of date data storage allocation.
  • the storage server does not proceed with the processing of the request because to do so might corrupt data.
  • the storage server causes an error to be generated that is provided, via the network, to a management storage server.
  • the management storage server provides the application client with an updated identifier that the application client is then capable of utilizing to retry the data related requested, if desired.
  • Fig. 1 is a block diagram of a networked computer system that employs an embodiment of the distributed storage system of the present invention
  • Fig. 2 is a block diagram of a networked computer system in which the application client is a parallel database server and in which an embodiment of the distributed storage system of the present invention is employed;
  • Fig. 3A illustrates the use of bit masks in verify that a page of data on one storage server is synchronized with a copy of a page of data on another storage server when data is being replicated;
  • Fig. 3B illustrates the use of bit masks to indicate that a page of data on one storage server is desynchronized with a copy of a page of data on another storage server when data is being replicated;
  • Figs. 4A-4C illustrate an example of the use of a layering mechanism to migrate data from pages on one volume to pages on another volume
  • Figs. 5A-5C illustrate an example of the use of a layering mechanism to implement a snapshot operation
  • Fig. 6 illustrates an embodiment of a process implemented by the management storage server to manage the storage server system
  • Fig. 7A illustrates an embodiment of a process implemented by the driver associated with an application client to perform a read operation
  • Fig. 7B illustrates an embodiment of a process implemented by the driver associated with an application client to perform a write operation.
  • FIG. 1 illustrates an embodiment of a networked computer system 10 that employs an embodiment of a distributed storage system 12, hereinafter system 12.
  • the networked computer system 10 comprises: (a) an application client system 14 that comprises one or more application clients 16 (i.e., a computer that is or will run an application program); (b) the system 12; and (c) a network 18 for conveying communications between the application clients 16 and the system 12, and between elements of the system 12.
  • the network 18 is a Gigabit Ethernet network.
  • the invention is applicable or adaptable to other types of networks.
  • the system 12 is comprised of a storage system 20 that provides data storage capability to an application program executing on an application client.
  • the storage system 20 comprises one or more storage servers 22.
  • Each storage server 22 comprises at least one data storage device and at least one interface for communicating with the network 18.
  • the data storage device is a disk drive.
  • other types of data storage devices are feasible.
  • tape drives are feasible.
  • the storage server 22 is comprised of multiple data storage devices, the devices are all of the same type (e.g., disk drives). It is, however, feasible to use different types of data storage devices. (e.g., disk drives and tape drives, different types of disk drives, different types of tape drives or combinations thereof).
  • the system 12 is further comprised of a management storage server system 24 that provides management functions relating to data transfers between the application clients and the storage system 20.
  • the management storage server system 24 comprises one or more management storage servers 26. Generally, it is desirable to have multiple management storage servers 26 for fault tolerance.
  • Each management storage server 26 comprises at least one interface for communicating with the network 18 and at least one data storage device (e.g., disk drive or tape drive).
  • at least one of the management storage servers 26 comprises an interface 28 that allows a user to interact with the server 26 to implement certain functionality relating to data transfers between an application client 16 and the storage system 20.
  • the interface 28 is a graphical user interface (GUI) that allows a user to interact with the server 26 via a conventional monitor and keyboard or mouse.
  • GUI graphical user interface
  • Other types of interfaces that communicate with other types of peripherals (e.g., printers, light pens, voice recognition etc.) or network protocols are feasible.
  • a management storage server co-located with a storage server and/or driver.
  • the system 12 further comprises a driver 29 that is associated with each application client 16 and facilitates communications between the application client 16 and the system 12.
  • driver 29 there are alternatives to the use of driver 29.
  • PCI Peripheral Component Interconnect
  • HBA Host Bus Adapter
  • Each of the management storage servers 26 comprises a data storage configuration identifier that relates to a storage configuration map which reflects the composition of the storage system 20 and the allocation of data storage across the storage system 20 to the various application clients 16 at a point in time.
  • the data storage configuration identifier has a value that changes when the composition of the storage system 20 changes or the allocation of storage within the system 20 changes.
  • the value of the identifier is a logical time stamp that monotonically increases as changes occur.
  • Other types of logical time stamps are possible. For example, logical time stamps with values that decrease are possible, as well as logical time stamps whose values change in a predictable manner. Further, time stamps other than logical time stamps are feasible. For example, a time stamp that reflects actual time is also feasible.
  • the storage configuration map identifies each of the storage servers 22 in the storage system 20.
  • the map identifies each logical or virtual volume, i.e., an amount of data storage that is distributed between two of more the storage servers 22 that is allocated to a particular application client 16.
  • the map identifies the partitioning of each logical or virtual volume, i.e., how much data storage of the volume is provided by each of the storage servers 22.
  • a management storage server 26 allocates data storage within the storage system 20 to an application client 16
  • the server 26 provides an updated value for the data storage configuration identifier to the relevant application client 16 and, more particularly, to the driver 29 within the application client 16.
  • the identifier is attached to all requests for data transfers from the storage system 20 by the application client.
  • the management storage server 26 also provides each of the storage servers 22 with the updated value of the identifier.
  • the management storage server 26 may not, however, be able to provide the updated value to other application clients. Consequently, the other application clients may have outdated values for the identifier that reflect an outdated configuration.
  • each of the storage servers 22 receives a request for a data transfer from an application client to prevent corruption of the data.
  • each of the storage servers 22 comprises a comparator that compares the value for the identifier that has been most recently received from the a management storage server 26 to the value of the identifier appended to the data transfer request from an application client. If the values are not equal, then there has been a change in the composition of the storage system 20 or the allocation of storage within the storage server system 20. In this case, since corruption of data could occur or incorrect data could be provided to the application client if the transfer was carried out, the storage server 22 at least ignores the request.
  • the storage server 22 returns an error message to the relevant application client or a management storage server 26 that is processed so as to provide the relevant application client with an updated value for the identifier.
  • the application client may be able to reinitiate the request for a data transfer or know that it needs to get the new configuration.
  • the storage server 22 processes the data transfer requested by the relevant application client.
  • the system 12 is capable of readily being scaled to increase or decrease the number of storage servers 22 in the storage system 20.
  • a user is able to use the interface 28 associated with at least one of the management storage servers 26 to propose a modification to the configuration map that involves either the addition of a storage server to the storage system 20 or the subtraction of a storage server 22 from the system 20. If there are other management storage servers 26 in the management storage server system 24, the proposed modification to the configuration is provided to each of the servers 26.
  • Each of the servers 26 is capable of evaluating the impact of the proposed modification and providing a "vote" indicating approval or disapproval of the modification.
  • a management storage server might provide a disapproving vote if the proposed modification would adversely affect the ability to implement certain storage functions.
  • the configuration map is changed, any re-allocation of storage within the storage system 20 that is required by the change is implemented, any copying of data within the storage system 20 undertaken, and an updated value for the data storage configuration identifier is issued to each of the storage servers.
  • the system 12 is capable of implementing striping, i.e., the partitioning of a logical or virtual volume across two or more storage servers 22.
  • a user is able to use the interface 28 associated with at least one of the management storage servers 26 to propose: (a) a logical or virtual volume within the storage system 20 for an application client; and (b) the partitioning of such a volume between two or more of the storage servers 22 in the storage system 20.
  • the proposed logical volume and proposed partitioning of the volume is provided to each of the management storage servers 26 for assessing the impact thereof and providing an approving or disapproving vote.
  • the configuration map is changed, any re-allocation of storage within the storage system 20 that is required by the change is implemented, any copying of data within the storage system 20 undertaken, and an updated value for the data storage configuration identifier is issued to each of the storage servers.
  • the networked computer system 10' further comprises a particular application client system, namely, a parallel database server system 14', such as an ORACLE parallel database server system.
  • the parallel database server system 14' is comprised of two or more parallel database servers 16' that cooperatively operate with one another in the management of a database that is or will be stored in a volume on the storage system 20.
  • the parallel database server system 14' is further comprised of a distributed lock manager system 30 that is, in turn, comprised of one or more distributed lock managers 32 that each operate to issue "locks" to the parallel database servers 16'.
  • a lock relates to a distinct portion of the database that is or will be stored on the volume allocated to the parallel database server system on the storage system 20.
  • the issuance of a lock to one of the parallel database servers 16' provides exclusive write access or shared read access to the portion of the distinct portion of database to which the lock relates relative to the other parallel database servers. By providing exclusive write access to only one of the parallel database servers 16', the situation in which two of the servers are concurrently updating the same portion of the database is prevented.
  • each of the distributed lock managers 30 is implemented, in one embodiment, such that each of the distributed lock managers 30 is associated with one of the parallel database servers 16'.
  • each of the distributed lock managers 30 has access to the driver 29 (via a generic interface associated with the parallel database management program) that facilitates communication with the distributed storage system 12.
  • the distributed lock managers 30 are feasible, provided each of the lock managers has the ability to communicate with at least one of the management storage servers 26.
  • Each of the distributed lock managers 30 operates so as to monitor the parallel database server to which a lock has been issued to determine if the lock can be returned so that the lock can be issued to another one of the parallel database servers 16'.
  • a distributed lock manager 30 operates to revoke a lock issued to a first of the parallel database servers 16. For example, if a distributed lock manager 30 determines that the communication link with the first parallel database server to which a lock has been issued is no longer active or available or that the first parallel database server has failed, the distributed lock manager 30 revokes the lock issued to the first parallel database server. In such a situation, the distributed lock manager 30 can reissue the lock to a second parallel database servers.
  • a problem with the lock being issued to the second parallel database server is that the first parallel database server, while in possession of the lock, may have initiated a write request to the volume on the storage system 20 that has not been processed by the storage system 20 by the time the lock has been revoked and issued to the second parallel database server.
  • This situation occurs if, for example, the write request is still traversing the network during the period of time when the lock is being revoked and reissued to the second parallel database server.
  • one of the distributed lock managers 32 communicates, via its driver 29, with one of the management storage servers 26 that a lock is being revoked.
  • the management storage server updates a "lock" map. Updating of the "lock” map causes the value of the data storage configuration identifier to be updated.
  • the management storage server provides the updated value for the data storage configuration identifier to each of the storage servers 22 in the storage system 20. Subsequently, the management storage server issues a communication to the distributed lock manager that authorizes the lock manager to reissue the lock.
  • Providing an updated value for the data storage configuration identifier to the storage server 22 prevents the write request that was initiated by the first parallel database server from being processed the storage server.
  • associated with the write request is a particular value for the data storage configuration identifier that was previously provided to the parallel database server by one of the management storage servers 26.
  • the storage servers 22 have an updated value for the data storage configuration identifier that is different from the value for the identifier associated with the write request. Consequently, if one of the storage server 22 receives the write update, the comparator in the storage server detects the difference in the values of the data storage configuration identifiers and, due to the difference, at least ignores the request for the write update.
  • a user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause data from an application client to be replicated on the volume of the storage system 20 dedicated to the application client such that one copy of the data resides on one of the storage servers 22 and one or more other copies of the data each reside on one of the other storage servers 22.
  • This redundancy provides fault tolerance.
  • the user indicates that data is to be replicated by appropriately modifying the configuration map via the interface 28. Updating the configuration map causes the value of the data storage configuration identifier to be updated.
  • the updated value for the data storage configuration identifier is provided to each of the storage servers 22 and the driver 29 of the application client to which the replication is relevant.
  • the driver 29 is also provided with configuration map or other information that defines the replication that is to be applied to the application client data, e.g., the relevant volume and the storage servers on which the copies of the data are to reside.
  • a problem with replicating data is that the copies of the data can become de-synchronized, i.e., the copies are no longer identical to one another. For example, copies of data become de-synchronized when a first copy of the data is updated on one of the storage servers 22 but one of the other storage servers 22 that is to have a second copy of the data fails before the update occurs on the server.
  • bit mask device also referred to as synchronization bits
  • the operation of the bit mask device is illustrated for the situation in which copies of a page of data are to be replicated on server "0" and server "1".
  • a page of data is a unit of allocation for the storage system 20, typically on the order of a megabyte in size, but other sizes are feasible.
  • bit mask 40 Associated with server "0" is a two bit, bit mask 40 with the first bit of the mask relating to server "0" and the second bit relating to server "1".
  • Associated with server “1” is a two bit, bit mask 42 with a first bit of the mask relating to server “0” and the second bit relating to server "1".
  • the value of each of the bits in both bit masks is a logical "1", which is also referred to as a "clean" condition.
  • bit "S0" of the mask 40 is always set to a logical 1 and bit "S1" of the mask 42 is always set to a logical 1.
  • the write request includes clearing bit mask values and restoring bit mask values.
  • the clearing bit mask values are the values to which the bits of the bit mask 40 are to be set prior to the processing of the write request by server "0".
  • the restoring bit mask values are the values to which the bits of the bit mask 40 are to be set after it is confirmed that the write request was processed.
  • the clearing bit mask values are used to update bit mask 40 prior to processing the write request for server "0". Once the write request for server "0" has been processed by server "0", the server issues an acknowledgment with a token to the client application.
  • the write request issued by the driver 29 to server "1" includes clearing bit mask values and restoring bit mask values.
  • the clearing bit mask values are used to update bit mask 42 prior to processing the write request for server "1".
  • the server issues an acknowledgment with the token to the client application.
  • the driver 29 includes the token in the next commands issued to each of the storage servers on which data is being replicated.
  • the next commands are write requests issued to both server “0" and server “1" to replicate data.
  • the storage server "0” responds to its command by changing the value of the bits in the bit mask 40 to the restoring values, i.e., "11".
  • the storage server "1” respond to its command by changing the value of the bits in bit mask 42 to the restoring values, i.e., "11”.
  • the value of each of the bits in each of the bit masks 40, 42 is the same, namely, logical "1". Consequently, the copies of the page of data on server "0” and server “1” are synchronized, i.e., identical to one another.
  • the copies of the page of data on servers "0" and “1" are initially assumed to be in synchronization.
  • the value of each of the bits in bit masks 40, 42 is the same, namely, a logical "1".
  • one of the management storage servers 26 Prior to write requests being issued to servers "0" and “1" to implement a replication operation, one of the management storage servers 26 deems server "1" to have failed.
  • At least one of the management storage servers 26 issues a request to at least one of the storage servers 22 on occasion to determine if the storage server is operational. If the server is operational, the storage server will cause some form of reply or acknowledgment to be sent to the management storage server that issued the request within a predetermined amount of time.
  • the management storage server If a reply or acknowledgment is not received within the predetermined amount of time, the management storage server assumes that the storage server has failed. In such a situation, the management storage server updates the configuration map, updates the value of the data storage configuration map identifier, and provides the map and identifier to the application client, as well as the storage servers 22. Since the application client is aware that server "1" has failed, no write request is issued to storage server "1". The write request issued to server "0" includes clearing bit values and restoring bit values. However, due to the change in the storage system 20 caused by the failure of server "1" and reflected in the change in the data storage configuration identifier, the restoring bit values are, unlike in Fig. 3A , set to "10".
  • Server "0" after receiving the write request but before processing the write requests, sets the values of the bits in bit mask 40 to the clearing bit values, namely, logical "10".
  • the server then processes the write request and sends an acknowledgment to the application client that includes a token.
  • the next command received by server "0" from the application includes the token.
  • server "0” modifies the bits of the bit mask 40 to the restoring values specified in the restoring bit values that accompanied the write request, namely, logical "10".
  • the bit masks reflect a de-synchronization state.
  • At least one of the management storage servers 26 is monitoring the bit masks and detects the indication of the copies of the page of data being de-synchronized. After the management storage server detects this condition, the management storage server typically causes remedial action to be taken. In this case, the management storage server cause the copy of the page of data on server "0" to be written to server "1", thereby bringing the copies of the data back into synchronization. It should be appreciated that the bit masks are capable of being used to detect de-synchronization that is attributable to other causes.
  • bit mask device described with respect to Figs. 3A and 3B is capable of being extended to accommodate a greater number of copies. Further, it should be appreciated that opposite bit values from those described with respect to Figs. 3A and 3B can be utilized.
  • a user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause data on one logical volume to be migrated to another logical volume. This is accomplished using a "translucent" layering mechanism.
  • the management storage server saves the portion of the data storage configuration map that relates to the volume whose data that is to be migrated (the old volume), identifies this portion of the map as a layer, and orders this layer as a first or old layer.
  • the data storage configuration map is then updated to reflect the new data storage configuration and, in particular, to identify the logical volume to which the data is migrated (the new volume). This causes the value of the data storage configuration identifier to be updated.
  • the new map and value for the identifier are distributed to the storage servers 22 and to the driver 29 in the relevant application client.
  • the portion of the configuration map that relates to the new volume to which the data is to be migrated is identified as a layer and this layer is ordered as a second or new layer.
  • data is migrated from the old volume to the new volume by two possible mechanisms.
  • at least one of the management storage servers 26 actively monitors each of the pages in the first or old layer to determine if the data associated with each of the pages in the old volume has not been migrated to the new volume. If a page is found whose data has not been migrated to the new volume, the management storage server causes the data from the page on the old volume to be read, the data to then be written to the new volume, and the page in the old volume to be marked as "deleted".
  • the second mechanism for migrating data from the old volume to the new volume occurs when an application client endeavors to write to a page on the new volume.
  • the driver 29 interrogates the new layer before issuing the write request relating to the page to determine if the page in the new layer has received the data from the corresponding page in the old volume. If not, the driver 29 is able to "see through” the "transparent" portion of the new layer that relates to the page to which data is to be written to the old layer and "see” that the data has not yet been migrated from the old volume for the corresponding page. In this case, driver 29 causes the data from the page on the old volume to be read, the data to then be written to the new volume, and the page in the old volume to be marked as "deleted". Further, after data from the page on the old volume has been migrated to the new volume, the driver 29 issues the write request that then causes data to be written to the page on the new volume.
  • each page of the old volume By marking each page of the old volume as deleted after the data from the page has been migrated, a mechanism is provided for preventing a situation that could adversely affect the migration.
  • the driver 29 associated with each application client endeavors to cause the migration of data from the page on the old volume to the corresponding page on the new volume.
  • the driver 29 associated with one of the application clients will be successful in causing the data for the page to be migrated and may then cause the data on the page on the new volume to be updated via a write request.
  • the driver 29 associated with the other application client would not be aware that the data for the page has been migrated and endeavor to migrate the data to the corresponding page on the new volume. If this were to happen, the data migrated by the other application client could overwrite the new data established in the page by the write request issued by the application client that initially caused the data to be migrated. To avoid this possibility, the driver 29 checks the relevant page in the old layer to determine if the data for the page has already been migrated, before taking any action to migrate the data. If the data for the page has been migrated, then the driver 29 aborts the current write request and retries the write request.
  • the old layer is deleted.
  • Figure 4A illustrates an old volume comprised of six pages (0-5)and with data (A-F) in each of the pages and a new volume before the migration of any data from the old volume to the new volume.
  • the old volume is further identified as a layer and ordered as the first or old layer. Because data is present in each of the pages of the old volume at this point, there is no "transparency" associated with the old layer.
  • the new volume is also identified as a layer and ordered as the second or new layer. Because no data is present in any of the pages of the new volume at this point, there is “transparency” associated with each page in the new layer. This "transparency" allows the driver associated with an application client to "see” that the data for the page is present in the first or old layer.
  • FIG 4B illustrates the old volume and the new volume after the data (B) in page "1" of the old volume has been migrated to page "1" in the new volume.
  • Figure 4C illustrates the old volume and the new volume after the data for each page of the old volume has been migrated to the corresponding page in the new volume.
  • there is no longer any "transparency" associated with the new layer which indicates that data from all of the pages in the old volume has been migrated to the new volume.
  • each of the pages in the old layer, due to the completed migration is now marked as deleted. As a consequence, the old layer is no longer required and can be deleted.
  • the translucent layering mechanism is capable of being extended to multiple migrations that would require additional layers.
  • Snapshot A snapshot preserves the state of a volume at a particular point in time while also causing the data in the pages of the preserved volume, the snapshot volume, to be migrated to a new volume where the pages can be updated by one of more of the application clients. To preserve the state of the snapshot volume, the new volume cannot overlap with the snapshot volume.
  • a user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause a snapshot.
  • the management storage server 26 establishes the same translucent layering mechanism described with respect to the migration process to facilitate migration of the data from the snapshot volume to the new volume.
  • Migration is achieved by the migration of data in a page as a prelude to the issuance of a write request from the driver 29 associated with an application.
  • the page on the snapshot volume is not marked as deleted. Consequently, the data in the pages of the snapshot volume are preserved.
  • Figure 5A illustrates a snapshot volume comprised of six pages (0-5) and with data (A-F) in each of the pages and a new volume before the migration of any data from the snapshot volume to the new volume.
  • the snapshot volume is further identified as a layer and ordered as the first or old layer. Because data is present in each of the pages of the snapshot volume at this point, there is no "transparency" associated with the old layer.
  • the new volume is also identified as a layer and ordered as the second or new layer. Because no data is present in any of the pages of the new volume at this point, there is “transparency” associated with each page in the new layer. This "transparency" allows the driver associated with an application client to "see” that the data for the page is present in the first or old layer.
  • Figure 5B illustrates the snapshot volume and the new volume after the data (B) in page “1" of the snapshot volume has been migrated to page “1" in the new volume.
  • Figure 5C illustrates the snapshot volume and the new volume after the data for each page of the snapshot volume has been migrated to the corresponding page in the new volume.
  • there is no longer any "transparency" associated with the new layer which indicates that data from all of the pages in the old volume has been migrated to the new volume.
  • the data in each of the pages of the snapshot volume before the migration operation is still present and in the same location after completion of the migration.
  • the snapshot has preserved the state of the initial volume at a particular point in time.
  • the data in each of the pages of the snapshot volume has also been migrated to the new volume and the pages of the new volume are susceptible to modification as a result of the processing of write requests issued by an application client.
  • the management storage servers each carry out a process that has two primary tasks: resynchronization of data after a storage server failure or restart, and the migration of a volume of data.
  • the process has two phases. The first phase involves locating the volumes and pages within the volumes that need to be either resynchronized or migrated.
  • the management storage server begins by examining its set of configuration maps for the volumes currently being managed. From this, the server determines which volumes may require some work because the volume is in the process of being migrated to a different set of storage servers or because at least one of the storage servers storing data for the volume had failed and then restarted but had not yet been fully resynchronized.
  • the management storage server After determining the set of volumes requiring work, the management storage server then picks one of them, either randomly or according to some priority. The management storage server then requests that each of the storage servers enumerate up to some fixed number of pages that match the migration or resynchronization criteria. The pages are accumulated by the management storage server with duplicates being discarded. The management then proceeds through the pages, either one-by-one or potentially several in parallel, for the second phase of the process.
  • the management storage server For each page, the management storage server first requests the status of all copies of the page in all the layers associated with the volume from the associated storage servers. If any of the copies of the page in any of the layers has synchronization bits that indicate the different copies could contain different data, then these layers of the page are selected to be resynchronized. They are resynchronized as follows.
  • the management storage server picks a copy of the page on one server which is referred to as the "authoritative copy" and reads the contents of that copy.
  • the management storage servers must pick the authoritative copy in such a way that they all pick the same copy as authoritative. One way to do this is to base the selection on information in the configuration map, but other methods are feasible.
  • the management storage server After reading the authoritative copy, the management storage server then writes the contents of the page to the other copies of the page in that layer. The management storage server then marks all copies of the page as being clean by setting their synchronization bits. The management storage server is now done with the page for the time being (it is possible there is still some additional work to be done on the page, but in that case the storage servers will enumerate the page again).
  • the management storage server determines which layer will be the source layer and which layer will be the destination layer. The management storage server then reads one copy from the source layer. The management storage server writes that data to all copies of the destination layer. The management storage server then marks all the copies on the destination layer clean by setting their synchronization bits. Finally, the management storage server requests that all copies on the source layer be deleted. At this point, the management storage server is done migrating the page.
  • a storage server will generate an error indicating that the management storage server is using a value for the data storage configuration identifier that is out-of-date. If this happens, the management storage server then restarts the process. The management storage server also restarts the process if any communication errors occur during the process or any aspect of the configuration map for the volume changes.
  • the driver 29 implements a process to read a portion of a page of data for a volume. This process is only initiated after the driver has received a copy of the current configuration map and a value for the data storage configuration identifier from a management storage server for the volume that the driver is accessing.
  • the driver starts at the top-most layer and picks one copy of the page in that layer to read from.
  • the driver may pick the copy to read in any way; including randomly or according to a performance load metric (trying to pick the least loaded storage server). If the data exists in that layer, then the driver returns the data it read to the operating system. Otherwise, the driver advances layer by layer, attempting to read the page's data in each layer.
  • the driver gets to the last layer without locating any valid copies, then the driver returns data to the operating system as though the data were there but were all zeroes ("0"). If any copy is found to be potentially unsynchronized because of the status of the synchronization bits, then the driver will resynchronize that data by reading an "authoritative copy", writing to all other copies in the layer, setting the synchronization bits to all-ones ("1") and then restarting the process. If at any time, a storage server indicates in a reply to a request that the configuration value for the data storage configuration identifier the driver used is old, then the driver requests a new configuration map from a management storage server and restarts the process. The process also restarts if the management storage server sends the driver a new configuration map, if the driver encounters a page that was marked as having previously existed but has since been deleted, or if there are any communication errors.
  • the driver 29 implements a process to write data to a portion of a page in a volume. This process is only initiated after the driver has received its first configuration map and data storage configuration identifier from a management storage server.
  • the process begins by writing the data to all copies of the page in the top-most or most recent layer. If all writes succeed, then the driver returns the successful completion to the operating system. If any copy is not present in the top-most layer, then the driver proceeds to scan down the layers looking for the uppermost copy of the data in all the layers. If the data is not synchronized, the driver resynchronizes the data (using the same steps as in the read process above). If the page is not present in any layers, then zeroes are written to all copies of the top-most layer, the synchronization bits in all copies are set, and the process restarts. Otherwise, one copy of the data in the uppermost layer is selected, the driver reads the entire page, writes the driver to all copies in the top-most layer, sets the synchronization bits in the top-most layer, and then restarts this process.
  • a storage server replies that the driver's configuration ID is old, then the client driver requests a new configuration map and data storage configuration identifier from a management storage server and restarts the process.
  • the process also restarts if the management storage server sends the driver a new configuration map, if the driver encounters a page that was marked as having previously existed but has since been deleted, or if there are any communication errors.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Human Computer Interaction (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Software Systems (AREA)
  • Mathematical Physics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

Abstract of the Disclosure
The present invention is directed to a data storage system for use in achieving distributed data storage over a computer network. One embodiment of the data storage system comprises a storage server system that is comprised of one or more storage servers that each provide data storage, a management server system that is comprised of one or more management servers that each provide management functionality relating to the storage server system, and a driver that is capable of being associated each of the application clients that are to utilize the data storage system. A data storage configuration identifier structure whose value is updated when there is a change to the composition of the storage system or storage allocation within the storage system is used to manage data transfers between the storage system and application clients.

Description

    Detailed Description of the Invention CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of United States Patent Application No. 10/063,992, entitled "DISTRIBUTED NETWORK STORAGE SYSTEM WITH VIRTUALIZATION", filed on May 31, 2002.
  • FIELD OF THE INVENTION
  • The present invention relates to data storage and, in particular, to the distribution of data storage over a computer network.
  • BACKGROUND OF THE INVENTION
  • A conventional networked computer system is comprised of a number of computers that each have an operating system, a network for communicating data between the computers, and at least one data storage device that is attached to at least one of the computers but not directly attached to the network. In such a system, the transfer of data between the data storage device and a computer in the system other than the computer with which the device is associated requires that the operating system of the computer with which the data storage device is associated to devote a certain amount of time to the processing of the data transfer. Because the operating system of the computer is typically servicing requests from various applications (e.g., a word processing application) executing on the computer, the operating system typically is only able to devote a limited amount of time to the processing of the data transfer.
  • While data transfer rates over networks were relatively slow, the operating systems were typically able to service data transfer requests quickly enough to utilize any available time on the network for data transfers between computers in the system. In other words, the networks, due to their relatively low transfer rates, were the bottleneck in transferring data between a data storage device associated with one computer in the system and other computers in the system. However, as the data transfer rates for network improved, the operating system became the bottleneck because the operating system was typically servicing requests from various applications when the network was available for data transfers to or from the data storage device.
  • To avoid the operating system bottleneck, data storage devices were developed that directly attached to a network, i.e., network data storage devices. Due to this direct attachment, any computer in a networked computer system is able to directly communicate with the network storage device.
  • A further advent has been the development of distributed network data storage in which two or more network data storage devices are utilized and a mechanism exists for defining a logical volume, i.e., a unit of data storage that physically extends over the two or more data storage devices. Consequently, to computers in a networked computer system, the logical volume appears to be a single storage device. An example of a network computer system that employs distributed network storage is comprised of: (a) two fibre channel disk drives; (b) a computer; and (c) a network for facilitating data transfers between the drives and the computer. The computer comprises a driver (a program that allows an operating system to communicate with a device) for each of the drives and a logical volume manager that controls the drivers so as to define a logical or virtual volume that extends over the two fibre channel disk drives.
  • SUMMARY OF THE INVENTION
  • The present invention is directed to a system for use in achieving distributed network data storage in a network and that provides the flexibility to achieve additional functionality, such as the ability to scale the data storage, stripe data, replicate data, migrate data, snapshot data, and provide shared access.
  • In one embodiment, the system is comprised of a storage server system that is, in turn, comprised of one or more data storage servers which provide data storage and data transfer capability for application clients in a networked computer system. An application client is a computer in a networked computer system that is or will execute a particular application program (e.g., a data base management program) that requires or will likely require data storage and transfer capability. A data storage server is comprised of a data storage device (e.g., a disk drive) and a network interface for communicating, via a network, with an application client and a management storage server.
  • The system is further comprised of a management storage server system that is, in turn, comprised of one or more management storage servers which each provide certain storage management functionality relative to any application clients and the storage server system. A management data storage server is comprised of a network interface for communicating, via a network, with an application client and the storage servers in the storage system. A management data storage server is further comprised of a data storage device (e.g., a disk drive or tape drive).
  • Each of the management storage servers comprises a data storage configuration identifier that is used to coordinate the operation of the storage servers. The value of the identifier is indicative of an allocation of data storage within the storage server system at a particular point in time. In one embodiment, the value is a time stamp. Other types of values are feasible. The allocation of data storage within the storage server system comprises defining any number virtual or logical volumes that are each distributed over one or more of the storage servers. Each of the management storage servers is capable of providing a first value for the identifier to an application client. For example, a management storage server provides a first value for the identifier to an application client as part of the allocation of data storage to the application client. Further, each of the management storage servers is capable of providing an updated value for the identifier to each of the storage servers after there is a change in allocation of data storage within the storage server system.
  • The storage servers use the identifier in deciding whether or not to carry out a data related request from an application client. To elaborate, a data related request that a storage server receives from an application client comprises the most recent value of the data storage configuration identifier in the application client's possession. The storage server compares the most recent value of the identifier in its possession to the value of the identifier associated with the received request. If the values are the same, both the application client and the storage server understand the data storage allocation to be the same. In this case, the storage server proceeds with the processing of the data related request. If, however, the value of the identifier in the storage servers possession and the value of the identifier associated with the request are different, the application client and the storage server understand the data allocation to be different. Stated differently, the application client is operating based upon an out of date data storage allocation. In this case, the storage server does not proceed with the processing of the request because to do so might corrupt data. In one embodiment, the storage server causes an error to be generated that is provided, via the network, to a management storage server. In response, the management storage server provides the application client with an updated identifier that the application client is then capable of utilizing to retry the data related requested, if desired.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • Fig. 1 is a block diagram of a networked computer system that employs an embodiment of the distributed storage system of the present invention;
  • Fig. 2 is a block diagram of a networked computer system in which the application client is a parallel database server and in which an embodiment of the distributed storage system of the present invention is employed;
  • Fig. 3A illustrates the use of bit masks in verify that a page of data on one storage server is synchronized with a copy of a page of data on another storage server when data is being replicated;
  • Fig. 3B illustrates the use of bit masks to indicate that a page of data on one storage server is desynchronized with a copy of a page of data on another storage server when data is being replicated;
  • Figs. 4A-4C illustrate an example of the use of a layering mechanism to migrate data from pages on one volume to pages on another volume;
  • Figs. 5A-5C illustrate an example of the use of a layering mechanism to implement a snapshot operation;
  • Fig. 6 illustrates an embodiment of a process implemented by the management storage server to manage the storage server system;
  • Fig. 7A illustrates an embodiment of a process implemented by the driver associated with an application client to perform a read operation; and
  • Fig. 7B illustrates an embodiment of a process implemented by the driver associated with an application client to perform a write operation.
  • DETAILED DESCRIPTION
  • Figure 1 illustrates an embodiment of a networked computer system 10 that employs an embodiment of a distributed storage system 12, hereinafter system 12. The networked computer system 10 comprises: (a) an application client system 14 that comprises one or more application clients 16 (i.e., a computer that is or will run an application program); (b) the system 12; and (c) a network 18 for conveying communications between the application clients 16 and the system 12, and between elements of the system 12. In the illustrated embodiment, the network 18 is a Gigabit Ethernet network. However, the invention is applicable or adaptable to other types of networks.
  • With continuing reference to Fig. 1, the system 12 is comprised of a storage system 20 that provides data storage capability to an application program executing on an application client. The storage system 20 comprises one or more storage servers 22. Each storage server 22 comprises at least one data storage device and at least one interface for communicating with the network 18. In one embodiment, the data storage device is a disk drive. However, other types of data storage devices are feasible. For example, tape drives are feasible. Typically, when the storage server 22 is comprised of multiple data storage devices, the devices are all of the same type (e.g., disk drives). It is, however, feasible to use different types of data storage devices. (e.g., disk drives and tape drives, different types of disk drives, different types of tape drives or combinations thereof).
  • With continuing reference to Fig. 1, the system 12 is further comprised of a management storage server system 24 that provides management functions relating to data transfers between the application clients and the storage system 20. The management storage server system 24 comprises one or more management storage servers 26. Generally, it is desirable to have multiple management storage servers 26 for fault tolerance. Each management storage server 26 comprises at least one interface for communicating with the network 18 and at least one data storage device (e.g., disk drive or tape drive). In addition, at least one of the management storage servers 26 comprises an interface 28 that allows a user to interact with the server 26 to implement certain functionality relating to data transfers between an application client 16 and the storage system 20. In the illustrated embodiment, the interface 28 is a graphical user interface (GUI) that allows a user to interact with the server 26 via a conventional monitor and keyboard or mouse. Other types of interfaces that communicate with other types of peripherals (e.g., printers, light pens, voice recognition etc.) or network protocols are feasible. It should also be appreciated that a management storage server co-located with a storage server and/or driver.
  • With continuing reference to Fig. 1, the system 12 further comprises a driver 29 that is associated with each application client 16 and facilitates communications between the application client 16 and the system 12. It should be appreciated that there are alternatives to the use of driver 29. For example, a Peripheral Component Interconnect (PCI) card or Host Bus Adapter (HBA)card can be utilized.
  • Each of the management storage servers 26 comprises a data storage configuration identifier that relates to a storage configuration map which reflects the composition of the storage system 20 and the allocation of data storage across the storage system 20 to the various application clients 16 at a point in time. The data storage configuration identifier has a value that changes when the composition of the storage system 20 changes or the allocation of storage within the system 20 changes. In one embodiment, the value of the identifier is a logical time stamp that monotonically increases as changes occur. Other types of logical time stamps are possible. For example, logical time stamps with values that decrease are possible, as well as logical time stamps whose values change in a predictable manner. Further, time stamps other than logical time stamps are feasible. For example, a time stamp that reflects actual time is also feasible.
  • The storage configuration map identifies each of the storage servers 22 in the storage system 20. In addition, the map identifies each logical or virtual volume, i.e., an amount of data storage that is distributed between two of more the storage servers 22 that is allocated to a particular application client 16. Further, the map identifies the partitioning of each logical or virtual volume, i.e., how much data storage of the volume is provided by each of the storage servers 22.
  • When a management storage server 26 allocates data storage within the storage system 20 to an application client 16, the server 26 provides an updated value for the data storage configuration identifier to the relevant application client 16 and, more particularly, to the driver 29 within the application client 16. The identifier is attached to all requests for data transfers from the storage system 20 by the application client. The management storage server 26 also provides each of the storage servers 22 with the updated value of the identifier. The management storage server 26 may not, however, be able to provide the updated value to other application clients. Consequently, the other application clients may have outdated values for the identifier that reflect an outdated configuration.
  • The value of the identifier is used by each of the storage servers 22 that receives a request for a data transfer from an application client to prevent corruption of the data. To elaborate, each of the storage servers 22 comprises a comparator that compares the value for the identifier that has been most recently received from the a management storage server 26 to the value of the identifier appended to the data transfer request from an application client. If the values are not equal, then there has been a change in the composition of the storage system 20 or the allocation of storage within the storage server system 20. In this case, since corruption of data could occur or incorrect data could be provided to the application client if the transfer was carried out, the storage server 22 at least ignores the request. In one embodiment, the storage server 22 returns an error message to the relevant application client or a management storage server 26 that is processed so as to provide the relevant application client with an updated value for the identifier. Once the relevant application client has the current value for the identifier, the application client may be able to reinitiate the request for a data transfer or know that it needs to get the new configuration.
  • If the comparator determines that the value for the identifier that is appended to the request is equal to the value for the identifier that was most recently provided to the storage server by a management storage server, there has been no change in the composition of the storage system 20 or the allocation of storage within the system 20. In this case, the storage server 22 processes the data transfer requested by the relevant application client.
  • Scaling. The system 12 is capable of readily being scaled to increase or decrease the number of storage servers 22 in the storage system 20. To elaborate, a user is able to use the interface 28 associated with at least one of the management storage servers 26 to propose a modification to the configuration map that involves either the addition of a storage server to the storage system 20 or the subtraction of a storage server 22 from the system 20. If there are other management storage servers 26 in the management storage server system 24, the proposed modification to the configuration is provided to each of the servers 26. Each of the servers 26 is capable of evaluating the impact of the proposed modification and providing a "vote" indicating approval or disapproval of the modification. A management storage server might provide a disapproving vote if the proposed modification would adversely affect the ability to implement certain storage functions. For example, if a management storage server has caused data from an application client to be replicated over two storage servers with a copy on each server, the subtraction of one of the storage servers without the addition of another storage server is likely to be unacceptable. If the proposed change is approved by the management storage servers 26 in the management storage server system 24, the configuration map is changed, any re-allocation of storage within the storage system 20 that is required by the change is implemented, any copying of data within the storage system 20 undertaken, and an updated value for the data storage configuration identifier is issued to each of the storage servers.
  • Striping. The system 12 is capable of implementing striping, i.e., the partitioning of a logical or virtual volume across two or more storage servers 22. To elaborate, a user is able to use the interface 28 associated with at least one of the management storage servers 26 to propose: (a) a logical or virtual volume within the storage system 20 for an application client; and (b) the partitioning of such a volume between two or more of the storage servers 22 in the storage system 20. The proposed logical volume and proposed partitioning of the volume is provided to each of the management storage servers 26 for assessing the impact thereof and providing an approving or disapproving vote. If the proposed logical volume and partitioning thereof is approved by the management storage servers 26 in the management storage server system 24, the configuration map is changed, any re-allocation of storage within the storage system 20 that is required by the change is implemented, any copying of data within the storage system 20 undertaken, and an updated value for the data storage configuration identifier is issued to each of the storage servers.
  • Shared Access. With reference to Fig. 2, an embodiment of a networked computer system 10' that comprises the distributed storage system 12 and implements shared access is described. The networked computer system 10' further comprises a particular application client system, namely, a parallel database server system 14', such as an ORACLE parallel database server system. The parallel database server system 14' is comprised of two or more parallel database servers 16' that cooperatively operate with one another in the management of a database that is or will be stored in a volume on the storage system 20. The parallel database server system 14' is further comprised of a distributed lock manager system 30 that is, in turn, comprised of one or more distributed lock managers 32 that each operate to issue "locks" to the parallel database servers 16'. A lock relates to a distinct portion of the database that is or will be stored on the volume allocated to the parallel database server system on the storage system 20. The issuance of a lock to one of the parallel database servers 16' provides exclusive write access or shared read access to the portion of the distinct portion of database to which the lock relates relative to the other parallel database servers. By providing exclusive write access to only one of the parallel database servers 16', the situation in which two of the servers are concurrently updating the same portion of the database is prevented.
  • It should be appreciated that, while the distributed lock managers 30 are illustrated as being separate from the parallel database servers 16', the distributed lock managers 30 are implemented, in one embodiment, such that each of the distributed lock managers 30 is associated with one of the parallel database servers 16'. In such an embodiment, each of the distributed lock managers 30 has access to the driver 29 (via a generic interface associated with the parallel database management program) that facilitates communication with the distributed storage system 12. Other implementations of the distributed lock managers 30 are feasible, provided each of the lock managers has the ability to communicate with at least one of the management storage servers 26.
  • Each of the distributed lock managers 30 operates so as to monitor the parallel database server to which a lock has been issued to determine if the lock can be returned so that the lock can be issued to another one of the parallel database servers 16'. In certain situations, a distributed lock manager 30 operates to revoke a lock issued to a first of the parallel database servers 16. For example, if a distributed lock manager 30 determines that the communication link with the first parallel database server to which a lock has been issued is no longer active or available or that the first parallel database server has failed, the distributed lock manager 30 revokes the lock issued to the first parallel database server. In such a situation, the distributed lock manager 30 can reissue the lock to a second parallel database servers.
  • A problem with the lock being issued to the second parallel database server is that the first parallel database server, while in possession of the lock, may have initiated a write request to the volume on the storage system 20 that has not been processed by the storage system 20 by the time the lock has been revoked and issued to the second parallel database server. This situation occurs if, for example, the write request is still traversing the network during the period of time when the lock is being revoked and reissued to the second parallel database server. In this case, the possibility exists that the first and second parallel database servers could concurrently be updating the same portion of the volume of the database, a situation that is undesirable.
  • To address this problem, one of the distributed lock managers 32 communicates, via its driver 29, with one of the management storage servers 26 that a lock is being revoked. In response, the management storage server updates a "lock" map. Updating of the "lock" map causes the value of the data storage configuration identifier to be updated. After the value of the identifier has been updated, the management storage server provides the updated value for the data storage configuration identifier to each of the storage servers 22 in the storage system 20. Subsequently, the management storage server issues a communication to the distributed lock manager that authorizes the lock manager to reissue the lock.
  • Providing an updated value for the data storage configuration identifier to the storage server 22 prevents the write request that was initiated by the first parallel database server from being processed the storage server. To elaborate, associated with the write request is a particular value for the data storage configuration identifier that was previously provided to the parallel database server by one of the management storage servers 26. However, due to the updating of the data storage configuration identifier, the storage servers 22 have an updated value for the data storage configuration identifier that is different from the value for the identifier associated with the write request. Consequently, if one of the storage server 22 receives the write update, the comparator in the storage server detects the difference in the values of the data storage configuration identifiers and, due to the difference, at least ignores the request for the write update.
  • Replication. A user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause data from an application client to be replicated on the volume of the storage system 20 dedicated to the application client such that one copy of the data resides on one of the storage servers 22 and one or more other copies of the data each reside on one of the other storage servers 22. This redundancy provides fault tolerance. The user indicates that data is to be replicated by appropriately modifying the configuration map via the interface 28. Updating the configuration map causes the value of the data storage configuration identifier to be updated. The updated value for the data storage configuration identifier is provided to each of the storage servers 22 and the driver 29 of the application client to which the replication is relevant. The driver 29 is also provided with configuration map or other information that defines the replication that is to be applied to the application client data, e.g., the relevant volume and the storage servers on which the copies of the data are to reside.
  • A problem with replicating data is that the copies of the data can become de-synchronized, i.e., the copies are no longer identical to one another. For example, copies of data become de-synchronized when a first copy of the data is updated on one of the storage servers 22 but one of the other storage servers 22 that is to have a second copy of the data fails before the update occurs on the server.
  • This problem is addressed using a bit mask device (also referred to as synchronization bits) in the storage servers on which data is to be replicated that is, on occasion, interrogated by a management storage server and used by the management storage server to determine if copies have become de-synchronized and take remedial action. With reference to Fig. 3A, the operation of the bit mask device is illustrated for the situation in which copies of a page of data are to be replicated on server "0" and server "1". A page of data is a unit of allocation for the storage system 20, typically on the order of a megabyte in size, but other sizes are feasible. Associated with server "0" is a two bit, bit mask 40 with the first bit of the mask relating to server "0" and the second bit relating to server "1". Associated with server "1" is a two bit, bit mask 42 with a first bit of the mask relating to server "0" and the second bit relating to server "1". When the copies of a page of data on both of the servers are synchronized, the value of each of the bits in both bit masks is a logical "1", which is also referred to as a "clean" condition. Whenever the value of each of the bits in both bit maps is not "1", then the possibility exists that the copies are de-synchronized. A copy of a page of data is always deemed to be synchronized with itself. Consequently, bit "S0" of the mask 40 is always set to a logical 1 and bit "S1" of the mask 42 is always set to a logical 1.
  • When the driver 29 associated with the application client whose data is to be replicated issues a write request to server "0", the write request includes clearing bit mask values and restoring bit mask values. The clearing bit mask values are the values to which the bits of the bit mask 40 are to be set prior to the processing of the write request by server "0". The restoring bit mask values are the values to which the bits of the bit mask 40 are to be set after it is confirmed that the write request was processed. The clearing bit mask values are used to update bit mask 40 prior to processing the write request for server "0". Once the write request for server "0" has been processed by server "0", the server issues an acknowledgment with a token to the client application.
  • Similarly, the write request issued by the driver 29 to server "1" includes clearing bit mask values and restoring bit mask values. The clearing bit mask values are used to update bit mask 42 prior to processing the write request for server "1". Once the write request for server "1" has been processed by server "1", the server issues an acknowledgment with the token to the client application.
  • Once the driver 29 receives acknowledgments from both server "0" and server "1", the driver 29 includes the token in the next commands issued to each of the storage servers on which data is being replicated. Typically, the next commands are write requests issued to both server "0" and server "1" to replicate data. The storage server "0" responds to its command by changing the value of the bits in the bit mask 40 to the restoring values, i.e., "11". The storage server "1" respond to its command by changing the value of the bits in bit mask 42 to the restoring values, i.e., "11". At this point, the value of each of the bits in each of the bit masks 40, 42 is the same, namely, logical "1". Consequently, the copies of the page of data on server "0" and server "1" are synchronized, i.e., identical to one another.
  • With reference to Fig. 3B, a situation in which the bit masks 40, 42 are used to identify a situation in which the two copies of the page of data have become de-synchronized is described. The reason for the de-synchronization is that server "1" has been deemed to have failed (i.e., become unable to process requests or commands) prior to a write request from the client application being issued. As a consequence, when the application attempts to replicate the page of data on servers "0" and "1" only the data on server "0" is updated. Consequently, when server "1" is brought back on line, the copy of the page of data on server "1" will be "old" relative to the copy of the page of data on server "0".
  • With continuing reference to Fig. 3B, the copies of the page of data on servers "0" and "1" are initially assumed to be in synchronization. As a consequence, the value of each of the bits in bit masks 40, 42 is the same, namely, a logical "1". Prior to write requests being issued to servers "0" and "1" to implement a replication operation, one of the management storage servers 26 deems server "1" to have failed. At least one of the management storage servers 26 issues a request to at least one of the storage servers 22 on occasion to determine if the storage server is operational. If the server is operational, the storage server will cause some form of reply or acknowledgment to be sent to the management storage server that issued the request within a predetermined amount of time. If a reply or acknowledgment is not received within the predetermined amount of time, the management storage server assumes that the storage server has failed. In such a situation, the management storage server updates the configuration map, updates the value of the data storage configuration map identifier, and provides the map and identifier to the application client, as well as the storage servers 22. Since the application client is aware that server "1" has failed, no write request is issued to storage server "1". The write request issued to server "0" includes clearing bit values and restoring bit values. However, due to the change in the storage system 20 caused by the failure of server "1" and reflected in the change in the data storage configuration identifier, the restoring bit values are, unlike in Fig. 3A, set to "10".
  • Server "0", after receiving the write request but before processing the write requests, sets the values of the bits in bit mask 40 to the clearing bit values, namely, logical "10". The server then processes the write request and sends an acknowledgment to the application client that includes a token. The next command received by server "0" from the application includes the token. In response, server "0" modifies the bits of the bit mask 40 to the restoring values specified in the restoring bit values that accompanied the write request, namely, logical "10". At this point, since the value of each of the bits in bit masks 40, 42 is incapable of being the same value (since bit mask 40 is set to "10") the bit masks reflect a de-synchronization state. At least one of the management storage servers 26 is monitoring the bit masks and detects the indication of the copies of the page of data being de-synchronized. After the management storage server detects this condition, the management storage server typically causes remedial action to be taken. In this case, the management storage server cause the copy of the page of data on server "0" to be written to server "1", thereby bringing the copies of the data back into synchronization. It should be appreciated that the bit masks are capable of being used to detect de-synchronization that is attributable to other causes.
  • The bit mask device described with respect to Figs. 3A and 3B is capable of being extended to accommodate a greater number of copies. Further, it should be appreciated that opposite bit values from those described with respect to Figs. 3A and 3B can be utilized.
  • Migration. A user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause data on one logical volume to be migrated to another logical volume. This is accomplished using a "translucent" layering mechanism. To elaborate, after the user initiates or defines the migration of data that is to occur, the management storage server saves the portion of the data storage configuration map that relates to the volume whose data that is to be migrated (the old volume), identifies this portion of the map as a layer, and orders this layer as a first or old layer. The data storage configuration map is then updated to reflect the new data storage configuration and, in particular, to identify the logical volume to which the data is migrated (the new volume). This causes the value of the data storage configuration identifier to be updated. The new map and value for the identifier are distributed to the storage servers 22 and to the driver 29 in the relevant application client. In addition, the portion of the configuration map that relates to the new volume to which the data is to be migrated is identified as a layer and this layer is ordered as a second or new layer.
  • After the layering is defined and ordered, data is migrated from the old volume to the new volume by two possible mechanisms. First, at least one of the management storage servers 26 actively monitors each of the pages in the first or old layer to determine if the data associated with each of the pages in the old volume has not been migrated to the new volume. If a page is found whose data has not been migrated to the new volume, the management storage server causes the data from the page on the old volume to be read, the data to then be written to the new volume, and the page in the old volume to be marked as "deleted". The second mechanism for migrating data from the old volume to the new volume occurs when an application client endeavors to write to a page on the new volume. In this situation, the driver 29 interrogates the new layer before issuing the write request relating to the page to determine if the page in the new layer has received the data from the corresponding page in the old volume. If not, the driver 29 is able to "see through" the "transparent" portion of the new layer that relates to the page to which data is to be written to the old layer and "see" that the data has not yet been migrated from the old volume for the corresponding page. In this case, driver 29 causes the data from the page on the old volume to be read, the data to then be written to the new volume, and the page in the old volume to be marked as "deleted". Further, after data from the page on the old volume has been migrated to the new volume, the driver 29 issues the write request that then causes data to be written to the page on the new volume.
  • By marking each page of the old volume as deleted after the data from the page has been migrated, a mechanism is provided for preventing a situation that could adversely affect the migration. To elaborate, it is possible for two client applications to be attempting to write to a page in the new volume during the same period of time and when data for the page has not yet been migrated from the old volume. In this situation, the driver 29 associated with each application client endeavors to cause the migration of data from the page on the old volume to the corresponding page on the new volume. The driver 29 associated with one of the application clients will be successful in causing the data for the page to be migrated and may then cause the data on the page on the new volume to be updated via a write request. The driver 29 associated with the other application client, without the noted marking, would not be aware that the data for the page has been migrated and endeavor to migrate the data to the corresponding page on the new volume. If this were to happen, the data migrated by the other application client could overwrite the new data established in the page by the write request issued by the application client that initially caused the data to be migrated. To avoid this possibility, the driver 29 checks the relevant page in the old layer to determine if the data for the page has already been migrated, before taking any action to migrate the data. If the data for the page has been migrated, then the driver 29 aborts the current write request and retries the write request.
  • After the data from each page of the old volume has been migrated to the new volume, the old layer is deleted.
  • With reference to Figs. 4A-4C, an example of migration is described. Figure 4A illustrates an old volume comprised of six pages (0-5)and with data (A-F) in each of the pages and a new volume before the migration of any data from the old volume to the new volume. To effect the migration, the old volume is further identified as a layer and ordered as the first or old layer. Because data is present in each of the pages of the old volume at this point, there is no "transparency" associated with the old layer. The new volume is also identified as a layer and ordered as the second or new layer. Because no data is present in any of the pages of the new volume at this point, there is "transparency" associated with each page in the new layer. This "transparency" allows the driver associated with an application client to "see" that the data for the page is present in the first or old layer.
  • Figure 4B illustrates the old volume and the new volume after the data (B) in page "1" of the old volume has been migrated to page "1" in the new volume. At this point, there is no longer any "transparency" associated with page "1" of the new layer, which indicates that the data from page "1" in the old volume has been migrated to page "1" in the new volume. There is still "transparency" associated with the other pages of the new layer, which means that the data from the corresponding pages in the old layer has not yet been migrated. It should also be noted that page "1" in the old layer, due to the migration, is now marked as deleted, which is represented by an "X".
  • Figure 4C illustrates the old volume and the new volume after the data for each page of the old volume has been migrated to the corresponding page in the new volume. At this point, there is no longer any "transparency" associated with the new layer, which indicates that data from all of the pages in the old volume has been migrated to the new volume. Further, each of the pages in the old layer, due to the completed migration, is now marked as deleted. As a consequence, the old layer is no longer required and can be deleted.
  • It should be appreciated that the translucent layering mechanism is capable of being extended to multiple migrations that would require additional layers.
  • Snapshot. A snapshot preserves the state of a volume at a particular point in time while also causing the data in the pages of the preserved volume, the snapshot volume, to be migrated to a new volume where the pages can be updated by one of more of the application clients. To preserve the state of the snapshot volume, the new volume cannot overlap with the snapshot volume.
  • A user is able to use the interface 28 associated with at least one of the management storage servers 26 to cause a snapshot. Once a snapshot has been initiated, the management storage server 26 establishes the same translucent layering mechanism described with respect to the migration process to facilitate migration of the data from the snapshot volume to the new volume. Migration is achieved by the migration of data in a page as a prelude to the issuance of a write request from the driver 29 associated with an application. However, in contrast to the migration process, after data for a page is migrated from the snapshot volume to the new volume, the page on the snapshot volume is not marked as deleted. Consequently, the data in the pages of the snapshot volume are preserved.
  • With reference to Figs. 5A-5C, an example of snapshot is described. Figure 5A illustrates a snapshot volume comprised of six pages (0-5) and with data (A-F) in each of the pages and a new volume before the migration of any data from the snapshot volume to the new volume. To effect the migration, the snapshot volume is further identified as a layer and ordered as the first or old layer. Because data is present in each of the pages of the snapshot volume at this point, there is no "transparency" associated with the old layer. The new volume is also identified as a layer and ordered as the second or new layer. Because no data is present in any of the pages of the new volume at this point, there is "transparency" associated with each page in the new layer. This "transparency" allows the driver associated with an application client to "see" that the data for the page is present in the first or old layer.
  • Figure 5B illustrates the snapshot volume and the new volume after the data (B) in page "1" of the snapshot volume has been migrated to page "1" in the new volume. At this point, there is no longer any "transparency" associated with page "1" of the new layer, which indicates that the data from page "1" in the snapshot volume has been migrated to page "1" in the new volume. There is still "transparency" associated with the other pages of the new layer, which means that the data from the corresponding pages in the snapshot layer has not yet been migrated. It should also be noted that the data that was in page "1" in the snapshot volume before the migration is still in page "1" of the snapshot volume and cannot be altered. The data that has been migrated to page "1" of the new volume is, however, susceptible to modification.
  • Figure 5C illustrates the snapshot volume and the new volume after the data for each page of the snapshot volume has been migrated to the corresponding page in the new volume. At this point, there is no longer any "transparency" associated with the new layer, which indicates that data from all of the pages in the old volume has been migrated to the new volume. Further, it should be noted that the data in each of the pages of the snapshot volume before the migration operation is still present and in the same location after completion of the migration. Hence, the snapshot has preserved the state of the initial volume at a particular point in time. The data in each of the pages of the snapshot volume has also been migrated to the new volume and the pages of the new volume are susceptible to modification as a result of the processing of write requests issued by an application client.
  • Management Storage Server Process. With reference to Figure 6, the management storage servers each carry out a process that has two primary tasks: resynchronization of data after a storage server failure or restart, and the migration of a volume of data. The process has two phases. The first phase involves locating the volumes and pages within the volumes that need to be either resynchronized or migrated. The management storage server begins by examining its set of configuration maps for the volumes currently being managed. From this, the server determines which volumes may require some work because the volume is in the process of being migrated to a different set of storage servers or because at least one of the storage servers storing data for the volume had failed and then restarted but had not yet been fully resynchronized. After determining the set of volumes requiring work, the management storage server then picks one of them, either randomly or according to some priority. The management storage server then requests that each of the storage servers enumerate up to some fixed number of pages that match the migration or resynchronization criteria. The pages are accumulated by the management storage server with duplicates being discarded. The management then proceeds through the pages, either one-by-one or potentially several in parallel, for the second phase of the process.
  • For each page, the management storage server first requests the status of all copies of the page in all the layers associated with the volume from the associated storage servers. If any of the copies of the page in any of the layers has synchronization bits that indicate the different copies could contain different data, then these layers of the page are selected to be resynchronized. They are resynchronized as follows. The management storage server picks a copy of the page on one server which is referred to as the "authoritative copy" and reads the contents of that copy. The management storage servers must pick the authoritative copy in such a way that they all pick the same copy as authoritative. One way to do this is to base the selection on information in the configuration map, but other methods are feasible. After reading the authoritative copy, the management storage server then writes the contents of the page to the other copies of the page in that layer. The management storage server then marks all copies of the page as being clean by setting their synchronization bits. The management storage server is now done with the page for the time being (it is possible there is still some additional work to be done on the page, but in that case the storage servers will enumerate the page again).
  • If no copies of a page need to be resynchronized but there is a copy that needs to be migrated, then the management storage server follows these steps. First, the management storage server determines which layer will be the source layer and which layer will be the destination layer. The management storage server then reads one copy from the source layer. The management storage server writes that data to all copies of the destination layer. The management storage server then marks all the copies on the destination layer clean by setting their synchronization bits. Finally, the management storage server requests that all copies on the source layer be deleted. At this point, the management storage server is done migrating the page.
  • Throughout each step of this process, it is possible that a storage server will generate an error indicating that the management storage server is using a value for the data storage configuration identifier that is out-of-date. If this happens, the management storage server then restarts the process. The management storage server also restarts the process if any communication errors occur during the process or any aspect of the configuration map for the volume changes.
  • Client Driver Read Process. With reference to Figure 7A, the driver 29 implements a process to read a portion of a page of data for a volume. This process is only initiated after the driver has received a copy of the current configuration map and a value for the data storage configuration identifier from a management storage server for the volume that the driver is accessing. The driver starts at the top-most layer and picks one copy of the page in that layer to read from. The driver may pick the copy to read in any way; including randomly or according to a performance load metric (trying to pick the least loaded storage server). If the data exists in that layer, then the driver returns the data it read to the operating system. Otherwise, the driver advances layer by layer, attempting to read the page's data in each layer. If the driver gets to the last layer without locating any valid copies, then the driver returns data to the operating system as though the data were there but were all zeroes ("0"). If any copy is found to be potentially unsynchronized because of the status of the synchronization bits, then the driver will resynchronize that data by reading an "authoritative copy", writing to all other copies in the layer, setting the synchronization bits to all-ones ("1") and then restarting the process. If at any time, a storage server indicates in a reply to a request that the configuration value for the data storage configuration identifier the driver used is old, then the driver requests a new configuration map from a management storage server and restarts the process. The process also restarts if the management storage server sends the driver a new configuration map, if the driver encounters a page that was marked as having previously existed but has since been deleted, or if there are any communication errors.
  • Driver Write Process. With reference to Figure 7B, the driver 29 implements a process to write data to a portion of a page in a volume. This process is only initiated after the driver has received its first configuration map and data storage configuration identifier from a management storage server.
  • The process begins by writing the data to all copies of the page in the top-most or most recent layer. If all writes succeed, then the driver returns the successful completion to the operating system. If any copy is not present in the top-most layer, then the driver proceeds to scan down the layers looking for the uppermost copy of the data in all the layers. If the data is not synchronized, the driver resynchronizes the data (using the same steps as in the read process above). If the page is not present in any layers, then zeroes are written to all copies of the top-most layer, the synchronization bits in all copies are set, and the process restarts. Otherwise, one copy of the data in the uppermost layer is selected, the driver reads the entire page, writes the driver to all copies in the top-most layer, sets the synchronization bits in the top-most layer, and then restarts this process.
  • As in the other processes, if on any request a storage server replies that the driver's configuration ID is old, then the client driver requests a new configuration map and data storage configuration identifier from a management storage server and restarts the process. The process also restarts if the management storage server sends the driver a new configuration map, if the driver encounters a page that was marked as having previously existed but has since been deleted, or if there are any communication errors.

Claims (38)

1. (canceled).
2. (canceled).
3. (canceled).
4. (canceled).
5. (canceled).
6. (canceled).
7. (canceled).
8. (canceled).
9. (canceled).
10. (canceled).
11. (canceled).
12. (canceled).
13. (canceled).
14. (canceled).
15. (canceled).
16. (canceled).
17. (canceled).
18. A system for use in achieving distributed data storage over a computer network comprising:
a storage server system comprising one or more storage servers that each comprise a data storage device and a network interface for communicating with one or more application clients that will require data storage and at least one management storage server; and
a management server system comprising one or more management storage servers that each comprise a network interface for communicating with an application client and each of said storage servers;
each of said management servers and each of said data storage servers comprising a data storage configuration identifier whose value is indicative of an allocation of data storage within said storage server system at a point in time, the allocation of data storage within said storage server system comprising one or more virtual volumes of data storage distributed over one or more of said storage servers;
wherein each of said management storage servers is capable of providing a first value for said data storage configuration identifier to an application client and each of said storage servers, and each of said management storage servers is capable of asynchronously providing a second value for said data storage configuration identifier the application client and to each of said storage servers after there is a change in the allocation of data storage within said storage server system; and
wherein each of said storage servers is capable of: (a) comparing a value for said data storage configuration identifier which is associated with a data storage related request received from an application client with said second value for said data storage configuration, and (b) when the values are not equal, providing an indication to a management storage server that the values are not equal.
19. The system, as claimed in claim 18, wherein said management storage server is capable of providing an updated data storage configuration an data storage configuration identifier to said storage server when an indication is provided that the values are not equal.
20. The system, as claimed in claim 18, wherein each of said storage servers is further capable of reporting an error back to the application client when the values are not equal.
21. The system, as claimed in claim 20, wherein each of said storage servers is further capable of receiving an updated allocation of data storage within said data storage server system from a management storage server, evaluating said updated allocation to determine if data integrity within the data storage server will be adversely affected by the updated allocation, and return a vote to said management storage server approving of the allocation change when the data integrity is not adversely affected.
22. The system, as claimed in claim 21, wherein when the updated allocation is approved, each of said storage servers is further capable of determining if data stored at the respective storage servers is required to be moved as a result of the updated allocation and moving the data that is to be moved as a result of the updated allocation.
23. The system, as claimed in claim 18, wherein the allocation of data stored at said storage servers is not synchronized between one or more storage servers for an indeterminate period of time.
24. The system, as claimed in claim 18, further comprising a driver for associating with an operating system of an application client, wherein said driver comprises a configuration map that is capable of identifying one or more of said storage servers containing data to be accessed by the application client.
25. The system, as claimed in claim 24, wherein said allocation of data within said data storage system includes providing data stored at one or more of said storage servers be replicated to one or more other of said storage servers.
26. The system, as claimed in claim 25, wherein said driver is capable of initiating a read process to read data from said storage server system and determining based on said configuration map a source storage server to read said data from.
27. The system, as claimed in claim 26, wherein said data is stored on two or more storage servers and said driver selects said source storage server based on a performance load metric.
28. The system, as claimed in claim 25, wherein at least a first storage server has a failure and said driver is capable of determining other storage servers that are available to service data storage related requests from an application client.
29. The system, as claimed in claim 28, wherein when said failed first storage server recovers from said failure, said first storage server is operable to determine data that needs to be moved to and from said first server in order to recover from said failure.
30. The system, as claimed in claim 25, wherein said storage servers are further operable to perform copying of data between servers asynchronously.
31. The system, as claimed in claim 30, wherein said storage servers are further operable to perform copying from one storage server to multiple other data storage servers.
32. The system, as claimed in claim 25, wherein said storage server system is operable to perform data movement between data storage servers while continuing to receive and respond to data storage related requests received from application clients.
33. The system, as claimed in claim 32, wherein said data movement comprises generating a snapshot of data stored at a first virtual volume stored across at least a first storage server and copying said snapshot to at least a third storage server.
34. The system, as claimed in claim 33, wherein said snapshot is generated by designating data stored at said first storage server as snapshot data, and performing read and write operations to said first virtual volume on a new layer.
35. The system, as claimed in claim 18, wherein a first management server is capable of proposing a change to the number of storage servers in said storage server system, and at least a second management server is capable of evaluating the change and providing a vote indicating approval or disapproval of the change.
36. The system, as claimed in claim 35, wherein when evaluating the change, said second management server determines if the change would adversely affect the ability to implement one or more certain storage functions.
37. The system, as claimed in claim 36, wherein one of the storage functions is replication of data between a storage server and another storage server.
38. The system, as claimed in claim 18, wherein said storage servers are distributed across a network and are operable to provide shared read and write access to other components on the network.
US10/708,867 2002-05-31 2004-03-29 Distributed network storage system with virtualization Expired - Lifetime US7200664B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/708,867 US7200664B2 (en) 2002-05-31 2004-03-29 Distributed network storage system with virtualization

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/063,992 US6732171B2 (en) 2002-05-31 2002-05-31 Distributed network storage system with virtualization
US10/708,867 US7200664B2 (en) 2002-05-31 2004-03-29 Distributed network storage system with virtualization

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/063,992 Continuation US6732171B2 (en) 2002-05-31 2002-05-31 Distributed network storage system with virtualization

Publications (3)

Publication Number Publication Date
US20050010618A1 US20050010618A1 (en) 2005-01-13
US20050144199A2 true US20050144199A2 (en) 2005-06-30
US7200664B2 US7200664B2 (en) 2007-04-03

Family

ID=29581855

Family Applications (2)

Application Number Title Priority Date Filing Date
US10/063,992 Expired - Lifetime US6732171B2 (en) 2002-05-31 2002-05-31 Distributed network storage system with virtualization
US10/708,867 Expired - Lifetime US7200664B2 (en) 2002-05-31 2004-03-29 Distributed network storage system with virtualization

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US10/063,992 Expired - Lifetime US6732171B2 (en) 2002-05-31 2002-05-31 Distributed network storage system with virtualization

Country Status (9)

Country Link
US (2) US6732171B2 (en)
EP (1) EP1512082A4 (en)
JP (1) JP2005528684A (en)
KR (1) KR20050010845A (en)
CN (1) CN100339847C (en)
AU (1) AU2003243347A1 (en)
BR (1) BR0311390A (en)
CA (1) CA2486994A1 (en)
WO (1) WO2003102731A2 (en)

Cited By (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040030755A1 (en) * 2002-08-12 2004-02-12 Koning G. Paul Transparent request routing for a partitioned application service
US20040143637A1 (en) * 2003-01-20 2004-07-22 Koning G. Paul Adaptive storage block data distribution
US20040143648A1 (en) * 2003-01-20 2004-07-22 Koning G. P. Short-cut response for distributed services
US20040153615A1 (en) * 2003-01-21 2004-08-05 Koning G. Paul Distributed snapshot process
US20040215792A1 (en) * 2003-01-21 2004-10-28 Equallogic, Inc. Client load distribution
US20050002391A1 (en) * 2003-05-06 2005-01-06 Seiko Epson Corporation Data transfer control device, electronic instrument, and data transfer control method
US20050055385A1 (en) * 2003-09-06 2005-03-10 Oracle International Corporation Querying past versions of data in a distributed database
US20050262038A1 (en) * 2004-05-18 2005-11-24 Oracle International Corporation Distributing data across multiple storage devices
US20050278359A1 (en) * 2004-06-10 2005-12-15 Oracle International Corporation Providing mappings between logical time values and real time values in a multinode system
US20060029070A1 (en) * 2002-11-12 2006-02-09 Zetera Corporation Protocol adapter for electromagnetic device elements
US20060126666A1 (en) * 2002-11-12 2006-06-15 Charles Frank Low level storage protocols, systems and methods
US20060155946A1 (en) * 2005-01-10 2006-07-13 Minwen Ji Method for taking snapshots of data
US20060272015A1 (en) * 2005-05-26 2006-11-30 Frank Charles W Virtual devices and virtual bus tunnels, modules and methods
US20070083662A1 (en) * 2005-10-06 2007-04-12 Zetera Corporation Resource command messages and methods
US20070106857A1 (en) * 2003-01-21 2007-05-10 Equallogic Inc. Distributed snapshot process
US20070168396A1 (en) * 2005-08-16 2007-07-19 Zetera Corporation Generating storage system commands
US20080177802A1 (en) * 2007-01-23 2008-07-24 International Business Machines Corporation Securely deleting data in a transactionally consistent manner
US20080183894A1 (en) * 2007-01-25 2008-07-31 Oracle International Corporation Synchronizing cluster time
US7543046B1 (en) * 2008-05-30 2009-06-02 International Business Machines Corporation Method for managing cluster node-specific quorum roles
US7649880B2 (en) 2002-11-12 2010-01-19 Mark Adams Systems and methods for deriving storage area commands
US7702850B2 (en) 2005-03-14 2010-04-20 Thomas Earl Ludwig Topology independent storage arrays and methods
US20100103781A1 (en) * 2008-10-24 2010-04-29 Oracle International Corporation Time synchronization in cluster systems
US7870271B2 (en) 2002-11-12 2011-01-11 Charles Frank Disk drive partitioning methods and apparatus
US7904681B1 (en) * 2006-06-30 2011-03-08 Emc Corporation Methods and systems for migrating data with minimal disruption
US7924881B2 (en) 2006-04-10 2011-04-12 Rateze Remote Mgmt. L.L.C. Datagram identifier management
US7937551B2 (en) 2003-01-21 2011-05-03 Dell Products L.P. Storage systems having differentiated storage pools
US8166314B1 (en) 2008-12-30 2012-04-24 Emc Corporation Selective I/O to logical unit when encrypted, but key is not available or when encryption status is unknown
US8261068B1 (en) 2008-09-30 2012-09-04 Emc Corporation Systems and methods for selective encryption of operating system metadata for host-based encryption of data at rest on a logical unit
US20130007292A1 (en) * 2011-07-01 2013-01-03 International Business Machines Corporation Data set connection manager having a plurality of data sets to represent one data set
US8416954B1 (en) 2008-09-30 2013-04-09 Emc Corporation Systems and methods for accessing storage or network based replicas of encrypted volumes with no additional key management
US20140136501A1 (en) * 2005-01-27 2014-05-15 International Business Machines Corporation Database usage trends based on database lock requests
US8819092B2 (en) 2005-08-16 2014-08-26 Rateze Remote Mgmt. L.L.C. Disaggregated resources and access methods
US8930371B1 (en) * 2008-06-30 2015-01-06 Amazon Technologies, Inc. Systems and methods for efficiently storing index data on an electronic device
US8966211B1 (en) * 2011-12-19 2015-02-24 Emc Corporation Techniques for dynamic binding of device identifiers to data storage devices

Families Citing this family (108)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7162600B2 (en) * 2005-03-29 2007-01-09 Hitachi, Ltd. Data copying method and apparatus in a thin provisioned system
US6732171B2 (en) * 2002-05-31 2004-05-04 Lefthand Networks, Inc. Distributed network storage system with virtualization
US20040160975A1 (en) * 2003-01-21 2004-08-19 Charles Frank Multicast communication protocols, systems and methods
US20040210724A1 (en) * 2003-01-21 2004-10-21 Equallogic Inc. Block data migration
US6823442B1 (en) * 2003-05-12 2004-11-23 3Pardata, Inc. Method of managing virtual volumes in a utility storage server system
US7568034B1 (en) * 2003-07-03 2009-07-28 Google Inc. System and method for data distribution
US8136025B1 (en) 2003-07-03 2012-03-13 Google Inc. Assigning document identification tags
US9489150B2 (en) 2003-08-14 2016-11-08 Dell International L.L.C. System and method for transferring data between different raid data storage types for current data and replay data
US7613945B2 (en) * 2003-08-14 2009-11-03 Compellent Technologies Virtual disk drive system and method
US7287133B2 (en) 2004-08-24 2007-10-23 Symantec Operating Corporation Systems and methods for providing a modification history for a location within a data store
US7725760B2 (en) 2003-09-23 2010-05-25 Symantec Operating Corporation Data storage system
US7577806B2 (en) 2003-09-23 2009-08-18 Symantec Operating Corporation Systems and methods for time dependent data storage and recovery
US7827362B2 (en) 2004-08-24 2010-11-02 Symantec Corporation Systems, apparatus, and methods for processing I/O requests
US7904428B2 (en) 2003-09-23 2011-03-08 Symantec Corporation Methods and apparatus for recording write requests directed to a data store
US7991748B2 (en) 2003-09-23 2011-08-02 Symantec Corporation Virtual data store creation and use
US7730222B2 (en) 2004-08-24 2010-06-01 Symantec Operating System Processing storage-related I/O requests using binary tree data structures
JP4311637B2 (en) 2003-10-30 2009-08-12 株式会社日立製作所 Storage controller
US7565431B2 (en) * 2003-11-20 2009-07-21 International Business Machines Corporation Method, system, and program for determining information on a storage system in a network
CN100349408C (en) * 2004-02-12 2007-11-14 华为技术有限公司 Method for realizing configuration data real-time synchronization for network management system and network element device
US20060031230A1 (en) * 2004-07-21 2006-02-09 Kumar Sinha M Data storage systems
US8601035B2 (en) 2007-06-22 2013-12-03 Compellent Technologies Data storage space recovery system and method
US7707586B2 (en) * 2004-09-08 2010-04-27 Intel Corporation Operating system independent agent
US7062624B2 (en) * 2004-09-29 2006-06-13 Hitachi, Ltd. Method for managing volume groups considering storage tiers
CN100384294C (en) * 2004-09-30 2008-04-23 华为技术有限公司 Method for realizing roaming limitation
US20060080362A1 (en) * 2004-10-12 2006-04-13 Lefthand Networks, Inc. Data Synchronization Over a Computer Network
US7386664B1 (en) * 2004-10-13 2008-06-10 Symantec Operation Corporation Method and system for mirror storage element resynchronization in a storage virtualization device
US7330955B2 (en) * 2004-10-18 2008-02-12 Seagate Technology Llc Recovery record for updating a system configuration
US8346843B2 (en) 2004-12-10 2013-01-01 Google Inc. System and method for scalable data distribution
US20060129987A1 (en) * 2004-12-15 2006-06-15 Patten Benhase Linda V Apparatus, system, and method for accessing management data
JP2006172385A (en) * 2004-12-20 2006-06-29 Hitachi Ltd Computer system, method for calling storage management program and storage system
US8296271B1 (en) * 2005-03-28 2012-10-23 Federal Home Loan Mortgage Corporation System and method for optimizing data recovery in a parallel database
JP4699808B2 (en) 2005-06-02 2011-06-15 株式会社日立製作所 Storage system and configuration change method
CN100384146C (en) * 2005-06-08 2008-04-23 杭州华三通信技术有限公司 Method for managing distribution network equipment
US20060294300A1 (en) 2005-06-22 2006-12-28 Seagate Technology Llc Atomic cache transactions in a distributed storage system
EP1913482A4 (en) * 2005-07-14 2010-08-25 Emc Corp Maintaining write order fidelity on a multi-writer system
US7647335B1 (en) 2005-08-30 2010-01-12 ATA SpA - Advanced Technology Assessment Computing system and methods for distributed generation and storage of complex relational data
US20070088931A1 (en) * 2005-10-17 2007-04-19 Nobuyuki Osaki Method and apparatus to authorize cross-partition commands
JP4852298B2 (en) * 2005-10-28 2012-01-11 株式会社日立製作所 Method for taking over information for identifying virtual volume and storage system using the method
US8200869B2 (en) * 2006-02-07 2012-06-12 Seagate Technology Llc Storage system with alterable background behaviors
CN100423491C (en) 2006-03-08 2008-10-01 杭州华三通信技术有限公司 Virtual network storing system and network storing equipment thereof
US8005793B1 (en) * 2006-04-18 2011-08-23 Netapp, Inc. Retaining persistent point in time data during volume migration
US8260924B2 (en) * 2006-05-03 2012-09-04 Bluetie, Inc. User load balancing systems and methods thereof
JP5124103B2 (en) * 2006-05-16 2013-01-23 株式会社日立製作所 Computer system
CN101454745B (en) * 2006-05-24 2012-09-05 克姆佩棱特科技公司 System and method for raid management, reallocation, and restriping
CN101467122B (en) * 2006-05-24 2012-07-04 克姆佩棱特科技公司 Data progression disk locality optimization system and method
US8056082B2 (en) * 2006-05-31 2011-11-08 Bluetie, Inc. Capacity management and predictive planning systems based on trended rate change of monitored factors and methods thereof
CN101296108B (en) * 2007-04-27 2012-12-12 华为技术有限公司 Method, network appliance and system for resource backup in structured P2P
JP5130538B2 (en) * 2007-06-22 2013-01-30 日本電気株式会社 Network file system and network file system recovery method
US7945639B2 (en) * 2007-06-27 2011-05-17 Microsoft Corporation Processing write requests with server having global knowledge
JP5142629B2 (en) * 2007-08-22 2013-02-13 株式会社日立製作所 Storage system and method for backing up virtual volume
US8244846B2 (en) * 2007-12-26 2012-08-14 Symantec Corporation Balanced consistent hashing for distributed resource management
WO2010041515A1 (en) 2008-10-06 2010-04-15 インターナショナル・ビジネス・マシーンズ・コーポレーション System accessing shared data by a plurality of application servers
SE533007C2 (en) 2008-10-24 2010-06-08 Ilt Productions Ab Distributed data storage
KR100926098B1 (en) * 2008-11-18 2009-11-11 주식회사 네오플 Method and apparatus for information recovery in using snap shot database
US9323473B2 (en) 2009-01-09 2016-04-26 Hewlett Packard Enterprise Development Lp Virtual tape library
US8468292B2 (en) * 2009-07-13 2013-06-18 Compellent Technologies Solid state drive data storage system and method
US9092597B2 (en) * 2009-12-09 2015-07-28 Sandisk Technologies Inc. Storage device and method for using a virtual file in a public memory area to access a plurality of protected files in a private memory area
EP2712149B1 (en) 2010-04-23 2019-10-30 Compuverde AB Distributed data storage
US8301715B2 (en) 2010-05-20 2012-10-30 Sandisk Il Ltd. Host device and method for accessing a virtual file in a storage device by bypassing a cache in the host device
US8930330B1 (en) 2011-06-27 2015-01-06 Amazon Technologies, Inc. Validation of log formats
US9658892B2 (en) * 2011-08-31 2017-05-23 International Business Machines Corporation Management of storage cluster performance with hybrid workloads
US8650365B2 (en) 2011-09-02 2014-02-11 Compuverde Ab Method and device for maintaining data in a data storage system comprising a plurality of data storage nodes
US9021053B2 (en) 2011-09-02 2015-04-28 Compuverde Ab Method and device for writing data to a data storage system comprising a plurality of data storage nodes
US8997124B2 (en) 2011-09-02 2015-03-31 Compuverde Ab Method for updating data in a distributed data storage system
US8645978B2 (en) 2011-09-02 2014-02-04 Compuverde Ab Method for data maintenance
US9626378B2 (en) 2011-09-02 2017-04-18 Compuverde Ab Method for handling requests in a storage system and a storage node for a storage system
US8769138B2 (en) 2011-09-02 2014-07-01 Compuverde Ab Method for data retrieval from a distributed data storage system
US9141440B2 (en) * 2011-12-29 2015-09-22 Red Hat, Inc. Fault tolerant distributed lock manager
US9146851B2 (en) 2012-03-26 2015-09-29 Compellent Technologies Single-level cell and multi-level cell hybrid solid state drive
KR101496011B1 (en) * 2012-07-09 2015-02-26 부산대학교 산학협력단 System and method for processing sensor stream data based hadoop
CN102917005B (en) * 2012-08-28 2016-10-26 大唐软件技术股份有限公司 A kind of mass memory access method supporting affairs and device
KR101242458B1 (en) * 2012-09-13 2013-03-12 효성아이티엑스(주) Intelligent virtual storage service system and method thereof
US9501501B2 (en) 2013-03-15 2016-11-22 Amazon Technologies, Inc. Log record management
US9672237B2 (en) 2013-03-15 2017-06-06 Amazon Technologies, Inc. System-wide checkpoint avoidance for distributed database systems
US11030055B2 (en) 2013-03-15 2021-06-08 Amazon Technologies, Inc. Fast crash recovery for distributed database systems
US9514007B2 (en) 2013-03-15 2016-12-06 Amazon Technologies, Inc. Database system with database engine and separate distributed storage service
US10180951B2 (en) 2013-03-15 2019-01-15 Amazon Technologies, Inc. Place snapshots
JP5954738B2 (en) 2013-03-19 2016-07-20 インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation Computer, system, method and program for performing file backup processing
US10747746B2 (en) 2013-04-30 2020-08-18 Amazon Technologies, Inc. Efficient read replicas
US9317213B1 (en) 2013-05-10 2016-04-19 Amazon Technologies, Inc. Efficient storage of variably-sized data objects in a data store
US9760596B2 (en) 2013-05-13 2017-09-12 Amazon Technologies, Inc. Transaction ordering
US9208032B1 (en) 2013-05-15 2015-12-08 Amazon Technologies, Inc. Managing contingency capacity of pooled resources in multiple availability zones
US10303564B1 (en) 2013-05-23 2019-05-28 Amazon Technologies, Inc. Reduced transaction I/O for log-structured storage systems
US9305056B1 (en) 2013-05-24 2016-04-05 Amazon Technologies, Inc. Results cache invalidation
US9047189B1 (en) 2013-05-28 2015-06-02 Amazon Technologies, Inc. Self-describing data blocks of a minimum atomic write size for a data store
US9280591B1 (en) 2013-09-20 2016-03-08 Amazon Technologies, Inc. Efficient replication of system transactions for read-only nodes of a distributed database
US9460008B1 (en) 2013-09-20 2016-10-04 Amazon Technologies, Inc. Efficient garbage collection for a log-structured data store
US10216949B1 (en) 2013-09-20 2019-02-26 Amazon Technologies, Inc. Dynamic quorum membership changes
US9507843B1 (en) 2013-09-20 2016-11-29 Amazon Technologies, Inc. Efficient replication of distributed storage changes for read-only nodes of a distributed database
US9519664B1 (en) 2013-09-20 2016-12-13 Amazon Technologies, Inc. Index structure navigation using page versions for read-only nodes
US9552242B1 (en) 2013-09-25 2017-01-24 Amazon Technologies, Inc. Log-structured distributed storage using a single log sequence number space
US9699017B1 (en) 2013-09-25 2017-07-04 Amazon Technologies, Inc. Dynamic utilization of bandwidth for a quorum-based distributed storage system
US10223184B1 (en) 2013-09-25 2019-03-05 Amazon Technologies, Inc. Individual write quorums for a log-structured distributed storage system
US9760480B1 (en) 2013-11-01 2017-09-12 Amazon Technologies, Inc. Enhanced logging using non-volatile system memory
US10387399B1 (en) 2013-11-01 2019-08-20 Amazon Technologies, Inc. Efficient database journaling using non-volatile system memory
US9880933B1 (en) 2013-11-20 2018-01-30 Amazon Technologies, Inc. Distributed in-memory buffer cache system using buffer cache nodes
US9223843B1 (en) 2013-12-02 2015-12-29 Amazon Technologies, Inc. Optimized log storage for asynchronous log updates
US10303663B1 (en) 2014-06-12 2019-05-28 Amazon Technologies, Inc. Remote durable logging for journaling file systems
US9665432B2 (en) * 2014-08-07 2017-05-30 Microsoft Technology Licensing, Llc Safe data access following storage failure
US9847918B2 (en) 2014-08-12 2017-12-19 Microsoft Technology Licensing, Llc Distributed workload reassignment following communication failure
CN107466456B (en) 2015-12-30 2020-01-17 华为技术有限公司 Locking request processing method and server
CN105630104A (en) * 2015-12-30 2016-06-01 深圳市瑞驰信息技术有限公司 Cluster storing system
US11914571B1 (en) 2017-11-22 2024-02-27 Amazon Technologies, Inc. Optimistic concurrency for a multi-writer database
US10534751B1 (en) 2018-09-11 2020-01-14 Seagate Technology Llc Metadata space efficient snapshot operation in page storage
US10942902B2 (en) * 2019-01-17 2021-03-09 Cohesity, Inc. Efficient database migration using an intermediary secondary storage system
CN111277634B (en) * 2020-01-14 2021-12-21 北京金山云网络技术有限公司 Data ID distribution method, device, system and server
US11341163B1 (en) 2020-03-30 2022-05-24 Amazon Technologies, Inc. Multi-level replication filtering for a distributed database
CN113760395A (en) * 2020-06-30 2021-12-07 北京沃东天骏信息技术有限公司 Method, device, equipment and computer readable medium for interface authentication

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5537585A (en) * 1994-02-25 1996-07-16 Avail Systems Corporation Data storage management for network interconnected processors
US6260145B1 (en) * 1997-02-14 2001-07-10 Fujitsu Limited System and method of authentication of digital information
US20010020254A1 (en) * 1998-06-30 2001-09-06 Blumenau Steven M. Method and apparatus for managing access to storage devices in a storage system with access control
US6732171B2 (en) * 2002-05-31 2004-05-04 Lefthand Networks, Inc. Distributed network storage system with virtualization

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE69822283T2 (en) * 1997-12-24 2004-07-29 Nortel Networks Ltd., St. Laurent Distributed persistent storage for user-provider systems with sometimes broken connections
US6295575B1 (en) * 1998-06-29 2001-09-25 Emc Corporation Configuring vectors of logical storage units for data storage partitioning and sharing
US6148414A (en) * 1998-09-24 2000-11-14 Seek Systems, Inc. Methods and systems for implementing shared disk array management functions
US20020103889A1 (en) * 2000-02-11 2002-08-01 Thomas Markson Virtual storage layer approach for dynamically associating computer storage with processing hosts

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5537585A (en) * 1994-02-25 1996-07-16 Avail Systems Corporation Data storage management for network interconnected processors
US6260145B1 (en) * 1997-02-14 2001-07-10 Fujitsu Limited System and method of authentication of digital information
US20010020254A1 (en) * 1998-06-30 2001-09-06 Blumenau Steven M. Method and apparatus for managing access to storage devices in a storage system with access control
US6732171B2 (en) * 2002-05-31 2004-05-04 Lefthand Networks, Inc. Distributed network storage system with virtualization

Cited By (79)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110191412A1 (en) * 2002-08-12 2011-08-04 Dell Products, L.P. Transparent request routing for a partitioned application service
US7571206B2 (en) 2002-08-12 2009-08-04 Equallogic, Inc. Transparent request routing for a partitioned application service
US20090276490A1 (en) * 2002-08-12 2009-11-05 Koning G Paul Transparent request routing for a partitioned application service
US7925696B2 (en) 2002-08-12 2011-04-12 Dell Products L.P. Transparent request routing for a partitioned application service
US20040030755A1 (en) * 2002-08-12 2004-02-12 Koning G. Paul Transparent request routing for a partitioned application service
US8055706B2 (en) 2002-08-12 2011-11-08 Dell Products, L.P. Transparent request routing for a partitioned application service
US8005918B2 (en) 2002-11-12 2011-08-23 Rateze Remote Mgmt. L.L.C. Data storage devices having IP capable partitions
US8473578B2 (en) 2002-11-12 2013-06-25 Rateze Remote Mgmt, L.L.C. Data storage devices having IP capable partitions
US7870271B2 (en) 2002-11-12 2011-01-11 Charles Frank Disk drive partitioning methods and apparatus
US20060029070A1 (en) * 2002-11-12 2006-02-09 Zetera Corporation Protocol adapter for electromagnetic device elements
US20060126666A1 (en) * 2002-11-12 2006-06-15 Charles Frank Low level storage protocols, systems and methods
US7882252B2 (en) 2002-11-12 2011-02-01 Charles Frank Providing redundancy for a device within a network
US7916727B2 (en) 2002-11-12 2011-03-29 Rateze Remote Mgmt. L.L.C. Low level storage protocols, systems and methods
US8694640B2 (en) 2002-11-12 2014-04-08 Rateze Remote Mgmt. L.L.C. Low level storage protocols, systems and methods
US7720058B2 (en) 2002-11-12 2010-05-18 Charles Frank Protocol adapter for electromagnetic device elements
US7698526B2 (en) 2002-11-12 2010-04-13 Charles Frank Adapted disk drives executing instructions for I/O command processing
US7688814B2 (en) 2002-11-12 2010-03-30 Charles Frank Methods of conveying information using fixed sized packets
US7649880B2 (en) 2002-11-12 2010-01-19 Mark Adams Systems and methods for deriving storage area commands
US20110138057A1 (en) * 2002-11-12 2011-06-09 Charles Frank Low level storage protocols, systems and methods
US7962609B2 (en) 2003-01-20 2011-06-14 Dell Products, L.P. Adaptive storage block data distribution
US7627650B2 (en) 2003-01-20 2009-12-01 Equallogic, Inc. Short-cut response for distributed services
US20040143648A1 (en) * 2003-01-20 2004-07-22 Koning G. P. Short-cut response for distributed services
US20080209042A1 (en) * 2003-01-20 2008-08-28 Equallogic Inc. Adaptive storage block data distribution
US7461146B2 (en) 2003-01-20 2008-12-02 Equallogic, Inc. Adaptive storage block data distribution
US20040143637A1 (en) * 2003-01-20 2004-07-22 Koning G. Paul Adaptive storage block data distribution
US8966197B2 (en) 2003-01-21 2015-02-24 Dell Products L.P. Distributed snapshot process
US20040153615A1 (en) * 2003-01-21 2004-08-05 Koning G. Paul Distributed snapshot process
US20040215792A1 (en) * 2003-01-21 2004-10-28 Equallogic, Inc. Client load distribution
US8209515B2 (en) 2003-01-21 2012-06-26 Dell Products Lp Storage systems having differentiated storage pools
US7937551B2 (en) 2003-01-21 2011-05-03 Dell Products L.P. Storage systems having differentiated storage pools
US7127577B2 (en) * 2003-01-21 2006-10-24 Equallogic Inc. Distributed snapshot process
US8499086B2 (en) 2003-01-21 2013-07-30 Dell Products L.P. Client load distribution
US20070106857A1 (en) * 2003-01-21 2007-05-10 Equallogic Inc. Distributed snapshot process
US8037264B2 (en) 2003-01-21 2011-10-11 Dell Products, L.P. Distributed snapshot process
US20110208943A1 (en) * 2003-01-21 2011-08-25 Dell Products, L.P. Storage systems having differentiated storage pools
US8612616B2 (en) 2003-01-21 2013-12-17 Dell Products, L.P. Client load distribution
US7505461B2 (en) * 2003-05-06 2009-03-17 Seiko Epson Corporation Data transfer control device, electronic instrument, and data transfer control method
US20050002391A1 (en) * 2003-05-06 2005-01-06 Seiko Epson Corporation Data transfer control device, electronic instrument, and data transfer control method
US7552149B2 (en) 2003-09-06 2009-06-23 Oracle International Corporation Querying past versions of data in a distributed database
US20050055385A1 (en) * 2003-09-06 2005-03-10 Oracle International Corporation Querying past versions of data in a distributed database
US7395369B2 (en) * 2004-05-18 2008-07-01 Oracle International Corporation Distributing data across multiple storage devices
US20050262038A1 (en) * 2004-05-18 2005-11-24 Oracle International Corporation Distributing data across multiple storage devices
US7251660B2 (en) * 2004-06-10 2007-07-31 Oracle International Corporation Providing mappings between logical time values and real time values in a multinode system
US20050278359A1 (en) * 2004-06-10 2005-12-15 Oracle International Corporation Providing mappings between logical time values and real time values in a multinode system
US7363444B2 (en) * 2005-01-10 2008-04-22 Hewlett-Packard Development Company, L.P. Method for taking snapshots of data
US20060155946A1 (en) * 2005-01-10 2006-07-13 Minwen Ji Method for taking snapshots of data
US9141965B2 (en) * 2005-01-27 2015-09-22 International Business Machines Corporation Database usage trends based on database lock requests
US20140136501A1 (en) * 2005-01-27 2014-05-15 International Business Machines Corporation Database usage trends based on database lock requests
US7702850B2 (en) 2005-03-14 2010-04-20 Thomas Earl Ludwig Topology independent storage arrays and methods
US20060272015A1 (en) * 2005-05-26 2006-11-30 Frank Charles W Virtual devices and virtual bus tunnels, modules and methods
US8726363B2 (en) 2005-05-26 2014-05-13 Rateze Remote Mgmt, L.L.C. Information packet communication with virtual objects
US8387132B2 (en) 2005-05-26 2013-02-26 Rateze Remote Mgmt. L.L.C. Information packet communication with virtual objects
US20070168396A1 (en) * 2005-08-16 2007-07-19 Zetera Corporation Generating storage system commands
US7743214B2 (en) 2005-08-16 2010-06-22 Mark Adams Generating storage system commands
USRE47411E1 (en) 2005-08-16 2019-05-28 Rateze Remote Mgmt. L.L.C. Disaggregated resources and access methods
US8819092B2 (en) 2005-08-16 2014-08-26 Rateze Remote Mgmt. L.L.C. Disaggregated resources and access methods
USRE48894E1 (en) 2005-08-16 2022-01-11 Rateze Remote Mgmt. L.L.C. Disaggregated resources and access methods
US11848822B2 (en) 2005-10-06 2023-12-19 Rateze Remote Mgmt. L.L.C. Resource command messages and methods
US11601334B2 (en) 2005-10-06 2023-03-07 Rateze Remote Mgmt. L.L.C. Resource command messages and methods
US9270532B2 (en) 2005-10-06 2016-02-23 Rateze Remote Mgmt. L.L.C. Resource command messages and methods
US20070083662A1 (en) * 2005-10-06 2007-04-12 Zetera Corporation Resource command messages and methods
US7924881B2 (en) 2006-04-10 2011-04-12 Rateze Remote Mgmt. L.L.C. Datagram identifier management
US7904681B1 (en) * 2006-06-30 2011-03-08 Emc Corporation Methods and systems for migrating data with minimal disruption
US8352448B2 (en) * 2007-01-23 2013-01-08 International Business Machines Corporation Securely deleting data in a transactionally consistent manner
US20080177802A1 (en) * 2007-01-23 2008-07-24 International Business Machines Corporation Securely deleting data in a transactionally consistent manner
US20080183894A1 (en) * 2007-01-25 2008-07-31 Oracle International Corporation Synchronizing cluster time
US7814360B2 (en) 2007-01-25 2010-10-12 Oralce International Corporation Synchronizing cluster time to a master node with a faster clock
US7543046B1 (en) * 2008-05-30 2009-06-02 International Business Machines Corporation Method for managing cluster node-specific quorum roles
US8930371B1 (en) * 2008-06-30 2015-01-06 Amazon Technologies, Inc. Systems and methods for efficiently storing index data on an electronic device
US8416954B1 (en) 2008-09-30 2013-04-09 Emc Corporation Systems and methods for accessing storage or network based replicas of encrypted volumes with no additional key management
US8261068B1 (en) 2008-09-30 2012-09-04 Emc Corporation Systems and methods for selective encryption of operating system metadata for host-based encryption of data at rest on a logical unit
US8169856B2 (en) 2008-10-24 2012-05-01 Oracle International Corporation Time synchronization in cluster systems
US20100103781A1 (en) * 2008-10-24 2010-04-29 Oracle International Corporation Time synchronization in cluster systems
US8166314B1 (en) 2008-12-30 2012-04-24 Emc Corporation Selective I/O to logical unit when encrypted, but key is not available or when encryption status is unknown
US10127262B2 (en) 2011-07-01 2018-11-13 International Business Machines Corporation Data set connection manager having a plurality of data sets to represent one data set
US8688635B2 (en) * 2011-07-01 2014-04-01 International Business Machines Corporation Data set connection manager having a plurality of data sets to represent one data set
US20130007292A1 (en) * 2011-07-01 2013-01-03 International Business Machines Corporation Data set connection manager having a plurality of data sets to represent one data set
US11995063B2 (en) 2011-07-01 2024-05-28 International Business Machines Corporation Data set connection manager having a plurality of data sets to represent one data set
US8966211B1 (en) * 2011-12-19 2015-02-24 Emc Corporation Techniques for dynamic binding of device identifiers to data storage devices

Also Published As

Publication number Publication date
BR0311390A (en) 2005-04-05
CN1662903A (en) 2005-08-31
CA2486994A1 (en) 2003-12-11
JP2005528684A (en) 2005-09-22
AU2003243347A1 (en) 2003-12-19
WO2003102731A2 (en) 2003-12-11
US20050010618A1 (en) 2005-01-13
US7200664B2 (en) 2007-04-03
EP1512082A4 (en) 2009-07-22
US20030225884A1 (en) 2003-12-04
KR20050010845A (en) 2005-01-28
WO2003102731A3 (en) 2004-03-25
EP1512082A2 (en) 2005-03-09
CN100339847C (en) 2007-09-26
US6732171B2 (en) 2004-05-04

Similar Documents

Publication Publication Date Title
US7200664B2 (en) Distributed network storage system with virtualization
US6950915B2 (en) Data storage subsystem
JP4809040B2 (en) Storage apparatus and snapshot restore method
US7149787B1 (en) Apparatus and method for mirroring and restoring data
US6772303B2 (en) System and method for dynamically resynchronizing backup data
US8732121B1 (en) Method and system for backup to a hidden backup storage
US6968425B2 (en) Computer systems, disk systems, and method for controlling disk cache
US6647473B1 (en) Kernel-based crash-consistency coordinator
US7103713B2 (en) Storage system, device and method using copy-on-write for synchronous remote copy
US7509567B1 (en) System and method for resolving data inconsistencies with a data majority
US20080140963A1 (en) Methods and systems for storage system generation and use of differential block lists using copy-on-write snapshots
US6701455B1 (en) Remote copy system with data integrity
EP0405926A2 (en) Method and apparatus for managing a shadow set of storage media
US8751765B2 (en) Computer system, storage system and method for saving storage area by integrating same data
JP2004252686A (en) Information processing system
US20030023808A1 (en) Method and system for maintaining data coherency in a dual input/output adapter utilizing clustered adapters
JP2003162439A (en) Storage system and control method therefor
JP2005031716A (en) Method and device for data backup
US8316196B1 (en) Systems, methods and computer readable media for improving synchronization performance after partially completed writes
US20100217857A1 (en) Consolidating session information for a cluster of sessions in a coupled session environment
US7451283B2 (en) Method, system, and program for copying tracks between a primary storage and secondary storage
US7197599B2 (en) Method, system, and program for managing data updates
JP2008225616A (en) Storage system, remote copy system and data restoration method
JPH1069422A (en) File number remapping method and device for suspended processing
EP1855187A2 (en) Computer system for managing number of writes for storage medium and control method therefor

Legal Events

Date Code Title Description
STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: HEWLETT-PACKARD COMPANY, CALIFORNIA

Free format text: MERGER;ASSIGNOR:LEFTHAND NETWORKS, INC.;REEL/FRAME:022460/0989

Effective date: 20081201

AS Assignment

Owner name: HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P., TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT-PACKARD COMPANY;REEL/FRAME:022529/0821

Effective date: 20090325

AS Assignment

Owner name: HEWLETT-PACKARD COMPANY, CALIFORNIA

Free format text: MERGER;ASSIGNOR:LEFTHAND NETWORKS, INC.;REEL/FRAME:022542/0346

Effective date: 20081201

Owner name: LEFTHAND NETWORKS, INC, CALIFORNIA

Free format text: MERGER;ASSIGNOR:LAKERS ACQUISITION CORPORATION;REEL/FRAME:022542/0337

Effective date: 20081113

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP, TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.;REEL/FRAME:037079/0001

Effective date: 20151027

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12