The disclosure is related to the field of data storage, and more particularly to operation of clustered data storage systems.
One aspect of the current technique is a method for selecting a surviving storage node based on environmental conditions. A request for exclusive access to a volume is received. A score based on data associated with an environment of the node is determined for each node in a cluster. Based on the scores, a node to grant exclusive access to the volume is identified, and such exclusive access is granted to the identified node.
A first request from a first node and a second request from a second node may be received. Data from sensors at sites of the nodes in the cluster may be requested. Values for each sensor may be determined based on the response from the sensor. If the response from the sensor corresponds to normal conditions at the environment of the node, the sensor may be assigned a positive value. If the response from the sensor corresponds to abnormal conditions at the environment of the node, the sensor may be assigned a negative value. If the sensor failed to respond to the request for data, the sensor may be assigned a negative value. The magnitude of the value may depend on whether the response from the sensor corresponds to normal or abnormal conditions at the environment of the node, or whether the sensor failed to respond to the request for data. The values of the sensors associated with a particular node in the cluster may be summed or normalized. A node whose score is at least a threshold amount greater than the scores of other nodes in the cluster is selected for exclusive access to the volume.
Another aspect of the current technique is a system with at least one processor. The at least one processor is configured to receive a request for exclusive access to a volume; determine, for each node in a cluster, a score based on data associated with an environment of the node; identify, based on the scores, a node to grant exclusive access to the volume; and grant exclusive access to the volume to the identified node. The at least one processor may be configured to perform any other processes in conformance with the aspect of the current techniques described above.
Features and advantages of the present technique will become more apparent from the following detailed description of exemplary embodiments thereof taken in conjunction with the accompanying drawings in which:
Consider an active/active arrangement in which two data storage systems present a single data storage object, such as a volume 26. The volume 26 data is available through paths going to both systems, which may be referred to as “System A” and “System B”. Every write to A is replicated to B synchronously, and similarly, every write to B is replicated to A, synchronously. The two systems maintain a cluster between them via a Time to Live (TTL) mechanism, where one system (preferred) grants TTL to its peer (non-preferred). In this basic, TTL-only arrangement, the non-preferred system lives at the mercy of the preferred system, and once its TTL expires, it goes offline. In the case of a failure, the non-preferred system always becomes unavailable (due to expiration of its TTL), and if any other system in the cluster survives, that system becomes the preferred system.
When one of the systems cannot replicate a write, the system must be made unavailable, thereby breaking the cluster. Surviving systems continue processing I/O requests from hosts. As indicated above, in the 2-node, TTL-only arrangement, the survivor (if any) is always preferred. The TTL mechanism is used to guarantee that no “split brain” situation occurs, i.e., the situation in which both systems are processing host I/Os (Reads and Writes) but no replication is occurring. Using TTL, once one system cannot replicate to its peer, TTL request/grant stops and the non-preferred eventually becomes unavailable. At that point, the preferred system is allowed to service I/O requests, and to process writes without replicating them to its peer.
There are conditions in which it is possible and desirable for the non-preferred system to survive and continue processing host I/O requests, while the preferred system is made unavailable. A simple example is the complete failure of the preferred system. Rolling disasters, such as power failures, earthquakes, or fires, may cause communication between systems in a cluster to fail, and such disasters may also cause systems to become unavailable.
To improve availability by allowing for a system to survive when possible, a disclosed approach employs a separate “witness node” and protocol to enable a system to provide single-node access to a storage volume 26 (also referred to herein as “exclusive access”) after a failure within the cluster. When communication between the systems fails, both systems may contact the witness node to request becoming the preferred system (also referred to herein as “polarization”). In the rolling disasters described above, a system in an affected site may successfully communicate with the witness node, but subsequently become unavailable and thus incapable of servicing I/O requests. To ensure an unavailable system does not become a preferred system, the witness node may take into account environmental information about the sites where the systems reside, when determining which system shall become preferred.
In at least some implementations in accordance with the techniques as described herein, one or more of the following advantages can be provided: continued storage availability to hosts through the selection of an available system to continue servicing I/O requests, and selection of a system without human intervention.
As shown, the system further includes one or more replication links 24 between the DSSs 10, which may be distinct physical links or logical links carried via the network 14. For ease of reference the singular “replication link” is used in this description. Also shown is a logical volume 26 that can be accessed by the hosts 10 via both the DSSs 10, under normal operating conditions. In one embodiment the cluster 16 is a high-availability cluster whose nodes/DSSs 10 reside in different physical locations, such as different buildings of a campus or across some other limited geographic area (e.g., tens of miles). The volume 26 may be referred to as a “stretched” volume 26, referring to its logical presence on such physically separated DSSs 16. In normal operation, each DSS 10 services host I/O requests to the volume 26, which includes replicating write-type requests to the other DSS 16 via the replication link 24. Although the present description is based on access to a volume 26 specifically, it will be appreciated that the disclosed technique may be used with other types of data storage objects such as files, containers, etc.
Also shown is a special logical session referred to as “time to live” or TTL 30, which is used as part of protection against failure, and in particular to protect against the so-called “split brain” problem in which one DSS 10 is modifying its local copy of the volume 26 without such modifications also being made on the other DSS 10, resulting in data corruption. Using TTL 30, one DSS 10 (“preferred”) regularly grants permission for continued operation to the other DSS 10 (“non-preferred”), so that both DSSs 10 provide host access to the volume 26 as long as this permission stays in effect. Under various failure conditions, the TTL mechanism 30 either fails itself (signifying the failure) or it is used in a manner that signals a separately detected failure from one DSS 10 to the other (i.e., by stopping the requesting or granting of permission). Additional details are given below. As also explained below, the witness node 18 is also involved in processing during failure conditions, namely in helping select a DSS 10 which is to survive a failure and provide sole, single-node access to the volume 26 to the exclusion of the other DSS 10. Because of the protection function of the witness node 18, it is preferably in a different fault domain than either of the DSSs 10, e.g. in a different building or other physical location to improve its availability when there is a failure affecting one or both DSSs 10 or the replication link 24.
Each of the DSSs 10 maintains a TTL expiration time, which is periodically refreshed and used in conjunction with a system time-of-day (TOD) to monitor for expiration of TTL. Whenever the TOD value is higher than the expiration time, it means TTL has expired and the DSS 10 initiates polarization. From time to time, the “TTL expiration time” is updated (via TTL requests). Thus, under normal circumstances the “TTL expiration time” is always in the future, and as the TOD clocks is ticking, TTL updates keep moving the TTL expiration time ahead so that it stays in the future. If TTL updates stop, due to a failure, eventually the TOD clock progresses past the TTL expiration timer and polarization will be triggered.
The preferred DSS 10-P uses its TTL expiration timer to track its projection of the expiration of the TTL timer at the non-preferred DSS 10-NP. When a failure occurs (which may be intermittent), TTL grant requests (or responses) are not being transferred on the link 24, and one or both arrays 10 see their TTL timer expiring. When an array timer expires, the array 10 stops servicing I/O requests and starts queuing them instead, while also invoking the polarization process to resolve which of the two arrays 10 should survive. The TTL mechanism alone would dictate that only the preferred DSS 10-P should survive, if any. However, additional functionality involving the witness node 18 can result in the non-preferred DSS 10-NP surviving in some cases, as explained more below. If only one of the arrays 10 has connectivity to the witness node 18, there is a strong indication that the other DSS 10 has been isolated (e.g., in a data center failure), and the DSS 10 with the intact witness connectivity should prevail even if it is the non-preferred DSS 10-NP. If both DSSs 10 have connectivity to the witness node 18 so as to send requests for polarization, the witness node 18 determines which DSS 10 should be granted exclusive access to a volume 26.
At 50, normal operation occurs in which the DSS 10 employs a time-to-live (TTL) mechanism by which a preferred node 10 of a clustered pair regularly communicates permission for continued operation to a non-preferred node of the clustered pair in response to regular TTL requests therefrom. It will be understood that the use of the TTL mechanism differs between the preferred and non-preferred nodes 10-P, 10-NP accordingly, and as described above. Also at 50, assuming regular non-errored operation of the TTL mechanism, both DSSs 10 service host I/O requests to the volume 26 and replicate write-type requests to the other DSS 10 of the pair, in order to maintain synchronization of the local copies of the volume 26.
At 52, a node detects a failure of replication, which may be indicated by errored operation of the TTL mechanism, and performs a polarization operation to select a surviving node 10 to transition to single-node access to the volume 26. “Errored” operation refers to the situation in which the TTL timer at either/both the DSSs 10 reach zero. The polarization process may include:
(1) Suspending the servicing of the host I/O requests and stopping TTL operation (withholding requests and grants). Host I/O requests may be queued for processing after completion of polarization.
(2) At least one of the preferred DSS 10-P and non-preferred DSS 10-NP contacts the witness node 18 to request survivor status, so as to gain exclusive access to the volume 26.
(3) The witness node 18 determines which nodes shall be granted survivor status.
(4) The node 10 granted survivor status continues to service host I/O requests to the volume 26 without replicating write-type requests to the other node 10.
(5) The other node, based on being denied survivor status, discontinues servicing of host I/O requests to the volume 26.
It will be appreciated that using the above scheme, there are conditions in which the non-preferred DSS 10-NP receives survivor status and continues operation, to the exclusion of the preferred DSS 10-P. This can occur, for example, if the preferred DSS 10-P completely fails and is unable to contact the witness node 18, in which case the witness node 18 receives a polarization request from the non-preferred DSS 10-NP and allows it to become the survivor.
For clarity, it is emphasized that active/active replication failure can stem from either TTL failure or a failure to replicate a write request. This description employs the term “replication” to refer to the active/active mechanism, and in this case, there are the types of following failures that cause polarization:
1. Inability to replicate a host write within a specified time window
2. Inability to get timely response to TTL requests, resulting in expiration of the TTL timer
In cases of rolling disasters, disruptions to the environment of a DSS 10 may render the DSS 10 unavailable for servicing I/O requests from hosts 12. Because a DSS 10 may successfully communicate with the witness node 18 to request polarization before the disaster fully renders the DSS 10 unavailable, the witness node 18 needs to assess the DSS's 10 suitability independently. As previously explained, sensors 205 collect data about the environments of each DSS 10. The witness node 18 may analyze the data to determine if a DSS's 10 ability to request polarization belies its unavailability to service I/O requests, such that polarization should not be granted.
When the witness node 18 receives a request for polarization from a DSS 10, the witness node 18 attempts to avoid granting polarization to any DSS 10 that may be unavailable and thus incapable of servicing I/O requests. In response to such a request, the witness node 18 may set a timer and send requests to sensors 205 for data about the environments of the sites. In many embodiments, the length of time of the timer is shorter than the timeout for a host (e.g., 1 second for the timer, compared to 3 seconds for the host). As the witness node 18 limits the amount of time the sensors 205 have to respond and selects a survivor node 10 accordingly, the survivor node 10 may assume responsibility for the volume 26 without interrupting service to the hosts 12.
Depending on its state, a sensor 205 may not respond to the witness node's request for data 18. For example, in event of fire, temperature probes 205 may have melted, and in event of an earthquake, vibrations may have disrupted equipment so as to fall upon and break vibration sensors 205. Floods may wash away sensors 205, and power outages may leave sensors 205 without the ability to communicate with the witness node 18. Due to the possible inferences for non-responsive sensors 205, the witness node 18 assigns such sensors 205 negative scores.
In other situations, a sensor 205 may respond to the witness node 18, but provide data that indicates that the DSS 10 is operating in a sub-optimal environment. Should a hurricane destroy part of a building at a site, a humidity probe 205 may return values far higher than usual. Alternatively, abnormally high values may indicate that the heating, ventilation, and air conditioning (HVAC) system on site has failed. If a power system is facing irregularities, a sensor 205 may indicate that voltages/currents to the buildings have fluctuated significantly over the past 24 hours, or that multiple interruptions have occurred. Vibration sensors 205 may indicate the site has recently experienced tremors, thereby carrying risks of after effects. Due to the possible inferences for responsive sensors 205 returning concerning data, the witness node 18 assigns such sensors 205 negative scores. In many embodiments, the negative scores have lower magnitudes than those assigned for non-responsive sensors.
Sites that have not experienced any major disruptions or irregularities will have sensors 205 that respond to the witness node 18 with normal values, and the witness node 18 assigns these sensors 205 positive scores.
In some embodiments, a score for a sensor 205 can be binary. Thus, a positive score would be “1”, for responsive sensors 205 reporting normal values, and a negative score would be “0”, for non-responsive sensors 205 or responsive sensors 205 reporting abnormal values. In other embodiments, a score may fall within a range, such as 0 to 10. For example, if a sensor 205 is non-responsive, it may be assigned a score of 0, and if it is responsive and reporting normal values, it may be assigned a score of 10. If the sensor 205 is responsive but reporting abnormal values, its score may depend on the extent to which the values deviate from normal conditions. For example, a sensor 205 that reports 3 power outages of 30+ minutes within the past 24 hours may be given a score of 3, whereas a sensor 205 that reports a single power outage of 5 minutes within the past 24 hours may be given a score of 7. A temperature probe 205 reporting a temperature of 5 degrees higher than normal may be given a score of 8, where a probe 205 reporting a temperature of 40 degrees higher than normal may be given a score of 2.
After the witness node 18 assigns values to the sensors 205 based on the returned data, the witness node 18 determines a score for each site corresponding to a DSS 10. The witness node 18 may sum the values of the sensors 205 at a particular site. If all of the sites have the same number and type of sensors 205, the witness node 18 may simply compare the site scores. However, when sites differ in the number and type of sensors 205, the witness node 18 may normalize the site scores. For example, the witness node 18 may average the scores of the sensors 205 at a site. Alternatively, the scores may be normalized according to a scale of 0 to 100. Thus, if the maximum score for a site is 50, the actual score of the site may be multiplied by 2 before being compared to the normalized score of other sites. In another example, for a site with 15 sensors 205, the sum of the sensor 205 scores may be multiplied by (100/15) to obtain a normalized score.
When the timer set by the witness node 18 elapses, the witness node 18 identify the DSS 10 to which exclusive access to the volume 26 will be granted. In some embodiments, only one DSS 10 sends the request for polarization to the witness node 18, and thus the request is granted regardless of the scores. In other embodiments, the witness node 18 receives the request from more than one node 10. The witness node 18 compares the scores for the nodes. Polarization may be granted to the DSS 10 with the higher score. In some embodiments, the score for one DSS 10 must be appreciably higher than the score for the others 10 for that DSS 10 to be granted polarization. One score may need to be at least 15% higher, although other thresholds and metrics for comparing the scores may be used.
If the scores for the DSSs 10 are not appreciably different, the witness node 18 may grant polarization to the preferred DSS 10. Alternatively, the witness node 18 may grant polarization to the DSS 10 whose request was received first. In some situations, if none of the DSSs 10 are preferred (e.g., the preferred DSS 10 is unavailable, and there is no preference among the remaining DSSs 10), then the first DSS 10 that requested polarization will receive exclusive access to the volume 26.
For the method illustrated in
It should again be emphasized that the implementations described above are provided by way of illustration, and should not be construed as limiting the present invention to any specific embodiment or group of embodiments. For example, the invention can be implemented in other types of systems, using different arrangements of processing devices and processing operations. Also, message formats and communication protocols utilized may be varied in alternative embodiments. Moreover, various simplifying assumptions made above in the course of describing the illustrative embodiments should also be viewed as exemplary rather than as requirements or limitations of the invention. Numerous alternative embodiments within the scope of the appended claims will be readily apparent to those skilled in the art.
Furthermore, as will be appreciated by one skilled in the art, the present disclosure may be embodied as a method, system, or computer program product. Accordingly, the present disclosure may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present disclosure may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising”, when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
While the invention has been disclosed in connection with preferred embodiments shown and described in detail, their modifications and improvements thereon will become readily apparent to those skilled in the art. Accordingly, the spirit and scope of the present invention should be limited only by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5527003 | Diesel | Jun 1996 | A |
5958009 | Friedrich | Sep 1999 | A |
6105094 | Lindeman | Aug 2000 | A |
7739541 | Rao | Jun 2010 | B1 |
7793051 | Nguyen | Sep 2010 | B1 |
8473462 | Banerjee | Jun 2013 | B1 |
9626378 | Bernbo | Apr 2017 | B2 |
10895972 | Apostolatos | Jan 2021 | B1 |
11068461 | Chan | Jul 2021 | B1 |
11086802 | Jalal | Aug 2021 | B1 |
11130422 | Goldfarb | Sep 2021 | B1 |
11347607 | Tylik | May 2022 | B1 |
11481116 | Tavallaei | Oct 2022 | B2 |
11487594 | Ehmann | Nov 2022 | B1 |
11563764 | Hoscheit | Jan 2023 | B1 |
11734636 | Harry | Aug 2023 | B2 |
20010007971 | Okada | Jul 2001 | A1 |
20020108077 | Havekost | Aug 2002 | A1 |
20020120819 | Hickson | Aug 2002 | A1 |
20030110157 | Maki | Jun 2003 | A1 |
20030126381 | Vo | Jul 2003 | A1 |
20030149848 | Ibrahim | Aug 2003 | A1 |
20040034724 | Bruner | Feb 2004 | A1 |
20040068619 | Van Doren | Apr 2004 | A1 |
20040207965 | Ausserlechner | Oct 2004 | A1 |
20060020778 | Edrington | Jan 2006 | A1 |
20060227664 | Horak | Oct 2006 | A1 |
20070050563 | Alsup | Mar 2007 | A1 |
20070113233 | Collard | May 2007 | A1 |
20070219751 | Huang | Sep 2007 | A1 |
20070226423 | Arimilli | Sep 2007 | A1 |
20070247767 | Zhang | Oct 2007 | A1 |
20080022030 | Hagiwara | Jan 2008 | A1 |
20080120441 | Loewenstein | May 2008 | A1 |
20080129740 | Itagaki | Jun 2008 | A1 |
20080253386 | Barum | Oct 2008 | A1 |
20080320230 | Vishin | Dec 2008 | A1 |
20090094430 | Bergheaud | Apr 2009 | A1 |
20090119461 | Cypher | May 2009 | A1 |
20090157770 | Havewala | Jun 2009 | A1 |
20100100655 | Dowedeit | Apr 2010 | A1 |
20110191496 | Luo | Aug 2011 | A1 |
20120027030 | Naito | Feb 2012 | A1 |
20120144107 | Asher | Jun 2012 | A1 |
20120144138 | Kandasamy | Jun 2012 | A1 |
20120245791 | Yun | Sep 2012 | A1 |
20130297552 | Bansal | Nov 2013 | A1 |
20130339630 | Alexander | Dec 2013 | A1 |
20140015568 | Shimamune | Jan 2014 | A1 |
20140040410 | McDowell | Feb 2014 | A1 |
20140134955 | Honda | May 2014 | A1 |
20140171749 | Chin | Jun 2014 | A1 |
20140281234 | Power | Sep 2014 | A1 |
20150208464 | Heo | Jul 2015 | A1 |
20150325272 | Murphy | Nov 2015 | A1 |
20150347055 | Truong | Dec 2015 | A1 |
20150350318 | Van Assche | Dec 2015 | A1 |
20150378800 | Suzuki | Dec 2015 | A1 |
20160117105 | Thangaraj | Apr 2016 | A1 |
20160117267 | Witt | Apr 2016 | A1 |
20160126741 | Ito | May 2016 | A1 |
20160212007 | Alatorre | Jul 2016 | A1 |
20160218933 | Porras | Jul 2016 | A1 |
20160259742 | Faulkner | Sep 2016 | A1 |
20160305232 | Bird | Oct 2016 | A1 |
20160327417 | Hara | Nov 2016 | A1 |
20170249082 | Litke | Aug 2017 | A1 |
20170318060 | Wang | Nov 2017 | A1 |
20180026644 | Shankar | Jan 2018 | A1 |
20180227202 | Aravot | Aug 2018 | A1 |
20180234478 | Das | Aug 2018 | A1 |
20180260120 | Ozguner | Sep 2018 | A1 |
20180270381 | Ikuta | Sep 2018 | A1 |
20180270927 | Daroussin | Sep 2018 | A1 |
20180276142 | Algieri | Sep 2018 | A1 |
20180278055 | Shaik | Sep 2018 | A1 |
20180307297 | Semeria | Oct 2018 | A1 |
20190042118 | Lu | Feb 2019 | A1 |
20190042440 | Kumar | Feb 2019 | A1 |
20190108152 | Lee | Apr 2019 | A1 |
20190108739 | Wedig | Apr 2019 | A1 |
20190163404 | Pedersen | May 2019 | A1 |
20190193520 | Tsunoda | Jun 2019 | A1 |
20190196917 | Ma | Jun 2019 | A1 |
20190278644 | Chen | Sep 2019 | A1 |
20190278672 | Jin | Sep 2019 | A1 |
20190294554 | Bryant | Sep 2019 | A1 |
20190317945 | Ezick | Oct 2019 | A1 |
20190347167 | Wang | Nov 2019 | A1 |
20190387009 | Kondaveeti | Dec 2019 | A1 |
20200042733 | Chen | Feb 2020 | A1 |
20200192721 | Mclean | Jun 2020 | A1 |
20200272972 | Harry | Aug 2020 | A1 |
20200314218 | Kumar | Oct 2020 | A1 |
20200314607 | Hwang | Oct 2020 | A1 |
20200403991 | Sohail | Dec 2020 | A1 |
20210089366 | Wang | Mar 2021 | A1 |
20210126935 | Todd | Apr 2021 | A1 |
20210176036 | Gulati | Jun 2021 | A1 |
20210208817 | Shin | Jul 2021 | A1 |
20210306414 | Beard | Sep 2021 | A1 |
20210317618 | Hu | Oct 2021 | A1 |
20210365301 | Rao | Nov 2021 | A1 |
20220050613 | Muchherla | Feb 2022 | A1 |
20220100398 | Raff | Mar 2022 | A1 |
20220138055 | Gothi | May 2022 | A1 |
20220334971 | Malewicki | Oct 2022 | A1 |
20220342558 | Longo | Oct 2022 | A1 |
Number | Date | Country | |
---|---|---|---|
20230019241 A1 | Jan 2023 | US |