Cluster-based network file server

US9715346B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9715346-B2
Application numberUS-201514628028-A
CountryUS
Kind codeB2
Filing dateFeb 20, 2015
Priority dateNov 4, 2014
Publication dateJul 25, 2017
Grant dateJul 25, 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.

Methods and systems for managing, storing, and serving data within a virtualized environment are described. In some embodiments, a data management system may manage the extraction and storage of virtual machine snapshots, provide near instantaneous restoration of a virtual machine or one or more files located on the virtual machine, and enable secondary workloads to directly use the data management system as a primary storage target to read or modify past versions of data. The data management system may allow a virtual machine snapshot of a virtual machine stored within the system to be directly mounted to enable substantially instantaneous virtual machine recovery of the virtual machine.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for operating a cluster-based network file server, comprising: assigning a first floating IP address to a first node in a cluster; detecting that the first node has failed; determining a set of nodes within the cluster that are responsive in response to detecting that the first node has failed, the set of nodes includes a second node in the cluster; generating a set of priority values corresponding with the set of nodes, the generating a set of priority values includes assigning a set of identification numbers to the set of nodes, each node of the set of nodes is assigned a different identification number of the set of identification numbers, the generating a set of priority values includes assigning an identification number of the set of identification numbers to the second node, the generating a set of priority values includes determining a number of nodes within the cluster and generating a priority value for the second node equal to a difference between the identification number and the first floating IP address modulo the number of nodes within the cluster; determining that the second node should be assigned the first floating IP address based on the set of priority values; and assigning the first floating IP address to the second node in response to determining that the second node should be assigned the first floating IP address. 2. The method of claim 1 , wherein: the determining that the second node should be assigned the first floating IP address includes determining that the second node is associated with a highest priority value of the set of priority values; and the assigning the first floating IP address includes assigning the first floating IP address to the second node in response to determining that the second node is associated with the highest priority value of the set of priority values. 3. The method of claim 1 , wherein: the determining that the second node should be assigned the first floating IP address includes identifying a set of virtual machines that were running on the first node when the first node failed, identifying a subset of the set of nodes within the cluster that are running cloned versions of the set of virtual machines, determining a subset of the set of priority values corresponding with the subset of the set of nodes, and determining that the second node is associated with a highest priority value of the subset of the set of priority values; and the assigning the first floating IP address includes assigning the first floating IP address to the second node in response to determining that the second node is associated with the highest priority value of the subset of the set of priority values. 4. The method of claim 1 , wherein: the generating a set of priority values includes determining a maximum number of nodes for the cluster and generating the priority value for the second node equal to the identification number minus the first floating IP address modulo the maximum number of nodes for the cluster. 5. The method of claim 1 , wherein: the set of priority values comprises an ordered list of priority values, each priority value of the set of priority values is different from any of the other priority values of the set of priority values. 6. The method of claim 1 , further comprising: detecting that the first node is back up and causing the second node to release the first floating IP address in response to detecting that the first node is back up. 7. The method of claim 1 , wherein: the detecting that the first node has failed includes determining that the first node has failed to communicate within a threshold period of time. 8. The method of claim 1 , wherein: the detecting that the first node has failed includes detecting that the first node has experienced a hardware failure. 9. The method of claim 1 , wherein: the cluster-based network file server does not include a front-end load balancer; each node in the cluster is stateless, the cluster comprises a plurality of physical machines in communication with each other via a network, the first node is associated with a first physical machine of the plurality of physical machines, the second node is associated with a second physical machine of the plurality of physical machines; and the cluster is backed by a distributed file system. 10. The method of claim 1 , wherein: each node in the cluster runs a Virtual Router Redundancy Protocol daemon. 11. The method of claim 1 , wherein: the second node runs a Virtual Router Redundancy Protocol daemon, the Virtual Router Redundancy Protocol daemon determines a priority value of the set of priority values for the second node and determines that the second node should be assigned the first floating IP address based on the priority value. 12. The method of claim 1 , wherein: the second node runs a Virtual Router Redundancy Protocol daemon, the Virtual Router Redundancy Protocol daemon detects that the first node has failed, determines that the second node should be assigned the first floating IP address in response to detecting that the first node has failed, and assigns the first floating IP address to the second node. 13. A cluster-based network file server, comprising: a first node of a cluster, the first node is assigned a first floating IP address; and a second node of the cluster in communication with the first node, the second node configured to run a daemon, the daemon configured to detect that the first node has failed and determine a set of nodes within the cluster that are responsive in response to detecting that the first node has failed, the set of nodes includes the second node, the daemon configured to assign a set of identification numbers to the set of nodes, each node of the set of nodes is assigned a different identification number of the set of identification numbers, the daemon configured to assign an identification number of the set of identification numbers to the second node and generate a set of priority values corresponding with the set of nodes, the daemon configured to determine a number of nodes within the cluster and generate a priority value of the set of priority values for the second node based on a difference between the identification number and the first floating IP address modulo the number of nodes within the cluster, the daemon configured to determine that the second node should be assigned the first floating IP address based on the set of priority values and assign the first floating IP address to the second node in response to determining that the second node should be assigned the first floating IP address. 14. The cluster-based network file server of claim 13 , wherein: the daemon configured to determine that the second node is associated with a highest priority value of the set of priority values and assign the first floating IP address to the second node in response to determining that the second node is associated with the highest priority value of the set of priority values. 15. The cluster-based network file server of claim 13 , wherein: the daemon configured to determine a maximum number of nodes for the cluster and generate the priority value for the second node equal to the identification number minus the first floating IP address modulo the maximum number of nodes for the cluster. 16. The cluster-based network file server of claim 13 , wherein: the cluster comprises a plurality of physical machines in communication with each other via a network, the first node is associated with a first physical machine of the plurality of physical machines, the seco

Assignees

Inventors

Classifications

  • File search processing · CPC title

  • Management of the data involved in backup or backup restore · CPC title

  • Details of file system snapshots on the file-level, e.g. snapshot creation, administration, deletion (error detection or correction of the data by redundancy in operations or in hardware G06F11/14, G06F11/16) · CPC title

  • by checking functioning · CPC title

  • Memory management, e.g. access or allocation · 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 US9715346B2 cover?
Methods and systems for managing, storing, and serving data within a virtualized environment are described. In some embodiments, a data management system may manage the extraction and storage of virtual machine snapshots, provide near instantaneous restoration of a virtual machine or one or more files located on the virtual machine, and enable secondary workloads to directly use the data manage…
Who is the assignee on this patent?
Rubrik Inc
What technology area does this patent fall under?
Primary CPC classification G06F9/45558. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jul 25 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 7 related publications on this page (citations in our corpus or others sharing the same primary CPC).