CN101154410B - 在自动数据存储库子系统中的方法和库控制器 - Google Patents
在自动数据存储库子系统中的方法和库控制器 Download PDFInfo
- Publication number
- CN101154410B CN101154410B CN2007101477094A CN200710147709A CN101154410B CN 101154410 B CN101154410 B CN 101154410B CN 2007101477094 A CN2007101477094 A CN 2007101477094A CN 200710147709 A CN200710147709 A CN 200710147709A CN 101154410 B CN101154410 B CN 101154410B
- Authority
- CN
- China
- Prior art keywords
- data storage
- error event
- storage medium
- driving
- threshold value
- 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.)
- Expired - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0766—Error or fault reporting or storing
- G06F11/0787—Storage of error reports, e.g. persistent data storage, storage using memory protection
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0706—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
- G06F11/0727—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a storage system, e.g. in a DASD or network based storage system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0766—Error or fault reporting or storing
- G06F11/0781—Error filtering or prioritizing based on a policy defined by the user or on a policy defined by a hardware/software module, e.g. according to a severity level
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0751—Error or fault detection not based on redundancy
- G06F11/0754—Error or fault detection not based on redundancy by exceeding limits
- G06F11/076—Error or fault detection not based on redundancy by exceeding limits by exceeding a count or rate limit, e.g. word- or bit count limit
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
- Automatic Tape Cassette Changers (AREA)
Abstract
当检测到涉及数据存储驱动和数据存储介质的被选错误事件,子系统尝试把介质移动到另一驱动上,并实施类似的操作。该子系统分开跟踪个体驱动和个体介质的连续错误事件,其中完整的成功操作打断了连续错误事件的链;并且一旦连续错误事件的数目达到门限值,就使该数据存储驱动或数据存储介质故障。错误事件被分类为:1)在介质安装到驱动之前或期间的错误事件;和2)在介质成功安装到驱动之后的错误事件;并且对于驱动和介质的每个类别分别实施跟踪、比较和故障步骤。
Description
技术领域
本发明涉及数据存储的错误处理,尤其涉及跟踪自动数据存储库子系统的数据存储驱动和数据存储介质的错误事件。
背景技术
数据存储子系统包括用于数据存储和访问的高度可靠的装置。自动数据存储库子系统提供了大量数据存储介质的存储并且一般具有大量的数据存储驱动,而且可以提供高速缓存和其它中间存储,以便将数据转移到数据存储介质以及从数据存储介质中访问数据。当错误可能出现时,希望既确保防止数据丢失又确保防止数据存储介质或数据存储驱动的不必要移除和替换,并避免更新子系统和/或数据所需的时间。另外,还希望确保防止不必要的服务呼叫并且避免可能导致的潜在停机时间。这意味着自动检查错误事件并实施移除、替换以及在必要时提供服务呼叫是所希望的。
发明内容
在某些实施例中,自动数据存储库子系统、计算机程序产品及方法涉及自动数据存储库子系统的库控制器,该库具有被配置成存储数据存储介质的存储架、多个数据存储驱动以及被配置成在存储架和数据存储驱动之间传送数据存储介质的至少一个自动机存取器(robot accessor)。
在一个实施例中,一种方法,检测涉及数据存储驱动和数据存储介质的被选错误事件的发生;一旦被选错误事件涉及数据存储介质,就尝试把该数据存储介质移到另一数据存储驱动,并实施与导致该被选错误事件的操作类似的操作;分开跟踪个体数据存储驱动和个 体数据存储介质的连续错误事件,其中数据存储驱动和/或数据存储介质的完整成功操作打断了连续错误事件的链;把数据存储驱动和/或数据存储介质的连续错误事件的数目与门限值进行比较;并且一旦连续错误事件的数目达到门限值,就把数据存储驱动和/或数据存储介质放置在故障类别中。
在另一个实施例中,一种方法,还涉及:把涉及数据存储驱动的错误事件和涉及数据存储介质的错误事件分类为:
1)在数据存储介质安装到数据存储驱动中之前或期间的错误事件;
2)在数据存储介质成功安装到数据存储驱动中之后的错误事件;
并对于数据存储驱动和数据存储介质的每个类别分别地实施跟踪、比较和放置步骤。
在又一个实施例中,一种方法,还把错误事件还分类为:
A)即时错误事件;和
B)非即时错误事件;
一旦隔离了具有即时错误事件的数据存储驱动或数据存储介质,就把被隔离的数据存储介质或数据存储驱动放置在故障类别中;并对于在所述即时错误事件中涉及的所述数据存储驱动或所述数据存储介质中的所述非即时错误事件实施所述跟踪、比较和放置步骤,所述即时错误事件具有所述故障类别数据存储介质或所述故障类别数据存储驱动,而不必在错误事件的所述连续或所述累计中考虑所述即时错误事件。
在又一个实施例中,一种方法,分别累计在一段时间周期上每个类别中的关于个体数据存储驱动和关于个体数据存储介质的被选错误事件;把类别中的数据存储驱动的和数据存储介质的累计错误事件数目与门限值进行比较;并且一旦该类别中的累计错误事件数目达到该门限值,就把数据存储驱动和/或数据存储介质放置在故障类别中。
在另一个实施例中,一种方法,还涉及:如果错误事件彼此相关,则降低这些错误事件在被选错误事件的连续之中以及累计中的权重。
在又一个实施例中,一种方法,还涉及:如果数据存储驱动从子系统中被移除,则清除在被移除数据存储驱动处发生的数据存储介质的错误事件。
在另一个实施例中,一种方法,还涉及:如果数据存储驱动从子系统中被移除并被返回,则清除被移除并被返回的数据存储驱动的错误事件。
在又一个实施例中,一种方法,还涉及:如果数据存储介质从子系统中被移除,则清除在数据存储驱动处发生的关于该被移除数据存储介质的数据存储驱动错误事件。
在又一个实施例中,一种方法,还涉及:如果数据存储介质从子系统中被移除并被返回,则清除被移除并被返回的数据存储介质的错误事件。
在另一个实施例中,一种方法,还涉及:把相关错误减少成单个被选错误事件。
在又一个实施例中,一种方法,还涉及:在数据库中存储与被选错误事件相关的信息,其中被选错误事件与数据存储介质和数据存储驱动都相关,该信息描述了数据存储介质和数据存储驱动以及被选错误事件。
为了更完整地理解本发明,请参考结合附图进行的随后的详细说明。
附图说明
图1是可以实现本发明的自动数据存储库的等尺寸图;
图2是图1的自动数据存储库的打开框架的示意图;
图3是系统方框示意图,该系统包括有具有图1和图2的自动数据存储库的自动数据存储库子系统;和
图4是描述了根据本发明的图3的自动数据存储库子系统的自动操作的流程图。
具体实施方式
在如下描述中将参考附图以优选实施例来描述本发明,其中,相同的附图标记表示相同或类似的元件。虽然本发明是按照实现本发明目的的最佳模式来描述的,但是本领域的技术人员将会明白,参照这些教导在不脱离本发明的精神或范围的前提下可以实现各种变化。
图1、2和3说明了根据本发明在子系统101中配置的自动数据存储库100的一个实施例,所述自动数据存储库100被布置成一般响应于来自至少一个外部主机系统21的命令来访问诸如磁带盒之类的数据存储介质,并且包括一个或多个框架50、51、52、53、54和55,它们每一个都具有多个用于存储数据存储介质的存储架66,并且可以具有多个用于相对于数据存储介质进行读取和写入数据的数据存储驱动10。库100还包括至少一个用于在存储架66和数据存储驱动10之间传送数据存储介质的自动机存取器68。自动机存取器68包括用于夹持一个或多个数据存储介质的夹持器组件60,而且可以包括存取器感应器72以读取数据存储介质的标签。例如,在输入/输出台77处,磁带数据存储盒可以被添加到库中或者从库中被移除。在此,自动数据存储库子系统101可以包括单个自动数据存储库100,或包括多个库。多个库可以被物理地连接到一起,以使自动机存取器可以在每个库之间移动以及移动到每个库中,或者使得建立一个通路以便允许数据存储介质在各个库之间移动。
库子系统101还包括库控制器80,它可以被分布在各个框架之中以便操作该库、与主机系统21通信以及与数据存储驱动10通信。另外,库可以提供一个或多个操作面板93用于与库控制器通信。自动数据存储库的一个例子包括3584磁带库,并且自动数据存储库的另一个例子包括3494磁带库。在此,“库控制器”可以包 括任何合适的逻辑、微处理器以及用于对程序代码进行响应的相关联的存储器和/或数据存储,并且相关联的存储器和/或数据存储可以包括固定的或者可重写的存储器或数据存储设备。通过以下方式程序代码可以像来自数据存储设备或存储器中一样被直接提供给库控制器:例如,在例如操作面板93处通过来自光盘的输入、或者例如在数据存储驱动10处通过从磁带盒中读取、或者例如经由主机系统21来自网络、或者通过任何其它合适的方式。库控制器80一般位于自动数据存储库100中,但是也可物理上位于子系统中的任意点处,或者跨该库或子系统分布。
库子系统101可以包括或者不包括虚拟化节点40,并且可以包括或者不包括高速缓存45。虚拟化节点40可以包括库控制器的一部分或者可以包括独立实体,并且包括磁带守护进程(daemon)41,其模拟对主机系统21的磁带驱动,但是正如本领域技术人员已知的那样,它实际上对位于高速缓存45上的文件进行操作。正如本领域技术人员已知的那样,高速缓存45一般是诸如RAID(独立冗余磁盘阵列)之类的一个磁盘文件子系统,或者是若干个如此的磁盘文件子系统。子系统把数据从主机系统放到高速缓存中并把该数据移到自动数据存储库。数据可被保留在高速缓存45中,以供主机系统快速访问,并且,如果数据已被转移,则正如本领域技术人员已知的那样,它一般从自动数据存储库被移到高速缓存并使其可从高速缓存中获得。
虽然库、数据存储驱动和数据存储介质是高度可靠的,但是错误还是可能发生,并且错误类型可能极不相同。为了避免一些错误,可以实施各种重试过程。例如,读取错误可能是由于如下问题所引起:正在从磁带数据存储介质中读取数据的磁带驱动的读头未对准、写入数据的磁带驱动的写头未对准、磁带数据存储介质中的缺陷、延伸的磁带数据存储介质、正在读取数据的磁带驱动中的伺服错误等等。因此,重试过程可以尝试改变磁带驱动的一个或多个参数,比如使伺服少量偏移等等。在此,不是每个错误都导致“被选错误 事件”。例如,如果驱动实施最终起作用的重试过程,则原始错误可能不包括被选错误事件。可替换地,如果在操作成功完成之前实施了大量重试过程,则可以将原始错误认为是一些未来问题的警告,并且因此原始(或上一个)错误可以被认为是被选错误事件。仍然可替换地,该错误可以是重试不会起作用的类型,诸如数据存储介质盒从存储架中丢失之类的错误,例如,操作员未更新库目录将其从库中移除,因此无法找到标签或者无法访问由该物理目录指示的物理存储架处的盒的错误可能构成被选错误事件而无有效的重试过程。在同一情形下,如果错误是无法读取标签(因为标签不在那里),则在错误变成被选错误事件之前,可以实施相当数量的重试以便确定存在该错误。许多其它场景是本领域技术人员已知的,并且,关于选择哪些种错误类型以及在潜在的错误变成被选错误事件之前所需的重试量在此易受到相当大的改变。
另外,许多错误可能在不知道该错误是由于数据存储驱动、数据存储介质、前一数据存储驱动、或另一实体或设备所引起的情况下发生。被选错误事件可以只提供描述被检测到的错误或问题的错误代码,而不必识别该错误或问题的来源。
参见图3和4,示出了一种用于相对于自动数据存储库子系统实现本发明的方法实施例。在步骤200中,检测如上所讨论的被选错误事件。检测可以是通过数据存储驱动10、通过自动机存取器68等等来进行,并且一般借助于错误代码来进行报告。在此,检测还描述了所涉及的数据存储驱动和/或数据存储介质。
步骤202把被选错误事件中彼此可能相关的一些进行分组,把检测到的错误事件减少成单个错误事件。例如,数据存储驱动在打开已经被安装在该驱动中的数据存储介质的文件时可能有错误,在从该数据存储介质读取数据时可能有错误,在向该数据存储介质写入数据时可能有错误,并且在关闭文件时可能有错误。所有这些错误可能只有一个原因,于是被减少成单个错误事件。
在步骤205中,可以将检测信息提供给库控制器80的数据库85, 并被存储在其中,例如在驱动-介质表中,列出所涉及的数据存储驱动和所涉及的数据存储介质相关的每个被选错误事件。如果与被选错误事件相关的信息与数据存储介质和数据存储驱动都相关,则存储在数据库中的信息描述该数据存储介质和错误事件,并且描述该数据存储驱动和被选错误事件。该表格虑及了将要描述的被选错误事件的跟踪。为了一些与错误无关的目的,库中的所有介质可以在数据库85中都有条目。存储在数据库中的信息的例子包括卷名、它所包含的数据的状态以及数量。步骤205确定所涉及的数据存储驱动(如果有)以及所涉及的数据存储介质(如果有),并把该信息存储在数据库85中。数据库85可以包括库控制器的一部分存储器和/或数据存储,或者可以包括不同的存储器和/或不同的数据存储。
关于本发明,数据库85还至少识别这个介质所安装到其上的、具有前一错误的上一物理驱动。在步骤207,基于存在错误的上一物理驱动的数据库信息,库尝试把该错误中所涉及的数据存储介质移到另一数据存储驱动去,并且实施与导致该被选错误事件的操作类似的操作。例如如果通过错误检测步骤200的重复等等而发现错误在第二数据存储驱动上重复,那么该介质很可能是该问题的原因。如果错误未重复,那么不知道该错误是否被另一个驱动所克服或者该原始的驱动是否是该问题的原因。步骤207防止重试过程再次尝试该操作,但是发现当前可用的唯一驱动是发生该问题的那个驱动,并且可能再三在原始驱动处尝试该操作且重复该问题。
在步骤210中,一些被选错误事件可以被认为是“即时事件”。一个例子包括库子系统尝试访问数据存储介质盒但无法定位该盒,这意味着不可访问或者放置错误,例如,该盒已经从库子系统中被移除而未更新目录。另一个例子包括驱动已被重新配置但是重新配置还未通知库控制器,因此重新配置之前的驱动不再“存在”于库中。步骤210将错误事件分类为A)即时错误事件;和B)非即时错误事件。
如果错误事件是即时错误事件,则步骤213隔离具有即时错误事 件的数据存储介质或数据存储驱动,并且在步骤215,把被隔离的数据存储介质或数据存储驱动放在故障类别中。例如,如果数据存储介质盒不能被访问,则该介质发生故障。如果数据存储驱动无法被找到,则该驱动发生故障。关于故障介质或者故障驱动的信息可被保持在数据库中,以防该介质或驱动再出现。
如果错误事件是非即时错误事件,则步骤220把涉及数据存储驱动和/或数据存储介质的错误事件分类为:1)在数据存储介质安装到数据存储驱动中之前或期间的错误事件;2)在数据存储介质成功安装到数据存储驱动中之后的错误事件。
在数据存储介质的情况下,不是在错误事件之后把该介质表征为出故障,而是至少在某些错误之后可以把该介质发送到恢复队列。在恢复队列中的数据存储介质然后可以通过只读恢复处理,以便恢复尽可能多的数据。在此,术语“故障类别”和类似的术语是指故障的特征以及在恢复处理中的放置其中之一或者两者。
在安装数据存储介质之前或期间的错误事件的例子包括不能被装入(threaded)驱动中的磁带导带块(leader block),例如,由于导带块丢失或者在错误的位置,或者由于驱动装入(threading)机构工作不正常。在成功安装之后的一个错误事件例子是不能将数据写入介质,例如是由于写保护按钮已被设置,或者由于驱动写入驱动器未正常起作用。在成功安装之后的另一错误事件例子是伺服错误,例如由于磁带被延伸并错误定位了伺服轨迹,或者由于驱动伺服有跟踪错误。如果可能是驱动或者介质的错误发生,则错误事件归因于二者。
根据本发明,被分类的错误事件在性质上如此不同以至于它们毫不相干,并且跟踪这些不同类型的连续错误很可能导致驱动或介质的错误故障。
提供仅仅两种类别把重点放在特定的驱动或者特定的介质上,而非放在错误类型上,改变重点将其从具体驱动如何编码错误移开。以这种方式,该算法对驱动类型或者驱动制造商是不可知的,这些 制造商可能以特别引起他们兴趣的特定方法对错误进行编码。
步骤221降低相关错误事件的权重。例如,如果库断电,则当该库再次加电和/或重新初始化时,可能在一些或者所有数据存储驱动处发生错误,并且步骤221降低权重或者除去出现的与加电和/或重新初始化相关的所有错误。
步骤230分开跟踪在步骤220的两个类别中的个体数据存储驱动和个体数据存储介质的连续错误事件。如果数据存储驱动或数据存储介质没有归因于其的错误事件,则数据存储驱动或数据存储介质根本不需要被跟踪。连续错误事件例如从上面讨论的数据库中的条目被跟踪。在此,“分开跟踪”可以指分开跟踪所有驱动和介质的每一个并且指出它们是否有错误事件;或者只分开跟踪已经被识别为具有错误事件的驱动和介质。正如上面所讨论的那样,如果可能是驱动或者介质的错误发生,则错误事件归因于二者。假设由于步骤207把介质移到另一驱动的连续错误出现是因为具有连续错误事件的驱动或介质就是问题所在。
在步骤232中,数据存储驱动和/或数据存储介质的完整的成功操作打断了连续错误事件的链。根据本发明,该链只与错误事件的特定类别相关。因此,盒的成功安装打断了与被安装的盒相关和/或与在其位置处盒正被安装的驱动相关的安装之前或期间的错误事件的链,但是没有打断在成功安装之后发生的错误事件的链。在安装之后的成功操作将打断“成功安装之后”类别的错误事件的链。
在此,术语“数据存储驱动和/或数据存储介质”,或者反过来“数据存储介质和/或数据存储驱动”,以及类似的术语,是指与数据存储驱动和数据存储介质中的至少一个相关的动作。因此,在成功安装之后涉及数据存储盒的连续错误事件链的例子中,其中数据存储驱动没有当前错误事件链,则驱动和盒的成功操作只打断盒的连续错误事件链。
步骤235把数据存储驱动和/或数据存储介质的连续错误事件的数目与门限值237进行比较;并且一旦连续错误事件的数目达到该 门限值,就在步骤238把数据存储驱动和/或数据存储介质放在故障类别中。
可为数据存储介质和数据存储驱动设置不同的步骤237的门限值,并且可为不同的错误事件类别设置不同的步骤237的门限值。驱动的门限值可以被保守地设置,例如以便使驱动容易故障从而阻止情况更糟以及潜在地损毁若干介质,或者或许以便补偿不像其它驱动精确的那些驱动。门限值可以被设置得较高,例如以避免或者延迟在不寻常的高的装载周期期间花很长时间交换驱动。介质的门限值可以被保守地设置以便更好地确保防止潜在的数据丢失,或者可以对于具有诸如地震数据串之类非关键数据的介质而将所述门限值设置为较高。
一串连续错误事件的发生是具有连续错误的驱动或介质有问题的强有力证据。因此门限值的一个例子是4个连续错误事件。
步骤240分开累计在一个时间周期上在每个类别中关于个体数据存储驱动以及关于个体数据存储介质的被选错误事件。例如是24小时一个周期的时间可以通过重置243来控制。这个累计不被成功操作重置,并且累计在整个周期内继续。例如,在关于介质的错误事件之后,以至于该介质在步骤207被安装到不同的驱动上,则对于不同的介质成功完成了不同的操作,这打断了步骤232的链,但是错误事件在这一天中稍后再次发生。这也可能是指示驱动有问题。
步骤235把类别中的数据存储驱动和/或数据存储介质的累计错误事件的数目与门限值237进行比较;并且一旦该类别中的累计错误事件的数目达到该门限值,则在步骤238把数据存储驱动和/或数据存储介质放到故障类别中。
与步骤230的连续事件相比,可以为步骤240的累计错误事件设置不同的步骤237的门限值。另外,该门限值对于数据存储介质和对于数据存储驱动可以不同,而且对于不同类别的错误事件可以设置为不同。正如在上面讨论的那样,驱动的门限值可以被保守地设置,例如以便使驱动容易故障从而阻止情况更糟以及潜在地损毁若 干介质,或者或许以便补偿不像其它驱动精确的那些驱动。门限值可以被设置为较高,例如以避免或者延迟在不寻常的高的装载周期期间花很长时间交换驱动。介质的门限值可以被保守地设置以便更好地确保防止潜在的数据丢失,或者可以对于具有诸如地震数据串之类非关键数据的介质将所述门限值设置为较高。
在一个给定时间周期内若干错误事件的发生是有错误的驱动或介质有问题的证据。因此门限值的一个例子是累计4个错误事件。
如果哪个门限值都不满足,则该处理从步骤241继续以检查数据库以便跟踪并累计错误事件计数。
一种备选故障类型在步骤250中被指出,其中不但一个驱动或介质故障,而且相当多的驱动和/或介质已经出故障从而呈现出需要另外引起注意的情形。因此,在步骤250,“call home(呼叫中心)”信号被发出以便呼叫管理员、和/或库制造商、和/或驱动制造商或供应商、和/或介质制造商或供应商。随后的分析可能导致或者可能不会导致服务呼叫。
一旦通过步骤260检测到故障驱动或介质被移除,则可能是现在解决了该驱动或介质涉及的介质或驱动的错误事件,这些错误事件也已经被添加到数据库,用于受到影响的其它介质或驱动。
在步骤260和265中,如果数据存储驱动从子系统中被移除,则清除该被移除的数据存储驱动处发生的数据存储介质的错误事件。
类似地,在步骤260和265中,如果数据存储介质从子系统中被移除,则清除在数据存储驱动处发生的关于该被移除的数据存储介质的数据存储驱动的错误事件。
一旦故障驱动或介质通过步骤270已被检测到已被移除然后被返回,则可以假定该驱动或介质在被返回之前已被修理。
在步骤270和275中,如果数据存储驱动从子系统中被移除然后被返回,则清除该被移除并被返回的数据存储驱动的错误事件。
同样在步骤270和275中,如果数据存储介质从子系统中被移除然后被返回,则清除该被移除并被返回的数据存储介质的错误事件。
在即时错误事件的情况下,在步骤280,如果数据存储驱动在步骤210、213和215出故障,则在该故障数据存储驱动处发生的数据存储介质的相应错误不被认为是错误事件。类似地,如果数据存储介质在步骤210、213和215出故障,则相对于该故障数据存储介质而发生的数据存储驱动的相应错误不被认为是错误事件。
本领域技术人员应该理解:对于上面所讨论的这些方法可以进行各种改变,包括:对步骤的排序的改变或者各种步骤的移除。另外,本领域技术人员应该理解:除了在此示出的布置之外还可以使用不同的特定组件布置。
虽然已详细说明了本发明的优选实施例,但是应该明白:对本领域技术人员来说,可以想到对于那些实施例的改变和修改,而未偏离如随后权利要求中所阐明的本发明的范围。
Claims (21)
1.一种在自动数据存储库子系统中的方法,其中所述自动数据存储库子系统具有被配置成存储数据存储介质的存储架、多个数据存储驱动和被配置成在所述存储架和所述数据存储驱动之间传送数据存储介质的至少一个自动机存取器,该方法包括:
检测涉及数据存储驱动的被选错误事件和涉及数据存储介质的被选错误事件的发生;
一旦被选错误事件涉及数据存储介质,就尝试把所述数据存储介质移到另一数据存储驱动以阻止重试过程,并实施与导致所述被选错误事件的操作类似的操作;
分开跟踪个体数据存储驱动和个体数据存储介质的连续错误事件,其中所述数据存储介质和所述数据存储驱动中至少一个的完整成功操作打断了所述连续错误事件的链,对于所述成功,所述数据存储介质和所述数据存储驱动中至少一个具有所述连续错误事件的链;
把所述数据存储驱动和所述数据存储介质中至少一个的所述连续错误事件的数目与门限值进行比较;以及
一旦所述连续错误事件的所述数目达到所述门限值,就把所述数据存储驱动和所述数据存储介质中的至少一个放置在故障类别中。
2.根据权利要求1的方法,还包括:
把涉及所述数据存储驱动的所述错误事件和涉及所述数据存储介质的所述错误事件分类为:
1)在数据存储介质安装到数据存储驱动中之前和期间的错误事件;
2)在数据存储介质成功安装到数据存储驱动中之后的错误事件;
对于所述数据存储驱动和所述数据存储介质的每个所述类别实施所述跟踪、比较和放置步骤,
其中所述连续错误事件的链的打断只应用于所述完整成功操作所属于的错误事件的类别。
3.根据权利要求2的方法,还包括:
分开累计在一个时间周期上每个所述类别中关于个体数据存储驱动和关于个体数据存储介质的被选错误事件;
把类别中的数据存储驱动和数据存储介质中至少一个的所述累计错误事件数目与门限值进行比较;以及
一旦所述类别中的所述累计错误事件的所述数目达到所述门限值,就把所述数据存储驱动和所述数据存储介质中的所述至少一个放置在故障类别中。
4.根据权利要求3的方法,还包括:
如果错误事件彼此相关,则降低所述错误事件在所述被选错误事件的所述连续中以及所述累计之中的权重。
5.根据权利要求1的方法,还包括:
如果数据存储驱动从所述子系统中被移除,则清除在所述被移除数据存储驱动处发生的数据存储介质的所述错误事件。
6.根据权利要求5的方法,还包括:
如果数据存储驱动从所述子系统中被移除并被返回,则清除所述被移除并被返回的数据存储驱动的所述错误事件。
7.权利要求1的方法,还包括:
如果数据存储介质从所述子系统中被移除,则清除在所述数据存储驱动处发生的关于所述被移除数据存储介质的数据存储驱动的所述错误事件。
8.根据权利要求7的方法,还包括:
如果数据存储介质从所述子系统中被移除并被返回,则清除所述被移除并被返回的数据存储介质的所述错误事件。
9.根据权利要求1的方法,还包括:
把相关错误减少成单个所述被选错误事件。
10.根据权利要求1的方法,还包括:
在数据库中存储与所述被选错误事件相关的信息,其中所述被选错误事件与数据存储介质和数据存储驱动都相关,所述信息描述了所述数据存储介质和所述数据存储驱动以及所述被选错误事件。
11.一种自动数据存储库子系统中的库控制器,其中所述自动数据存储库子系统包括:
存储架,被配置成存储数据存储介质;
多个数据存储驱动,被配置成安装、卸下数据存储介质、以及对于数据存储介质进行数据写入和读取;
至少一个自动机存取器,被配置成在所述存储架和所述数据存储驱动之间传送数据存储介质;以及
所述库控制器包括:
用于检测涉及数据存储驱动的被选错误事件的发生的装置;
用于把所述错误事件分类为:
1)在数据存储介质安装到数据存储驱动中之前和期间的错误事件;
2)在数据存储介质成功安装到数据存储驱动中之后的错误事件的装置;
用于分开跟踪每个所述类别中的个体数据存储驱动的连续错误事件的装置,其中所述数据存储驱动的完整的成功操作打断了所述连续错误事件的链,其中所述连续错误事件的链的打断只应用于所述完整成功操作所属于的错误事件的类别;
用于把类别中的数据存储驱动的所述连续错误事件的数目与门限值进行比较的装置;以及
用于一旦所述连续错误事件的所述数目达到所述门限值,就把所述数据存储驱动放置在故障类别中的装置。
12.根据权利要求11的库控制器,其中所述库控制器还包括:
用于检测涉及数据存储介质的被选错误事件的发生的装置;
用于把涉及所述数据存储介质的所述错误事件分类为:
1)在数据存储介质安装到数据存储驱动中之前和期间的错误事件;
2)在数据存储介质成功安装到数据存储驱动中之后的错误事件的装置;
用于分开跟踪每个所述类别中的个体数据存储介质的连续错误事件的装置,其中所述数据存储介质相对于数据存储驱动的完整的成功操作打断了所述连续错误事件的链,其中所述连续错误事件的链的打断只应用于所述完整成功操作所属于的错误事件的类别;
用于把类别中的数据存储介质的所述连续错误事件的数目与门限值进行比较的装置;以及
用于一旦所述连续错误事件的所述数目达到所述门限值,就把所述数据存储介质放置在故障类别中的装置。
13.根据权利要求12的库控制器,其中所述库控制器还包括:
用于分开累计在一个时间周期上在所述类别中关于个体数据存储驱动和关于个体数据存储介质的被选错误事件的装置;
用于把数据存储驱动和数据存储介质中的至少一个的所述累计错误事件数目与门限值进行比较的装置;以及
用于一旦所述累计错误事件的所述数目达到所述门限值,就把所述数据存储驱动和所述数据存储介质中的所述至少一个放置在故障类别中的装置。
14.根据权利要求13的库控制器,其中所述库控制器还包括:
用于如果错误事件彼此相关,则降低所述错误事件在所述被选错误事件的所述连续之中以及所述累计之中的权重的装置。
15.根据权利要求12的库控制器,其中所述库控制器还包括:
用于如果数据存储驱动从所述子系统中被移除,则清除在所述被移除数据存储驱动处发生的数据存储介质的所述错误事件的装置。
16.根据权利要求15的库控制器,其中所述库控制器还包括:
用于如果数据存储驱动从所述子系统中被移除并被返回,则清除所述被移除并被返回的数据存储驱动的所述错误事件的装置。
17.根据权利要求12的库控制器,其中所述库控制器还包括:
用于如果数据存储介质从所述子系统中被移除,则清除在所述数据存储驱动处发生的关于所述被移除数据存储介质的数据存储驱动的所述错误事件的装置。
18.根据权利要求17的库控制器,其中所述库控制器还包括:
用于如果数据存储介质从所述子系统中被移除并被返回,则清除所述被移除并被返回的数据存储介质的所述错误事件的装置。
19.根据权利要求12的库控制器,其中所述库控制器还包括:
用于把相关错误减少成单个所述被选错误事件的装置。
20.根据权利要求12的库控制器,其中所述库控制器还包括:
用于在数据库中存储与所述被选错误事件相关的信息的装置,其中所述被选错误事件与数据存储介质和数据存储驱动都相关,所述信息描述了所述数据存储介质和所述数据存储驱动以及所述被选错误事件。
21.一种自动数据存储库子系统中的库控制器,其中所述自动数据存储库子系统包括:
存储架,被配置成存储数据存储介质;
多个数据存储驱动,被配置成安装、卸下数据存储介质、以及对于数据存储介质进行数据写入和读取;
至少一个自动机存取器,被配置成在所述存储架和所述数据存储驱动之间传送数据存储介质;以及
所述库控制器包括:
用于检测涉及数据存储介质的被选错误事件和涉及数据存储驱动的被选错误事件的发生的装置;
用于一旦被选错误事件涉及数据存储介质,就尝试把所述数据存储介质移到另一数据存储驱动以阻止重试过程,并实施与导致所述被选错误事件的操作类似的操作的装置;
用于分开跟踪个体数据存储驱动的连续错误事件的装置,其中所述数据存储驱动中至少一个的完整成功操作打断了所述连续错误事件的链,对于所述成功,所述数据存储驱动中至少一个具有所述连续错误事件的链;
用于把数据存储驱动的所述连续错误事件的数目与门限值进行比较的装置;
用于一旦所述连续错误事件的所述数目达到所述门限值,就把所述数据存储驱动放置在故障类别中的装置;
用于分开跟踪个体数据存储介质的连续错误事件的装置,其中所述数据存储介质的完整成功操作打断了所述连续错误事件的链,对于所述成功,所述数据存储介质具有所述连续错误事件的链;
用于把数据存储介质的所述连续错误事件的数目与门限值进行比较的装置;以及
用于一旦所述连续错误事件的所述数目达到所述门限值,就把所述数据存储介质放置在故障类别中的装置。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/535,238 US7627786B2 (en) | 2006-09-26 | 2006-09-26 | Tracking error events relating to data storage drives and/or media of automated data storage library subsystems |
US11/535,238 | 2006-09-26 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN101154410A CN101154410A (zh) | 2008-04-02 |
CN101154410B true CN101154410B (zh) | 2011-07-20 |
Family
ID=39226441
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN2007101477094A Expired - Fee Related CN101154410B (zh) | 2006-09-26 | 2007-08-24 | 在自动数据存储库子系统中的方法和库控制器 |
Country Status (2)
Country | Link |
---|---|
US (1) | US7627786B2 (zh) |
CN (1) | CN101154410B (zh) |
Families Citing this family (233)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8832495B2 (en) | 2007-05-11 | 2014-09-09 | Kip Cr P1 Lp | Method and system for non-intrusive monitoring of library components |
US8650241B2 (en) * | 2008-02-01 | 2014-02-11 | Kip Cr P1 Lp | System and method for identifying failing drives or media in media library |
US9015005B1 (en) * | 2008-02-04 | 2015-04-21 | Kip Cr P1 Lp | Determining, displaying, and using tape drive session information |
US7974215B1 (en) | 2008-02-04 | 2011-07-05 | Crossroads Systems, Inc. | System and method of network diagnosis |
US8645328B2 (en) | 2008-02-04 | 2014-02-04 | Kip Cr P1 Lp | System and method for archive verification |
US9866633B1 (en) | 2009-09-25 | 2018-01-09 | Kip Cr P1 Lp | System and method for eliminating performance impact of information collection from media drives |
US8843787B1 (en) | 2009-12-16 | 2014-09-23 | Kip Cr P1 Lp | System and method for archive verification according to policies |
US8775868B2 (en) | 2010-09-28 | 2014-07-08 | Pure Storage, Inc. | Adaptive RAID for an SSD environment |
US9244769B2 (en) | 2010-09-28 | 2016-01-26 | Pure Storage, Inc. | Offset protection data in a RAID array |
JP5785455B2 (ja) | 2011-07-29 | 2015-09-30 | インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation | リムーバブルメディアに関する処理を行う装置及び方法 |
US8780471B2 (en) * | 2011-10-27 | 2014-07-15 | Hewlett-Packard Development Company, L.P. | Linking errors to particular tapes or particular tape drives |
US9043573B2 (en) * | 2012-06-07 | 2015-05-26 | Netapp, Inc. | System and method for determining a level of success of operations on an abstraction of multiple logical data storage containers |
US9311176B1 (en) * | 2012-11-20 | 2016-04-12 | Emc Corporation | Evaluating a set of storage devices and providing recommended activities |
JP2014130475A (ja) * | 2012-12-28 | 2014-07-10 | Fujitsu Ltd | ライブラリ装置、制御方法、及びプログラム |
US9063967B2 (en) | 2013-01-10 | 2015-06-23 | Pure Storage, Inc. | Performing copies in a storage system |
JP6163855B2 (ja) | 2013-04-30 | 2017-07-19 | 富士通株式会社 | ストレージシステム、制御装置、制御プログラムおよび制御方法 |
US11630585B1 (en) | 2016-08-25 | 2023-04-18 | Pure Storage, Inc. | Processing evacuation events in a storage array that includes a plurality of storage devices |
US9443616B2 (en) * | 2014-04-02 | 2016-09-13 | Seagate Technology Llc | Bad memory unit detection in a solid state drive |
CN105094684B (zh) * | 2014-04-24 | 2018-03-09 | 国际商业机器公司 | 磁盘阵列系统中问题磁盘的重用方法和系统 |
US9489132B2 (en) | 2014-10-07 | 2016-11-08 | Pure Storage, Inc. | Utilizing unmapped and unknown states in a replicated storage system |
US9552247B2 (en) * | 2014-11-05 | 2017-01-24 | Dell Products, Lp | Method for detection of soft media errors for hard drive |
US11102298B1 (en) | 2015-05-26 | 2021-08-24 | Pure Storage, Inc. | Locally providing cloud storage services for fleet management |
US9716755B2 (en) | 2015-05-26 | 2017-07-25 | Pure Storage, Inc. | Providing cloud storage array services by a local storage array in a data center |
US9594678B1 (en) | 2015-05-27 | 2017-03-14 | Pure Storage, Inc. | Preventing duplicate entries of identical data in a storage device |
US9444822B1 (en) | 2015-05-29 | 2016-09-13 | Pure Storage, Inc. | Storage array access control from cloud-based user authorization and authentication |
US9300660B1 (en) | 2015-05-29 | 2016-03-29 | Pure Storage, Inc. | Providing authorization and authentication in a cloud for a user of a storage array |
US10021170B2 (en) | 2015-05-29 | 2018-07-10 | Pure Storage, Inc. | Managing a storage array using client-side services |
US11503031B1 (en) | 2015-05-29 | 2022-11-15 | Pure Storage, Inc. | Storage array access control from cloud-based user authorization and authentication |
US9588691B2 (en) | 2015-06-10 | 2017-03-07 | Pure Storage, Inc. | Dynamically managing control information in a storage device |
US9594512B1 (en) | 2015-06-19 | 2017-03-14 | Pure Storage, Inc. | Attributing consumed storage capacity among entities storing data in a storage array |
US10310740B2 (en) | 2015-06-23 | 2019-06-04 | Pure Storage, Inc. | Aligning memory access operations to a geometry of a storage device |
US10296236B2 (en) | 2015-07-01 | 2019-05-21 | Pure Storage, Inc. | Offloading device management responsibilities from a storage device in an array of storage devices |
US9892071B2 (en) | 2015-08-03 | 2018-02-13 | Pure Storage, Inc. | Emulating a remote direct memory access (‘RDMA’) link between controllers in a storage array |
US9851762B1 (en) | 2015-08-06 | 2017-12-26 | Pure Storage, Inc. | Compliant printed circuit board (‘PCB’) within an enclosure |
US10198194B2 (en) | 2015-08-24 | 2019-02-05 | Pure Storage, Inc. | Placing data within a storage device of a flash array |
US11294588B1 (en) | 2015-08-24 | 2022-04-05 | Pure Storage, Inc. | Placing data within a storage device |
US11625181B1 (en) | 2015-08-24 | 2023-04-11 | Pure Storage, Inc. | Data tiering using snapshots |
US10514978B1 (en) * | 2015-10-23 | 2019-12-24 | Pure Storage, Inc. | Automatic deployment of corrective measures for storage arrays |
US9384082B1 (en) * | 2015-10-23 | 2016-07-05 | Pure Storage, Inc. | Proactively providing corrective measures for storage arrays |
US11360844B1 (en) | 2015-10-23 | 2022-06-14 | Pure Storage, Inc. | Recovery of a container storage provider |
US10284232B2 (en) | 2015-10-28 | 2019-05-07 | Pure Storage, Inc. | Dynamic error processing in a storage device |
US10374868B2 (en) | 2015-10-29 | 2019-08-06 | Pure Storage, Inc. | Distributed command processing in a flash storage system |
US9740414B2 (en) | 2015-10-29 | 2017-08-22 | Pure Storage, Inc. | Optimizing copy operations |
US10353777B2 (en) | 2015-10-30 | 2019-07-16 | Pure Storage, Inc. | Ensuring crash-safe forward progress of a system configuration update |
US11762764B1 (en) | 2015-12-02 | 2023-09-19 | Pure Storage, Inc. | Writing data in a storage system that includes a first type of storage device and a second type of storage device |
US9760479B2 (en) | 2015-12-02 | 2017-09-12 | Pure Storage, Inc. | Writing data in a storage system that includes a first type of storage device and a second type of storage device |
US11616834B2 (en) | 2015-12-08 | 2023-03-28 | Pure Storage, Inc. | Efficient replication of a dataset to the cloud |
US10326836B2 (en) | 2015-12-08 | 2019-06-18 | Pure Storage, Inc. | Partially replicating a snapshot between storage systems |
US10162835B2 (en) | 2015-12-15 | 2018-12-25 | Pure Storage, Inc. | Proactive management of a plurality of storage arrays in a multi-array system |
US11347697B1 (en) | 2015-12-15 | 2022-05-31 | Pure Storage, Inc. | Proactively optimizing a storage system |
US10346043B2 (en) | 2015-12-28 | 2019-07-09 | Pure Storage, Inc. | Adaptive computing for data compression |
US9886314B2 (en) | 2016-01-28 | 2018-02-06 | Pure Storage, Inc. | Placing workloads in a multi-array system |
US10572460B2 (en) | 2016-02-11 | 2020-02-25 | Pure Storage, Inc. | Compressing data in dependence upon characteristics of a storage system |
US9760297B2 (en) | 2016-02-12 | 2017-09-12 | Pure Storage, Inc. | Managing input/output (‘I/O’) queues in a data storage system |
US9959043B2 (en) | 2016-03-16 | 2018-05-01 | Pure Storage, Inc. | Performing a non-disruptive upgrade of data in a storage system |
US11995315B2 (en) | 2016-03-16 | 2024-05-28 | Pure Storage, Inc. | Converting data formats in a storage system |
US11112990B1 (en) | 2016-04-27 | 2021-09-07 | Pure Storage, Inc. | Managing storage device evacuation |
US9841921B2 (en) | 2016-04-27 | 2017-12-12 | Pure Storage, Inc. | Migrating data in a storage array that includes a plurality of storage devices |
US11809727B1 (en) | 2016-04-27 | 2023-11-07 | Pure Storage, Inc. | Predicting failures in a storage system that includes a plurality of storage devices |
US9811264B1 (en) | 2016-04-28 | 2017-11-07 | Pure Storage, Inc. | Deploying client-specific applications in a storage system utilizing redundant system resources |
US10303390B1 (en) | 2016-05-02 | 2019-05-28 | Pure Storage, Inc. | Resolving fingerprint collisions in flash storage system |
US11231858B2 (en) | 2016-05-19 | 2022-01-25 | Pure Storage, Inc. | Dynamically configuring a storage system to facilitate independent scaling of resources |
US9507532B1 (en) | 2016-05-20 | 2016-11-29 | Pure Storage, Inc. | Migrating data in a storage array that includes a plurality of storage devices and a plurality of write buffer devices |
US10691567B2 (en) | 2016-06-03 | 2020-06-23 | Pure Storage, Inc. | Dynamically forming a failure domain in a storage system that includes a plurality of blades |
US10452310B1 (en) | 2016-07-13 | 2019-10-22 | Pure Storage, Inc. | Validating cabling for storage component admission to a storage array |
US11706895B2 (en) | 2016-07-19 | 2023-07-18 | Pure Storage, Inc. | Independent scaling of compute resources and storage resources in a storage system |
US10459652B2 (en) | 2016-07-27 | 2019-10-29 | Pure Storage, Inc. | Evacuating blades in a storage array that includes a plurality of blades |
US10474363B1 (en) | 2016-07-29 | 2019-11-12 | Pure Storage, Inc. | Space reporting in a storage system |
US11481261B1 (en) | 2016-09-07 | 2022-10-25 | Pure Storage, Inc. | Preventing extended latency in a storage system |
US10235229B1 (en) | 2016-09-07 | 2019-03-19 | Pure Storage, Inc. | Rehabilitating storage devices in a storage array that includes a plurality of storage devices |
US11531577B1 (en) | 2016-09-07 | 2022-12-20 | Pure Storage, Inc. | Temporarily limiting access to a storage device |
US10146585B2 (en) | 2016-09-07 | 2018-12-04 | Pure Storage, Inc. | Ensuring the fair utilization of system resources using workload based, time-independent scheduling |
US10908966B1 (en) | 2016-09-07 | 2021-02-02 | Pure Storage, Inc. | Adapting target service times in a storage system |
US11960348B2 (en) | 2016-09-07 | 2024-04-16 | Pure Storage, Inc. | Cloud-based monitoring of hardware components in a fleet of storage systems |
US10331588B2 (en) | 2016-09-07 | 2019-06-25 | Pure Storage, Inc. | Ensuring the appropriate utilization of system resources using weighted workload based, time-independent scheduling |
US11886922B2 (en) | 2016-09-07 | 2024-01-30 | Pure Storage, Inc. | Scheduling input/output operations for a storage system |
US10671439B1 (en) | 2016-09-07 | 2020-06-02 | Pure Storage, Inc. | Workload planning with quality-of-service (‘QOS’) integration |
US11379132B1 (en) | 2016-10-20 | 2022-07-05 | Pure Storage, Inc. | Correlating medical sensor data |
US10007459B2 (en) | 2016-10-20 | 2018-06-26 | Pure Storage, Inc. | Performance tuning in a storage system that includes one or more storage devices |
US11620075B2 (en) | 2016-11-22 | 2023-04-04 | Pure Storage, Inc. | Providing application aware storage |
US10162566B2 (en) | 2016-11-22 | 2018-12-25 | Pure Storage, Inc. | Accumulating application-level statistics in a storage system |
US10198205B1 (en) | 2016-12-19 | 2019-02-05 | Pure Storage, Inc. | Dynamically adjusting a number of storage devices utilized to simultaneously service write operations |
US11461273B1 (en) | 2016-12-20 | 2022-10-04 | Pure Storage, Inc. | Modifying storage distribution in a storage system that includes one or more storage devices |
US10452468B2 (en) * | 2016-12-30 | 2019-10-22 | Western Digital Technologies, Inc. | Method and system for managing non-volatile memory |
US10489307B2 (en) | 2017-01-05 | 2019-11-26 | Pure Storage, Inc. | Periodically re-encrypting user data stored on a storage device |
US11307998B2 (en) | 2017-01-09 | 2022-04-19 | Pure Storage, Inc. | Storage efficiency of encrypted host system data |
US11340800B1 (en) | 2017-01-19 | 2022-05-24 | Pure Storage, Inc. | Content masking in a storage system |
US10503700B1 (en) | 2017-01-19 | 2019-12-10 | Pure Storage, Inc. | On-demand content filtering of snapshots within a storage system |
US11163624B2 (en) | 2017-01-27 | 2021-11-02 | Pure Storage, Inc. | Dynamically adjusting an amount of log data generated for a storage system |
US11803453B1 (en) | 2017-03-10 | 2023-10-31 | Pure Storage, Inc. | Using host connectivity states to avoid queuing I/O requests |
US10454810B1 (en) | 2017-03-10 | 2019-10-22 | Pure Storage, Inc. | Managing host definitions across a plurality of storage systems |
US12056383B2 (en) | 2017-03-10 | 2024-08-06 | Pure Storage, Inc. | Edge management service |
US11169727B1 (en) | 2017-03-10 | 2021-11-09 | Pure Storage, Inc. | Synchronous replication between storage systems with virtualized storage |
US11442825B2 (en) | 2017-03-10 | 2022-09-13 | Pure Storage, Inc. | Establishing a synchronous replication relationship between two or more storage systems |
US11675520B2 (en) | 2017-03-10 | 2023-06-13 | Pure Storage, Inc. | Application replication among storage systems synchronously replicating a dataset |
US10521344B1 (en) | 2017-03-10 | 2019-12-31 | Pure Storage, Inc. | Servicing input/output (‘I/O’) operations directed to a dataset that is synchronized across a plurality of storage systems |
US11089105B1 (en) | 2017-12-14 | 2021-08-10 | Pure Storage, Inc. | Synchronously replicating datasets in cloud-based storage systems |
US11941279B2 (en) | 2017-03-10 | 2024-03-26 | Pure Storage, Inc. | Data path virtualization |
US10503427B2 (en) | 2017-03-10 | 2019-12-10 | Pure Storage, Inc. | Synchronously replicating datasets and other managed objects to cloud-based storage systems |
US9910618B1 (en) | 2017-04-10 | 2018-03-06 | Pure Storage, Inc. | Migrating applications executing on a storage system |
US10459664B1 (en) | 2017-04-10 | 2019-10-29 | Pure Storage, Inc. | Virtualized copy-by-reference |
US11868629B1 (en) | 2017-05-05 | 2024-01-09 | Pure Storage, Inc. | Storage system sizing service |
US11442669B1 (en) | 2018-03-15 | 2022-09-13 | Pure Storage, Inc. | Orchestrating a virtual storage system |
US10789020B2 (en) | 2017-06-12 | 2020-09-29 | Pure Storage, Inc. | Recovering data within a unified storage element |
US11340939B1 (en) | 2017-06-12 | 2022-05-24 | Pure Storage, Inc. | Application-aware analytics for storage systems |
US12086650B2 (en) | 2017-06-12 | 2024-09-10 | Pure Storage, Inc. | Workload placement based on carbon emissions |
US10613791B2 (en) | 2017-06-12 | 2020-04-07 | Pure Storage, Inc. | Portable snapshot replication between storage systems |
US11016824B1 (en) | 2017-06-12 | 2021-05-25 | Pure Storage, Inc. | Event identification with out-of-order reporting in a cloud-based environment |
US11989429B1 (en) | 2017-06-12 | 2024-05-21 | Pure Storage, Inc. | Recommending changes to a storage system |
US12061822B1 (en) | 2017-06-12 | 2024-08-13 | Pure Storage, Inc. | Utilizing volume-level policies in a storage system |
US12086651B2 (en) | 2017-06-12 | 2024-09-10 | Pure Storage, Inc. | Migrating workloads using active disaster recovery |
US11592991B2 (en) | 2017-09-07 | 2023-02-28 | Pure Storage, Inc. | Converting raid data between persistent storage types |
US10417092B2 (en) | 2017-09-07 | 2019-09-17 | Pure Storage, Inc. | Incremental RAID stripe update parity calculation |
US10884636B1 (en) | 2017-06-12 | 2021-01-05 | Pure Storage, Inc. | Presenting workload performance in a storage system |
US10853148B1 (en) | 2017-06-12 | 2020-12-01 | Pure Storage, Inc. | Migrating workloads between a plurality of execution environments |
US11210133B1 (en) | 2017-06-12 | 2021-12-28 | Pure Storage, Inc. | Workload mobility between disparate execution environments |
US11609718B1 (en) | 2017-06-12 | 2023-03-21 | Pure Storage, Inc. | Identifying valid data after a storage system recovery |
EP3612922A1 (en) | 2017-06-12 | 2020-02-26 | Pure Storage, Inc. | Accessible fast durable storage integrated into a bulk storage device |
US10552090B2 (en) | 2017-09-07 | 2020-02-04 | Pure Storage, Inc. | Solid state drives with multiple types of addressable memory |
US10976962B2 (en) | 2018-03-15 | 2021-04-13 | Pure Storage, Inc. | Servicing I/O operations in a cloud-based storage system |
US11422731B1 (en) | 2017-06-12 | 2022-08-23 | Pure Storage, Inc. | Metadata-based replication of a dataset |
US11561714B1 (en) | 2017-07-05 | 2023-01-24 | Pure Storage, Inc. | Storage efficiency driven migration |
US11477280B1 (en) | 2017-07-26 | 2022-10-18 | Pure Storage, Inc. | Integrating cloud storage services |
US10831935B2 (en) | 2017-08-31 | 2020-11-10 | Pure Storage, Inc. | Encryption management with host-side data reduction |
US11861423B1 (en) | 2017-10-19 | 2024-01-02 | Pure Storage, Inc. | Accelerating artificial intelligence (‘AI’) workflows |
US11455168B1 (en) | 2017-10-19 | 2022-09-27 | Pure Storage, Inc. | Batch building for deep learning training workloads |
US10452444B1 (en) | 2017-10-19 | 2019-10-22 | Pure Storage, Inc. | Storage system with compute resources and shared storage resources |
US10671435B1 (en) | 2017-10-19 | 2020-06-02 | Pure Storage, Inc. | Data transformation caching in an artificial intelligence infrastructure |
US12067466B2 (en) | 2017-10-19 | 2024-08-20 | Pure Storage, Inc. | Artificial intelligence and machine learning hyperscale infrastructure |
US11494692B1 (en) | 2018-03-26 | 2022-11-08 | Pure Storage, Inc. | Hyperscale artificial intelligence and machine learning infrastructure |
US10360214B2 (en) | 2017-10-19 | 2019-07-23 | Pure Storage, Inc. | Ensuring reproducibility in an artificial intelligence infrastructure |
US10509581B1 (en) | 2017-11-01 | 2019-12-17 | Pure Storage, Inc. | Maintaining write consistency in a multi-threaded storage system |
US10467107B1 (en) | 2017-11-01 | 2019-11-05 | Pure Storage, Inc. | Maintaining metadata resiliency among storage device failures |
US10671494B1 (en) | 2017-11-01 | 2020-06-02 | Pure Storage, Inc. | Consistent selection of replicated datasets during storage system recovery |
US10817392B1 (en) | 2017-11-01 | 2020-10-27 | Pure Storage, Inc. | Ensuring resiliency to storage device failures in a storage system that includes a plurality of storage devices |
US10484174B1 (en) | 2017-11-01 | 2019-11-19 | Pure Storage, Inc. | Protecting an encryption key for data stored in a storage system that includes a plurality of storage devices |
US10929226B1 (en) | 2017-11-21 | 2021-02-23 | Pure Storage, Inc. | Providing for increased flexibility for large scale parity |
US10936238B2 (en) | 2017-11-28 | 2021-03-02 | Pure Storage, Inc. | Hybrid data tiering |
US10990282B1 (en) | 2017-11-28 | 2021-04-27 | Pure Storage, Inc. | Hybrid data tiering with cloud storage |
US10795598B1 (en) | 2017-12-07 | 2020-10-06 | Pure Storage, Inc. | Volume migration for storage systems synchronously replicating a dataset |
US11036677B1 (en) | 2017-12-14 | 2021-06-15 | Pure Storage, Inc. | Replicated data integrity |
US10929031B2 (en) | 2017-12-21 | 2021-02-23 | Pure Storage, Inc. | Maximizing data reduction in a partially encrypted volume |
KR102413096B1 (ko) * | 2018-01-08 | 2022-06-27 | 삼성전자주식회사 | 전자 장치 및 그 제어 방법 |
US10992533B1 (en) | 2018-01-30 | 2021-04-27 | Pure Storage, Inc. | Policy based path management |
US11972134B2 (en) | 2018-03-05 | 2024-04-30 | Pure Storage, Inc. | Resource utilization using normalized input/output (‘I/O’) operations |
US10521151B1 (en) | 2018-03-05 | 2019-12-31 | Pure Storage, Inc. | Determining effective space utilization in a storage system |
US11150834B1 (en) | 2018-03-05 | 2021-10-19 | Pure Storage, Inc. | Determining storage consumption in a storage system |
US10942650B1 (en) | 2018-03-05 | 2021-03-09 | Pure Storage, Inc. | Reporting capacity utilization in a storage system |
US11861170B2 (en) | 2018-03-05 | 2024-01-02 | Pure Storage, Inc. | Sizing resources for a replication target |
US10296258B1 (en) | 2018-03-09 | 2019-05-21 | Pure Storage, Inc. | Offloading data storage to a decentralized storage network |
US12066900B2 (en) | 2018-03-15 | 2024-08-20 | Pure Storage, Inc. | Managing disaster recovery to cloud computing environment |
US11210009B1 (en) | 2018-03-15 | 2021-12-28 | Pure Storage, Inc. | Staging data in a cloud-based storage system |
US11048590B1 (en) | 2018-03-15 | 2021-06-29 | Pure Storage, Inc. | Data consistency during recovery in a cloud-based storage system |
US11288138B1 (en) | 2018-03-15 | 2022-03-29 | Pure Storage, Inc. | Recovery from a system fault in a cloud-based storage system |
US10924548B1 (en) | 2018-03-15 | 2021-02-16 | Pure Storage, Inc. | Symmetric storage using a cloud-based storage system |
US10917471B1 (en) | 2018-03-15 | 2021-02-09 | Pure Storage, Inc. | Active membership in a cloud-based storage system |
US11171950B1 (en) | 2018-03-21 | 2021-11-09 | Pure Storage, Inc. | Secure cloud-based storage system management |
US11095706B1 (en) | 2018-03-21 | 2021-08-17 | Pure Storage, Inc. | Secure cloud-based storage system management |
US10838833B1 (en) | 2018-03-26 | 2020-11-17 | Pure Storage, Inc. | Providing for high availability in a data analytics pipeline without replicas |
US11436344B1 (en) | 2018-04-24 | 2022-09-06 | Pure Storage, Inc. | Secure encryption in deduplication cluster |
US11392553B1 (en) | 2018-04-24 | 2022-07-19 | Pure Storage, Inc. | Remote data management |
US11954220B2 (en) | 2018-05-21 | 2024-04-09 | Pure Storage, Inc. | Data protection for container storage |
US10992598B2 (en) | 2018-05-21 | 2021-04-27 | Pure Storage, Inc. | Synchronously replicating when a mediation service becomes unavailable |
US11455409B2 (en) | 2018-05-21 | 2022-09-27 | Pure Storage, Inc. | Storage layer data obfuscation |
US12086431B1 (en) | 2018-05-21 | 2024-09-10 | Pure Storage, Inc. | Selective communication protocol layering for synchronous replication |
US11675503B1 (en) | 2018-05-21 | 2023-06-13 | Pure Storage, Inc. | Role-based data access |
US10871922B2 (en) | 2018-05-22 | 2020-12-22 | Pure Storage, Inc. | Integrated storage management between storage systems and container orchestrators |
US11416298B1 (en) | 2018-07-20 | 2022-08-16 | Pure Storage, Inc. | Providing application-specific storage by a storage system |
US11403000B1 (en) | 2018-07-20 | 2022-08-02 | Pure Storage, Inc. | Resiliency in a cloud-based storage system |
US11146564B1 (en) | 2018-07-24 | 2021-10-12 | Pure Storage, Inc. | Login authentication in a cloud storage platform |
US11632360B1 (en) | 2018-07-24 | 2023-04-18 | Pure Storage, Inc. | Remote access to a storage device |
US11954238B1 (en) | 2018-07-24 | 2024-04-09 | Pure Storage, Inc. | Role-based access control for a storage system |
US11860820B1 (en) | 2018-09-11 | 2024-01-02 | Pure Storage, Inc. | Processing data through a storage system in a data pipeline |
US12026381B2 (en) | 2018-10-26 | 2024-07-02 | Pure Storage, Inc. | Preserving identities and policies across replication |
US10671302B1 (en) | 2018-10-26 | 2020-06-02 | Pure Storage, Inc. | Applying a rate limit across a plurality of storage systems |
US11379254B1 (en) | 2018-11-18 | 2022-07-05 | Pure Storage, Inc. | Dynamic configuration of a cloud-based storage system |
US12026061B1 (en) | 2018-11-18 | 2024-07-02 | Pure Storage, Inc. | Restoring a cloud-based storage system to a selected state |
US11526405B1 (en) | 2018-11-18 | 2022-12-13 | Pure Storage, Inc. | Cloud-based disaster recovery |
US11340837B1 (en) | 2018-11-18 | 2022-05-24 | Pure Storage, Inc. | Storage system management via a remote console |
US10963189B1 (en) | 2018-11-18 | 2021-03-30 | Pure Storage, Inc. | Coalescing write operations in a cloud-based storage system |
US12026060B1 (en) | 2018-11-18 | 2024-07-02 | Pure Storage, Inc. | Reverting between codified states in a cloud-based storage system |
US11650749B1 (en) | 2018-12-17 | 2023-05-16 | Pure Storage, Inc. | Controlling access to sensitive data in a shared dataset |
US11003369B1 (en) | 2019-01-14 | 2021-05-11 | Pure Storage, Inc. | Performing a tune-up procedure on a storage device during a boot process |
US11042452B1 (en) | 2019-03-20 | 2021-06-22 | Pure Storage, Inc. | Storage system data recovery using data recovery as a service |
US11221778B1 (en) | 2019-04-02 | 2022-01-11 | Pure Storage, Inc. | Preparing data for deduplication |
US11068162B1 (en) | 2019-04-09 | 2021-07-20 | Pure Storage, Inc. | Storage management in a cloud data store |
US11392555B2 (en) | 2019-05-15 | 2022-07-19 | Pure Storage, Inc. | Cloud-based file services |
US11853266B2 (en) | 2019-05-15 | 2023-12-26 | Pure Storage, Inc. | Providing a file system in a cloud environment |
US11327676B1 (en) | 2019-07-18 | 2022-05-10 | Pure Storage, Inc. | Predictive data streaming in a virtual storage system |
US11126364B2 (en) | 2019-07-18 | 2021-09-21 | Pure Storage, Inc. | Virtual storage system architecture |
US12001355B1 (en) | 2019-05-24 | 2024-06-04 | Pure Storage, Inc. | Chunked memory efficient storage data transfers |
US11093139B1 (en) | 2019-07-18 | 2021-08-17 | Pure Storage, Inc. | Durably storing data within a virtual storage system |
US11861221B1 (en) | 2019-07-18 | 2024-01-02 | Pure Storage, Inc. | Providing scalable and reliable container-based storage services |
US11550514B2 (en) | 2019-07-18 | 2023-01-10 | Pure Storage, Inc. | Efficient transfers between tiers of a virtual storage system |
US11422751B2 (en) | 2019-07-18 | 2022-08-23 | Pure Storage, Inc. | Creating a virtual storage system |
US11487715B1 (en) | 2019-07-18 | 2022-11-01 | Pure Storage, Inc. | Resiliency in a cloud-based storage system |
US11526408B2 (en) | 2019-07-18 | 2022-12-13 | Pure Storage, Inc. | Data recovery in a virtual storage system |
US11086553B1 (en) | 2019-08-28 | 2021-08-10 | Pure Storage, Inc. | Tiering duplicated objects in a cloud-based object store |
US11693713B1 (en) | 2019-09-04 | 2023-07-04 | Pure Storage, Inc. | Self-tuning clusters for resilient microservices |
US11797569B2 (en) | 2019-09-13 | 2023-10-24 | Pure Storage, Inc. | Configurable data replication |
US12045252B2 (en) | 2019-09-13 | 2024-07-23 | Pure Storage, Inc. | Providing quality of service (QoS) for replicating datasets |
US11625416B1 (en) | 2019-09-13 | 2023-04-11 | Pure Storage, Inc. | Uniform model for distinct types of data replication |
US11573864B1 (en) | 2019-09-16 | 2023-02-07 | Pure Storage, Inc. | Automating database management in a storage system |
US11669386B1 (en) | 2019-10-08 | 2023-06-06 | Pure Storage, Inc. | Managing an application's resource stack |
US11868318B1 (en) | 2019-12-06 | 2024-01-09 | Pure Storage, Inc. | End-to-end encryption in a storage system with multi-tenancy |
US11733901B1 (en) | 2020-01-13 | 2023-08-22 | Pure Storage, Inc. | Providing persistent storage to transient cloud computing services |
US11709636B1 (en) | 2020-01-13 | 2023-07-25 | Pure Storage, Inc. | Non-sequential readahead for deep learning training |
US11720497B1 (en) | 2020-01-13 | 2023-08-08 | Pure Storage, Inc. | Inferred nonsequential prefetch based on data access patterns |
US12014065B2 (en) | 2020-02-11 | 2024-06-18 | Pure Storage, Inc. | Multi-cloud orchestration as-a-service |
US11637896B1 (en) | 2020-02-25 | 2023-04-25 | Pure Storage, Inc. | Migrating applications to a cloud-computing environment |
US11868622B2 (en) | 2020-02-25 | 2024-01-09 | Pure Storage, Inc. | Application recovery across storage systems |
US12038881B2 (en) | 2020-03-25 | 2024-07-16 | Pure Storage, Inc. | Replica transitions for file storage |
US11321006B1 (en) | 2020-03-25 | 2022-05-03 | Pure Storage, Inc. | Data loss prevention during transitions from a replication source |
US11630598B1 (en) | 2020-04-06 | 2023-04-18 | Pure Storage, Inc. | Scheduling data replication operations |
US11301152B1 (en) | 2020-04-06 | 2022-04-12 | Pure Storage, Inc. | Intelligently moving data between storage systems |
US11494267B2 (en) | 2020-04-14 | 2022-11-08 | Pure Storage, Inc. | Continuous value data redundancy |
US11921670B1 (en) | 2020-04-20 | 2024-03-05 | Pure Storage, Inc. | Multivariate data backup retention policies |
US11431488B1 (en) | 2020-06-08 | 2022-08-30 | Pure Storage, Inc. | Protecting local key generation using a remote key management service |
US11349917B2 (en) | 2020-07-23 | 2022-05-31 | Pure Storage, Inc. | Replication handling among distinct networks |
US11442652B1 (en) | 2020-07-23 | 2022-09-13 | Pure Storage, Inc. | Replication handling during storage system transportation |
US12079222B1 (en) | 2020-09-04 | 2024-09-03 | Pure Storage, Inc. | Enabling data portability between systems |
US11397545B1 (en) | 2021-01-20 | 2022-07-26 | Pure Storage, Inc. | Emulating persistent reservations in a cloud-based storage system |
US11853285B1 (en) | 2021-01-22 | 2023-12-26 | Pure Storage, Inc. | Blockchain logging of volume-level events in a storage system |
US12086649B2 (en) | 2021-05-12 | 2024-09-10 | Pure Storage, Inc. | Rebalancing in a fleet of storage systems using data science |
US11816129B2 (en) | 2021-06-22 | 2023-11-14 | Pure Storage, Inc. | Generating datasets using approximate baselines |
US11914867B2 (en) | 2021-10-29 | 2024-02-27 | Pure Storage, Inc. | Coordinated snapshots among storage systems implementing a promotion/demotion model |
US11714723B2 (en) | 2021-10-29 | 2023-08-01 | Pure Storage, Inc. | Coordinated snapshots for data stored across distinct storage environments |
US11893263B2 (en) | 2021-10-29 | 2024-02-06 | Pure Storage, Inc. | Coordinated checkpoints among storage systems implementing checkpoint-based replication |
US11922052B2 (en) | 2021-12-15 | 2024-03-05 | Pure Storage, Inc. | Managing links between storage objects |
US11847071B2 (en) | 2021-12-30 | 2023-12-19 | Pure Storage, Inc. | Enabling communication between a single-port device and multiple storage system controllers |
US12001300B2 (en) | 2022-01-04 | 2024-06-04 | Pure Storage, Inc. | Assessing protection for storage resources |
US11860780B2 (en) | 2022-01-28 | 2024-01-02 | Pure Storage, Inc. | Storage cache management |
US11886295B2 (en) | 2022-01-31 | 2024-01-30 | Pure Storage, Inc. | Intra-block error correction |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6023709A (en) * | 1997-12-15 | 2000-02-08 | International Business Machines Corporation | Automated file error classification and correction in a hierarchical storage management system |
JP4535665B2 (ja) * | 2002-05-20 | 2010-09-01 | 日本電気株式会社 | 情報記録装置及びその方法 |
JP2005044357A (ja) * | 2003-07-18 | 2005-02-17 | Quantum Corp | 記憶システム、記憶システムを管理するための方法および記憶システムに診断データを記憶するための方法 |
US7676445B2 (en) * | 2003-08-20 | 2010-03-09 | International Business Machines Corporation | Apparatus, system and method for developing failure prediction software |
US7116506B1 (en) * | 2005-08-18 | 2006-10-03 | International Business Machines Corporation | Automated data storage library magnetic tape diagnostic |
US7461298B2 (en) * | 2005-08-31 | 2008-12-02 | Network Appliance, Inc. | Method and apparatus for diagnosing mass storage device anomalies |
-
2006
- 2006-09-26 US US11/535,238 patent/US7627786B2/en not_active Expired - Fee Related
-
2007
- 2007-08-24 CN CN2007101477094A patent/CN101154410B/zh not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
CN101154410A (zh) | 2008-04-02 |
US7627786B2 (en) | 2009-12-01 |
US20080077825A1 (en) | 2008-03-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101154410B (zh) | 在自动数据存储库子系统中的方法和库控制器 | |
US6338006B1 (en) | Data storage library with efficient cartridge eject | |
CN100481019C (zh) | 预测存储设备故障的装置、系统和方法 | |
US7133966B2 (en) | Disk array device having spare disk drive and data sparing method | |
US6023643A (en) | System for auditing storage cartridges in a library storage system | |
US7200722B2 (en) | Reducing inventory after media access in an automated data storage library | |
US20070174682A1 (en) | Apparatus, system, and method for a storage device's enforcing write recovery of erroneous data | |
CN1917063B (zh) | 自动化数据存储库和用于提供磁带诊断信息的系统和方法 | |
CN1466760A (zh) | 磁盘驱动器的关键事件记录 | |
CN101512650A (zh) | 验证安装在自动数据存储库中的可移动介质卷的身份 | |
US6480905B1 (en) | Data storage library with efficient cartridge insert | |
US6237109B1 (en) | Library unit with spare media and it's computer system | |
US20070174678A1 (en) | Apparatus, system, and method for a storage device's enforcing write recovery of erroneous data | |
US20050229020A1 (en) | Error handling in an embedded system | |
US7516250B2 (en) | Apparatus and method for managing component identifiers in a data storage system | |
US6785588B2 (en) | Method to provide failover protection to a data storage and retrieval system | |
WO1999039347A1 (fr) | Procede de remplacement automatique en cours de lecture et unite de disques magnetiques utilisant ce procede | |
US20050169126A1 (en) | Library for storing and retrieving removable information storage elements | |
US7222140B2 (en) | Method for improving the recovery time from a lost database in a VTS automation system | |
US7484036B2 (en) | Apparatus system and method for managing control path commands in an automated data storage library | |
JP5817498B2 (ja) | 管理システム、管理装置および電子機器の管理方法 | |
US11704040B2 (en) | Transparent drive-to-drive copying | |
JP2880701B2 (ja) | ディスクサブシステム | |
EP0507437A2 (en) | Self-cleaning automated storage library | |
US9336820B2 (en) | Data sector sync mark with multiple patterns |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20110720 |