Multi-class heterogeneous clients in a clustered filesystem

US9606874B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9606874-B2
Application numberUS-201414481666-A
CountryUS
Kind codeB2
Filing dateSep 9, 2014
Priority dateJun 5, 2001
Publication dateMar 28, 2017
Grant dateMar 28, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A cluster of computer system nodes connected by a storage area network include two classes of nodes. The first class of nodes can act as clients or servers, while the other nodes can only be clients. The client-only nodes require much less functionality and can be more easily supported by different operating systems. To minimize the amount of data transmitted during normal operation, the server responsible for maintaining a cluster configuration database repeatedly multicasts the IP address, its incarnation number and the most recent database generation number. Each node stores this information and when a change is detected, each node can request an update of the data needed by that node. A client-only node uses the IP address of the server to connect to the server, to download the information from the cluster database required by the client-only node and to upload local disk connectivity information.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for maintaining mirror consistency of data volumes in a cluster of computer system nodes, the method comprising: maintaining mirror specific state information by one or more volume manager servers mirroring a data volume, wherein the mirrored data volume is accessible by any node in the cluster, wherein one or more servers are chosen to be a volume manager server when initializing a cluster of servers, and wherein at least one of the one or more volume manager servers stores a first mirror of the data volume; determining that there was data lost on a data storage device storing at least a portion of the first mirrored data volume; initiating the revival of data in an address range in the first mirrored data volume, wherein I/O requests from client nodes made to the address range being revived are refused by the at least one of the one or more volume manager servers mirroring the data volume during the revival of the address range in the first mirrored data volume; and writing mirrored data from a second mirror of the data volume corresponding to the address range being revived in the first mirror of the data volume, wherein the mirrored data written to the first mirrored data volume was read from the second mirror of the data volume prior to writing. 2. The method of claim 1 , wherein at least one other of the one or more volume manager servers receives configuration information from all client nodes and distributes changes to each of the client nodes. 3. The method of claim 1 , wherein the refusing of at least one of the I/O requests comprising retiring at least one I/O request from a client node of the client nodes after a predetermined time interval without informing an application running on the client node when the mirrored data is currently being read from the second mirror. 4. The method of claim 3 , further comprising: receiving a message from the client node that the application wants to perform an I/O request to a portion of the of the address range being revived; and transmitting a reply to the client node. 5. The method of claim 4 , wherein the reply indicates that the I/O request overlaps an area being revived, and wherein the client node enters a loop where the access is retired periodically until it is successful without the application being aware that the client node entered the loop. 6. The method of claim 1 , wherein at least the first mirrored data volume or the second mirrored data volume are striped across a plurality of data storage devices. 7. The method of claim 1 , wherein the least one of the one or more volume manager servers receives configuration information from all client nodes and distributes changes to each client node of the client nodes. 8. A non-transitory computer readable storage medium having embodied thereon a program executable to perform a method for maintaining mirror consistency of data volumes in a cluster of computer system nodes, the method comprising: maintaining mirror specific state information by one or more volume manager servers mirroring a data volume, wherein the mirrored data volume is accessible by any node in the cluster, wherein one or more servers are chosen to be a volume manager server when initializing a cluster of servers, and wherein at least one of the one or more volume manager servers stores a first mirror of the data volume; determining that there was data lost on a data storage device storing at least a portion of the first mirrored data volume; initiating the revival of data in an address range in the first mirrored data volume, wherein I/O requests from client nodes made to the address range being revived are refused by the at least one of the one or more volume manager servers mirroring the data volume during the revival of the address range in the first mirrored data volume; and writing mirrored data from a second mirror of the data volume corresponding to the address range being revived in the first mirror of the data volume, wherein the mirrored data written to the first mirrored data volume was read from the second mirror of the data volume prior to writing. 9. The non-transitory computer readable storage medium of claim 8 , wherein at least one other of the one or more volume manager servers receives configuration information from all client nodes and distributes changes to each of the client nodes. 10. The non-transitory computer readable storage medium of claim 8 , wherein the refusing of at least one of the I/O requests comprising retiring at least one I/O request from a client node of the client nodes after a predetermined time interval without informing an application running on the client node when the mirrored data is currently being read from the second mirror. 11. The non-transitory computer readable storage medium of claim 10 , the program being further executable to: receive a message from the client node that the application wants to perform an I/O request to a portion of the of the address range being revived; and transmit a reply to the client node. 12. The non-transitory computer readable storage medium of claim 11 , wherein the reply indicates that the I/O request overlaps an area being revived, and wherein the client node enters a loop where the access is retired periodically until it is successful without the application being aware that the client node entered the loop. 13. The non-transitory computer readable storage medium of claim 8 , wherein at least the first mirrored data volume or the second mirrored data volume are striped across a plurality of data storage devices. 14. The non-transitory computer readable storage medium of claim 8 , wherein the least one of the one or more volume manager servers receives configuration information from all client nodes and distributes changes to each client node of the client nodes. 15. A system for maintaining mirror consistency of data volumes in a cluster of computer system nodes, the system comprising: a processor and a memory in each of one or more volume manager servers mirroring a data volume, wherein the processor in each of the one or more volume manager servers executes instructions out of its memory to: maintain mirror specific state information, wherein the mirrored data volume is accessible by any node in the cluster, wherein one or more servers are chosen to be a volume manager server when initializing a cluster of servers, and wherein at least one of the one or more volume manager servers stores a first mirror of the data volume; determine that there was data lost on a data storage device storing at least a portion of the first mirrored data volume; initiate the revival of data in an address range in the first mirrored data volume, wherein I/O requests from client nodes made to the address range being revived are refused by the at least one of the one or more volume manager servers mirroring the data volume during the revival of the address range in the first mirrored data volume; and write mirrored data from a second mirror of the data volume corresponding to the address range being revived in the first mirror of the data volume, wherein the mirrored data written to the first mirrored data volume was read from the second mirror of the data volume prior to writing. 16. The system of claim 15 , wherein at least one other of the one or more volume manager servers receives configuration information from all client nodes and distributes changes to each of the client nodes. 17. The system of claim 15 , wherein the refusing of at least one of the I/O requests comprising retiring at least on

Assignees

Inventors

Classifications

  • characterised by the conditions triggering a change of settings · CPC title

  • Electricity · mapped topic

  • 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] · CPC title

  • Physics · mapped topic

  • in the application layer [OSI layer 7] · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9606874B2 cover?
A cluster of computer system nodes connected by a storage area network include two classes of nodes. The first class of nodes can act as clients or servers, while the other nodes can only be clients. The client-only nodes require much less functionality and can be more easily supported by different operating systems. To minimize the amount of data transmitted during normal operation, the server…
Who is the assignee on this patent?
Silicon Graphics Int Corp
What technology area does this patent fall under?
Primary CPC classification H04L67/1097. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Mar 28 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).