CN107203329A - 存储管理方法及设备 - Google Patents

存储管理方法及设备 Download PDF

Info

Publication number
CN107203329A
CN107203329A CN201610154144.1A CN201610154144A CN107203329A CN 107203329 A CN107203329 A CN 107203329A CN 201610154144 A CN201610154144 A CN 201610154144A CN 107203329 A CN107203329 A CN 107203329A
Authority
CN
China
Prior art keywords
logic unit
main frame
capacity
group
extension
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201610154144.1A
Other languages
English (en)
Other versions
CN107203329B (zh
Inventor
张波
高雯雯
曹逾
黎明
崔妍
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
EMC Corp
Original Assignee
EMC Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by EMC Corp filed Critical EMC Corp
Priority to CN201610154144.1A priority Critical patent/CN107203329B/zh
Priority to US15/461,753 priority patent/US10936193B2/en
Publication of CN107203329A publication Critical patent/CN107203329A/zh
Application granted granted Critical
Publication of CN107203329B publication Critical patent/CN107203329B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • G06F3/0605Improving or facilitating administration, e.g. storage management by facilitating the interaction with a user or administrator
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • G06F3/0607Improving or facilitating administration, e.g. storage management by facilitating the process of upgrading existing storage systems, e.g. for improving compatibility between host and storage device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0629Configuration or reconfiguration of storage systems
    • G06F3/0635Configuration or reconfiguration of storage systems by changing the path, e.g. traffic rerouting, path reconfiguration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/067Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • G06F3/0689Disk arrays, e.g. RAID, JBOD

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本公开的实施例公开了一种存储管理方法及设备。该方法包括:从主机接收存储创建请求,存储创建请求指定主机期望的目标容量;为主机创建具有目标容量的第一组逻辑单元;将第一组逻辑单元与物理存储关联,以供主机使用;以及为主机创建具有超出目标容量的第一附加容量的第二组逻辑单元,而不将第二组逻辑单元与物理存储关联。本公开的实施例还公开了相应的设备。

Description

存储管理方法及设备
技术领域
本公开的实施例总体上涉及数据存储技术领域,并且具体地,涉及一种存储管理方法及设备。
背景技术
当今对数据处理和应用的需求不断增长,人们需要及产生的数据量显著增加。现在人们已认识到存储管理的重要性,对存储系统中的数据的管理不仅体现在应用层的管理,还体现在存储系统本身的管理。一方面,数据存储系统必须要有足够的存储容量以满足不断增长的数据量。另一方面,还需要能够提供更优化的存储管理技术。例如,随着各种应用的业务需求的不断增加,需要对应用存储容量不断扩展,这就要求存储系统能够根据应用需要提供操作简捷、实现快速并且应用不被中断的容量扩展技术。
发明内容
总体上,本公开的实施例通过预分配方式提供一种优化存储管理的解决方案。
根据本公开的第一方面,提供一种存储管理方法。该方法包括:从主机接收存储创建请求,存储创建请求指定主机期望的目标容量;为主机创建具有目标容量的第一组逻辑单元;将第一组逻辑单元与物理存储关联,以供主机使用;以及为主机创建具有超出目标容量的第一附加容量的第二组逻辑单元,而不将第二组逻辑单元与物理存储关联。
在某些实施例中,该方法进一步包括:从主机接收存储扩展请求,存储扩展请求指定主机期望的扩展容量;以及响应于存储扩展请求,至少部分地基于第二组逻辑单元,将扩展容量扩展给主机。
在某些实施例中,该扩展包括:响应于确定第一附加容量大于或等于扩展容量,从第二组逻辑单元中选择对应于扩展容量的逻辑单元;以及将选择的逻辑单元与物理存储关联,以供主机使用。
在某些实施例中,该扩展包括:响应于确定第一附加容量小于扩展容量,基于扩展容量与第一附加容量之间的差量,为主机创建第三组逻辑单元;以及将第三组逻辑单元与物理存储关联,以供主机使用。
在某些实施例中,该扩展进一步包括:为主机创建具有超出扩展容量的第二附加容量的第四组逻辑单元,而不将第四组逻辑单元与物理存储关联。
在某些实施例中,该方法进一步包括:从主机接收存储移除请求;以及响应于移除请求涉及目前与物理存储关联的所有逻辑单元,移除目前与物理存储关联的逻辑单元,以及移除第二组逻辑单元中尚未与物理存储关联的逻辑单元。
根据本公开的第二方面,提供一种存储管理设备,包括:至少一个处理器;以及包含计算机程序代码的至少一个存储器,至少一个存储器和计算机程序代码被配置成利用至少一个处理器而使得设备至少执行以下操作:从主机接收存储创建请求,存储创建请求指定主机期望的目标容量;为主机创建具有目标容量的第一组逻辑单元;将第一组逻辑单元与物理存储关联,以供主机使用;以及为主机创建具有超出目标容量的第一附加容量的第二组逻辑单元,而不将第二组逻辑单元与物理存储关联。
根据本公开的第三方面,提供一种存储管理装置,包括:接收单元,被配置成从主机接收存储创建请求,该存储创建请求指定主机期望的目标容量;创建单元,被配置成为主机创建具有目标容量的第一组逻辑单元,将第一组逻辑单元与物理存储关联,以供主机使用,并且为主机创建具有超出目标容量的第一附加容量的第二组逻辑单元,而不将第二组逻辑单元与物理存储关联。
根据本公开的第四方面,提供一种计算机可读存储介质,具有存储在其上的计算机可读程序指令,计算机可读程序指令用于执行根据本公开的第一方面提供的方法。
本公开的实施例能够提供安全、快速的存储容量扩展,并且预分配的逻辑单元并不占用物理存储空间,不会造成存储容量浪费。
附图说明
结合附图并参考以下详细说明,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。在附图中,相同或相似的附图标记表示相同或相似的元素,其中:
图1图示本公开的实施例可应用于其中的存储环境示意图;
图2图示根据本公开的实施例的存储环境示意图;
图3示出根据本公开的实施例的存储管理方法的流程图;
图4图示定义预分配逻辑单元的示意图;
图5图示配置主机的预分配逻辑单元的示意图;
图6示出根据本公开的实施例的扩展容量方法的流程图;
图7示出根据本公开的实施例的移除容量方法的流程图;
图8图示根据本公开的实施例的存储管理器示意图;以及
图9图示根据本公开的实施例的存储管理设备示意图。
具体实施方式
现将结合附图对本公开的实施例进行具体的描述。应当注意的是,附图中对相似的部件或者功能组件可能使用同样的数字标示。所附附图仅仅旨在说明本公开的实施例。本领域的技术人员可以在不偏离本公开精神和保护范围的基础上从下述描述得到替代的实施方式。
如本文中所述,术语“包括”及其各种变体可以被理解为开放式术语,其意味着“包括但不限于”。术语“基于”可以被理解为“至少部分地基于”。术语“一个实施例”可以被理解为“至少一个实施例”。术语“另一实施例”可以被理解为“至少一个其它实施例”。
图1图示了本公开的实施例可应用于其中的存储环境100。在某些实施例中,存储环境100例如可以基于存储区域网络(SAN)架构而建立。如图所示,存储环境100包括一个或多个主机102、存储管理器104和物理存储108。
主机102可以是任何适当的电子设备,其可以在存储管理器104的控制下实现数据在物理存储108上的存储。物理存储108可以包括一个或多个物理存储设备。物理存储设备的示例包括但不限于:固态盘(SSD)、光纤通道(FC)盘、串行高级技术附件(SATA)盘、串行连接小型计算机系统接口(SAS)盘等。在某些实施例中,物理存储108可以被配置为独立磁盘冗余阵列(RAID)。
存储管理器104对存储环境100进行管理。在某些实施例中,存储管理器104可以实现在主机102上的操作系统(OS)或管理程序(hypervisor)的一部分。特别地,在一个实施例中,存储管理器104可以实现为软件定义存储(Software Defined Storage,SDS)。例如,在本公开的实施例中,存储管理器104可以对物理存储108中的存储设备、主机102、光纤通道交换机(未示出)等进行配置和管理。光纤通道交换机被连接在连接主机102与物理存储108之间,为主机102提供对物理存储108的存储设备的网络访问能力和光纤通道切换功能,以实现数据传输和数据共享。
除其他功能之外,存储管理器104可以基于物理存储108所提供的物理存储空间向主机102提供虚拟存储。为此,存储管理器104以逻辑单元(Logical Unit)为单位向主机102分配和管理存储空间。每个逻辑单元可以具有唯一的逻辑单元编码(Logical Unit Number,LUN)。在本公开的上下文中,术语“逻辑单元”和“逻辑单元编号”可以互换使用以利于讨论。以此方式,从主机102的角度看,存储空间是LUN组成的存储池106。主机102可以使用这些LUN对物理存储108中存储的数据进行操作。
在传统方案中,从存储池106中分配给主机102的所有LUN都与物理存储108实际地关联。在这种情况下,当需要为一个主机102扩展存储空间的容量时,要根据扩展容量创建新的逻辑单元。而后将创建的新逻辑单元与磁盘阵列的物理存储关联。新创建的逻辑单元被添加到现有的磁盘阵列掩码(masking)中,以将主机102与其逻辑单元及磁盘阵列的端口进行关联。这样,在通过光纤通道交换机访问物理存储时,主机102能够正确识别其逻辑单元。此外,还可能需要修改交换中的现有分区,实现设备之间的相互隔离,在主机102上重新扫描和挂载新逻辑单元,以及在主机102上格式化以及使用新逻辑单元,等等。
上述过程影响主机102的正常运行。例如,区域的修改通常发生在若干个光纤通道交换机上,而这些交换机由若干个主机和磁盘阵列所共享。因此,频繁地改变配置可能导致更新失败以及配置错误,这将影响所有连接到这些交换机的主机和磁盘阵列。同时,改变磁盘阵列的掩码将导致正在运行的应用的服务质量(QoS)下降。为了避免这种问题,不得不借助于人类用户来核查上述操作过程并评估风险。在此期间,不可避免地应用和服务的QoS将下降甚至服务中断,而且导致大量的时间和人类成本开销。
根据本公开的实施例,提供了优化容量扩展过程以及最小化所需要的配置修改的解决方案,以降低扩容的潜在失败风险并简化相应的操作。一般而言,为了避免在容量扩展期间对多个设备在不同层中的频繁修改,在主机102请求存储空间时,存储管理器104在主机102实际需求的存储容量以外,为其额外提供附加存储容量,以满足潜在的扩容需求。
如图2所示,响应于主机102创建存储空间的请求,存储管理器104从存储池106中为主机102分配两组逻辑单元。第一组逻辑单元210的容量是主机102所期望或者请求的容量。另外,存储管理器104还为主机102分配额外的第二组逻辑单元212,其提供主机102当前并未请求、但是被预测为可能在将来需要扩展的容量。特别地,根据本公开的实施例,在创建阶段,只有第一组逻辑单元210与物理存储108实际地关联;而第二组存储单元212并不与物理存储108进行关联。也就是说,主机102当前所需容量的逻辑单元与物理存储“绑定”;而为主机102额外提供的那部分逻辑单元与物理存储保持“未绑定”。
下面结合图3对图2中所图示的实施例进行具体描述。图3示出了根据本公开的实施例的存储管理方法300流程图。图3中所示的方法300例如可由图2中所示的存储管理器104来执行。
在步骤302,从主机102接收存储创建请求。该存储创建请求指定主机102所期望的目标容量。换言之,目标容量为主机当前所实际需求的容量。
接下来,在步骤304,为主机102创建具有目标容量的第一组逻辑单元210。为此,可以根据每个逻辑单元的大小以及步骤302的请求中所指定的目标容量,来确定第一组逻辑单元210中所需要的逻辑单元的数目。备选地,在另一些实施例中,主机102也可以直接在创建请求中指明期望使用的逻辑单元的数目。在步骤306,将第一组逻辑单元210与物理存储108关联以供主机使用。也就是说,在步骤306,为第一组逻辑单元210实际分配了物理存储空间,这一部分将可以提供给主机使用。具体实现取决于各种物理存储设备108的具体结构。在例如RAID阵列的存储系统中,可以例如将RAID阵列的存储资源与第一组逻辑单元210的每个LUN的元数据进行关联。
方法300进行到步骤308,在此为主机102创建具有超出目标容量的第一附加容量的第二组逻辑单元212。第二组逻辑单元212所包含的附加容量的大小可以是预先确定的,可以根据主机102上运行的应用的特性而确定,可以根据主机102过往的存储空间使用情况而确定,等等。
根据本公开的实施例,如上所述,在步骤308创建的第二组逻辑单元212并不与物理存储108实际关联。也就是说,尽管从主机102的角度看第二组逻辑单元212已经分配,但是该第二组逻辑单元212并不占用实际物理存储空间,而仅仅是预分配的逻辑单元的位置预留,并不产生存储容量的浪费。在某些实施例中,可以例如诸如指针之类的数据结构来记录第二组逻辑单元212的预分配。
需要说明的是,尽管以上以顺序执行描述了操作,但是上述步骤304、306以及308的执行顺序并不需要以上述特定顺序执行,例如可以多任务或并行地处理304与308中的创建操作以及与物理存储的关联相关的操作等。另外,在步骤308之前,还可以先检查针对该主机是否启用了预分配逻辑单元这一特性,如果启用了该特性,则执行步骤308,否则仅分配所请求的逻辑单元即第一组逻辑单元210,对其进行操作,而不进行预分配逻辑单元的相关操作。
对于用户而言,可以简单地通过对各主机的配置操作来完成各主机的存储创建。在本公开的一个实施例中,图4和图5图示了配置示意。需要注意的是,图4和图5仅是图示对于预分配的逻辑单元(即第二组逻辑单元212)的配置操作,对于实际分配物理存储空间的逻辑单元组(即第一组逻辑单元210)的操作可以类似或者根据现有实现不做变化。另外,需要注意的是,从用户的角度来看,主机102可见的逻辑单元可以表现为与逻辑单元或LUN相对应的卷(Volume),这种呈现依赖于存储环境中用户对存储空间的抽象定义。因此,用户所操作的逻辑单元可以有不同的表现形式,但其不脱离在本公开的实施例中对相应的逻辑单元的操作的精神和本质。
图4图示了针对为主机102定义预分配逻辑单元组的用户界面(UI)400的示意图。用户可以根据主机102上的应用需求,为每个主机102定义具有逻辑单元组名称、逻辑单元大小和逻辑单元的数目的逻辑单元组。用户也可以针对多个主机或所有主机定义一个或多个预分配逻辑单元组,这种情况下,用户可以基于多个主机或所有主机的应用的潜在需求,考虑逻辑单元的大小和数目。
图4中所示的控件401、402和403分别可被用来显示和/或选择逻辑单元组的名称,逻辑单元组所包含的逻辑单元的数目,以及每个逻辑单元的大小。在某些实施例中,控件402和403可以是下拉菜单。在此示例中,UI 400用户选择“与源逻辑单元相同”复选框404,将使用第一个逻辑单元的大小到目标主机。例如,如果用户首先创建了特定大小(例如,100GB)的逻辑单元到主机,那么该逻辑单元组中的所有逻辑单元都被设定为这个大小。
定义了预分配逻辑单元组之后,可以向用户展示如图5所示的UI 500。用户可以将不同的预分配逻辑单元组与不同的主机关联。不同的主机也可以共享同一个逻辑单元组但每个主机各自具有单独的一个或多个逻辑单元。例如,逻辑单元组1具有8个逻辑单元,每个逻辑单元为特定大小(例如,10GB),考虑到主机102A和主机102C的应用相似,用户可以勾选相应的复选框501并在相应的下拉框502中进行选择操作,将主机102A和主机102C分别与逻辑单元组1进行关联,为主机102A和主机102C分别预分配了8个特定大小(例如,10GB)的逻辑单元。在图5中,用户为主机102B预分配了5个特定大小(例如,100GB)的逻辑单元,其构成了逻辑单元组2。用户还可以为没有容量扩展需求的主机禁用这一特性,例如不勾选主机102D相应的复选框501,这种情况下,对主机102D不进行预分配配置,对其的操作将如以前一样,没有任何变化。
根据本公开的实施例,响应于用户例如通过图4和图5所示意的UI对各主机配置第一组逻辑单元210和第二组逻辑单元212,存储控制器104即被触发以接收到来自主机的存储创建请求,进而执行如图3所示的方法300。其中,用户对主机102配置第一组逻辑单元210时,指定的第一组逻辑单元210所包含的逻辑单元的数目以及每个逻辑单元的大小是其根据应用的实际需求而配置,存储控制器104根据这一配置信息即得到主机102所期望的目标容量;用户对主机102配置第二组逻辑单元212时,指定的第二组逻辑单元212所包含的逻辑单元的数目以及每个逻辑单元的大小是其根据应用的潜在需求而配置,存储控制器104根据这一配置信息即得到主机102的第一附加容量。由此,存储控制器104为主机102创建存储。
在完成了方法300所示的逻辑单元创建之后,在本公开的一个实施例中,例如在存储环境200中,添加第一组逻辑单元210和第二组逻辑单元212到磁盘阵列的掩码中,创建光纤通道交换机上的划分区域,扫描和挂载主机102上的逻辑单元。现在从主机102的角度来看,可以看到所有创建的逻辑单元,但只能够使用第一组逻辑单元210的容量。
根据本公开的存储预分配机制,可以在满足主机102的当前实际需求的同时,便于将来的存储扩展容量。下面结合图6描述在主机希望扩展容量时的操作过程。图6示出了根据本公开的一个实施例的扩展容量的方法600的流程图。在某些实施例中,方法600同样可由存储管理器104来实现。
在步骤602,从主机102接收扩展容量请求。可以理解,随着主机102上的应用的执行,目前分配给主机102的存储容量可能无法满足主机102的要求。此时,主机102可以向存储管理器104发送扩容请求。扩展容量请求至少包括主机102期望的扩展容量。根据本公开的实施例,将至少部分地基于预先分配给主机102的第二组逻辑单元212来实现容量扩展。
具体而言,在步骤604,确定预先已经分配的第二组逻辑单元212所提供的容量(称为“第一附加容量”)是否能够满足扩展需求。如果第一附加容量大于扩展请求中指示的扩展容量(分支“是”),方法600进行到步骤606。在步骤606,从第二组逻辑单元212中选择与扩展容量对应的逻辑单元。接下来,在步骤608,将步骤606中选择的逻辑单元与物理存储关联,从而完成容量扩展。由于这些例如从第二组逻辑单元212中选择的逻辑单元已经为主机102预分配并且因此是主机102可见的,因此可以直接格式化并使用其存储容量。预分配逻辑单元中剩下的未使用的逻辑单元可以仍然保持“未绑定”状态,即,不实际占用物理存储资源。
另一方面,如果在步骤604确定第二组逻辑单元的容量不足以满足扩展单元(分支“否”),方法600进行到步骤610,在此基于主机102要求的扩展容量与第二组逻辑单元所提供的第一附加容量之间的差量,为主机102创建第三组逻辑单元。也就是说,第三组逻辑单元所提供的存储量等于扩展容量与第一附加容量之差。而后,在步骤612,将第三组逻辑单元与物理存储108关联,以供主机102使用。
应当理解,在步骤612,可以对第三组逻辑单元进行任何适当的配置,以便主机102能够使用这些逻辑单元。这样的配置包括但不限于:将新逻辑单元添加到磁盘阵列掩码中,检查或者修改光纤通道交换机上的分区,重新扫描主机102上的逻辑单元,等等。
可选地,在某些实施例中,容量扩展操作同样可以按照“预分配”的方式进行。具体而言,在这样的实施例中,方法600可以进行到步骤614,在此为主机102创建第四组逻辑单元。第四组逻辑单元提供超出当前所需扩展容量的附加容量(称为“第二附加容量”)。类似于第二组逻辑单元,尽管第四组逻辑单元对于主机102是可见的,但是并不与物理存储108进行实际的关联。也就是说,第四组逻辑单元同样处于“未绑定”状态。以此方式,可以为将来的进一步扩展做好准备。
从图6中可以看到,使用以上所描述的基于预分配的扩展容量方案,如果扩展容量请求能够通过预分配逻辑单元而得到处理,将能够使用很少的步骤完成扩展容量请求,避免在容量扩展期间对多个设备在不同层中的频繁修改,因而避免了潜在的失败可能性,并且加速了整个扩展容量流程。另外,在扩展容量发生之前,预分配逻辑单元仅是位置预留,并不占用物理存储空间,不会造成容量浪费。即使用户不使用预分配这一特性,或者扩展需求超出了预分配的设置,将以原有方式扩展容量,也不会产生任何负面影响。
可以理解,在某些情况下,随着主机102上的应用的执行,应用可能已经不需要或只需要部分目前实际分配给主机102使用的存储容量,此时,用户希望移除一些使用中的逻辑单元,以避免容量浪费。下面结合图7描述在主机102希望移除容量时的操作过程。
图7示出了根据本公开的一个实施例的存储移除的方法700的流程图。在某些实施例中,方法700同样可由存储管理器104来实现。可以理解,在存储管理器104运行一段时间后,与物理存储关联的逻辑单元以及与物理存储不关联的逻辑单元可能共存。方法700仅示出了在主机102启用了预分配逻辑单元特性情况下的一个示例,如果主机102未启用预分配逻辑单元特性,则移除过程可以以原有方式进行。
在步骤702,接收存储移除请求。在步骤704,确定移除请求是否涉及目前与物理存储108关联的所有逻辑单元。如果并非如此,这意味着用户希望仅移除部分“绑定”的逻辑单元,此时方法700进行到步骤706,在此仅仅移除存储移除请求所涉及的那些逻辑单元。将会理解,在这种情况下,保留所有其他与物理存储关联的逻辑单元以及与物理存储不关联的逻辑单元。如果用户希望将来创建新逻辑单元,则可以从那些与物理存储不关联的逻辑单元中很快得到。
另一方面,如果在步骤704确定移除请求涉及了目前与物理存储108相关联的所有逻辑单元(也即,涉及与物理存储108相关联的最后一个逻辑单元),方法700进行到步骤708,在此移除不仅移除与移除请求所涉及的那些逻辑单元,还移除与物理存储尚未关联的预分配的逻辑单元。这些逻辑单元可能来自第二组逻辑单元,以及可选地还可以来自上文参考图6描述的第四组逻辑单元。
在本公开的一个实施例中,如果每个逻辑单元分别以单个卷在主机102中呈现,方法700可以基于用户请求所要移除的目标卷执行。具体而言,可以确定该目标卷是否是最后一个与物理存储“绑定”的卷,即是否是对应于最后一个与物理存储关联的逻辑单元。如果是,这意味着用户希望移除所有“绑定”卷,则将目标卷与所有处于“未绑定”状态的卷一起移除。否则,仅移除用户请求移除的主机102上的目标卷。
图8图示了存储管理器104的一个实现的适宜性框图,存储管理器104包括:接收单元802,被配置成从主机接收存储创建请求,该存储创建请求指定主机期望的目标容量;创建单元804,被配置成为主机创建具有目标容量的第一组逻辑单元,将第一组逻辑单元与物理存储关联,以供所述主机使用,并且为主机创建具有超出目标容量的第一附加容量的第二组逻辑单元,而不将第二组逻辑单元与物理存储关联。
根据本公开的一个实施例,存储管理器104的的接收单元802还被配置成:从主机接收存储扩展请求,存储扩展请求指定所述主机期望的扩展容量;以及存储管理器104还包括扩展容量单元806,被配置成响应于存储扩展请求,至少部分地基于第二组逻辑单元,将扩展容量扩展给主机。
根据本公开的一个实施例,扩展容量单元806还被配置成:响应于确定第一附加容量大于或等于扩展容量,从第二组逻辑单元中选择对应于扩展容量的逻辑单元;以及将选择的逻辑单元与物理存储关联,以供主机使用。
根据本公开的一个实施例,扩展容量单元还806被配置成:响应于确定第一附加容量小于扩展容量,基于扩展容量与第一附加容量之间的差量,为主机创建第三组逻辑单元;以及将第三组逻辑单元与物理存储关联,以供所述主机使用。
根据本公开的一个实施例,扩展容量单元806还被配置成:为主机创建具有超出扩展容量的第二附加容量的第四组逻辑单元,而不将第四组逻辑单元与物理存储关联。
根据本公开的一个实施例,存储管理器104的接收单元802还被配置成:从主机接收存储移除请求;存储管理器104还包括移除容量单元808,被配置成:响应于移除请求涉及目前与物理存储关联的所有逻辑单元,移除目前与物理存储关联的逻辑单元,以及移除第二组逻辑单元中尚未与物理存储关联的逻辑单元。
在存储管理器104由SDS实现的实施例中,图8中所示的各个单元中的至少一部分可被实现为软件模块。备选地,在存储管理器104由硬件实现的实施例中,上述单元中的的一个或多个可以实现为硬件模块,包括但不限于:集成电路(IC)芯片、专用集成电路(ASIC)芯片、片上系统(SoC)、现场可编程门阵列(FPGA)等。
图9示出了一个可以用来实施本公开的实施例的设备900的示意性框图。设备900可以充当用于一种存储管理设备,其例如包括上文描述的存储管理器104。如图所示,设备900包括中央处理单元(CPU)901,其可以根据存储在只读存储器(ROM)902中的计算机程序指令或者从存储单元908加载到随机访问存储器(RAM)903中的计算机程序指令,来执行各种适当的动作和处理。在RAM 903中,还可存储设备900操作所需的各种程序和数据。CPU 901、ROM902以及RAM 903通过总线904彼此相连。输入/输出(I/O)接口905也连接至总线904。
设备900中的多个部件连接至I/O接口905,包括:输入单元906,例如键盘、鼠标等;输出单元907,例如各种类型的显示器、扬声器等;存储单元908,例如磁盘、光盘等;以及通信单元909,例如网卡、调制解调器、无线通信收发机等。通信单元909允许设备900通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
在某些实施例中,处理单元901可被配置为执行上文所描述的各个过程和处理,例如方法300、600以及700。例如,在一些实施例中,方法300、600以及700可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元908。在一些实施例中,计算机程序的部分或者全部可以经由ROM 902和/或通信单元909而被载入和/或安装到设备900上。当计算机程序被加载到RAM 903并由CPU 901执行时,可以执行上文描述的方法300、600以及700的一个或多个步骤。
通过以上描述和相关附图中所给出的教导,这里所给出的本公开的许多修改形式和其它实施方式将被本公开相关领域的技术人员所意识到。因此,所要理解的是,本公开的实施方式并不局限于所公开的具体实施方式,并且修改形式和其它实施方式意在包括在本公开的范围之内。此外,虽然以上描述和相关附图在部件和/或功能的某些示例组合形式的背景下对示例实施方式进行了描述,但是应当意识到的是,可以由备选实施方式提供部件和/或功能的不同组合形式而并不背离本公开的范围。就这点而言,例如,与以上明确描述的有所不同的部件和/或功能的其它组合形式也被预期处于本公开的范围之内。虽然这里采用了具体术语,但是它们仅以一般且描述性的含义所使用而并非意在进行限制。

Claims (19)

1.一种存储管理方法,包括:
从主机接收存储创建请求,所述存储创建请求指定所述主机期望的目标容量;
为所述主机创建具有所述目标容量的第一组逻辑单元;
将所述第一组逻辑单元与物理存储关联,以供所述主机使用;以及
为所述主机创建具有超出所述目标容量的第一附加容量的第二组逻辑单元,而不将所述第二组逻辑单元与所述物理存储关联。
2.根据权利要求1所述的方法,包括:
从所述主机接收存储扩展请求,所述存储扩展请求指定所述主机期望的扩展容量;以及
响应于所述存储扩展请求,至少部分地基于所述第二组逻辑单元,将所述扩展容量扩展给所述主机。
3.根据权利要求2所述的方法,其中所述扩展包括:
响应于确定所述第一附加容量大于或等于所述扩展容量,从所述第二组逻辑单元中选择对应于所述扩展容量的逻辑单元;以及
将选择的所述逻辑单元与所述物理存储关联,以供所述主机使用。
4.根据权利要求2所述的方法,其中所述扩展包括:
响应于确定所述第一附加容量小于所述扩展容量,基于所述扩展容量与所述第一附加容量之间的差量,为所述主机创建第三组逻辑单元;以及
将所述第三组逻辑单元与所述物理存储关联,以供所述主机使用。
5.根据权利要求4所述的方法,其中所述扩展进一步包括:
为所述主机创建具有超出所述扩展容量的第二附加容量的第四组逻辑单元,而不将所述第四组逻辑单元与所述物理存储关联。
6.根据权利要求1所述的方法,进一步包括:
从所述主机接收存储移除请求;以及
响应于所述移除请求涉及目前与所述物理存储关联的所有逻辑单元,
移除目前与所述物理存储关联的所述逻辑单元,以及
移除所述第二组逻辑单元中尚未与所述物理存储关联的逻辑单元。
7.一种存储管理设备,包括:
至少一个处理器;以及
包含计算机程序代码的至少一个存储器,所述至少一个存储器和所述计算机程序代码被配置成利用所述至少一个处理器而使得所述设备至少执行以下操作:
从主机接收存储创建请求,所述存储创建请求指定所述主机期望的目标容量;
为所述主机创建具有所述目标容量的第一组逻辑单元;
将所述第一组逻辑单元与物理存储关联,以供所述主机使用;以及
为所述主机创建具有超出所述目标容量的第一附加容量的第二组逻辑单元,而不将所述第二组逻辑单元与所述物理存储关联。
8.根据权利要求7所述的设备,其中所述至少一个存储器和所述计算机程序代码被配置成利用所述至少一个处理器而使得所述设备至少还执行以下操作:
从所述主机接收存储扩展请求,所述存储扩展请求指定所述主机期望的扩展容量;以及
响应于所述存储扩展请求,至少部分地基于所述第二组逻辑单元,将所述扩展容量扩展给所述主机。
9.根据权利要求8所述的设备,所述扩展包括:
响应于确定所述第一附加容量大于或等于所述扩展容量,从所述第二组逻辑单元中选择对应于所述扩展容量的逻辑单元;以及
将选择的所述逻辑单元与所述物理存储关联,以供所述主机使用。
10.根据权利要求8所述的设备,其中所述扩展包括:
响应于确定所述第一附加容量小于所述扩展容量,基于所述扩展容量与所述第一附加容量之间的差量,为所述主机创建第三组逻辑单元;以及
将所述第三组逻辑单元与所述物理存储关联,以供所述主机使用。
11.根据权利要求10所述的设备,其中所述扩展进一步包括:
为所述主机创建具有超出所述扩展容量的第二附加容量的第四组逻辑单元,而不将所述第四组逻辑单元与所述物理存储关联。
12.根据权利要求7所述的设备,其中所述至少一个存储器和所述计算机程序代码被配置成利用所述至少一个处理器而使得所述设备至少还执行:
从所述主机接收存储移除请求;以及
响应于所述移除请求涉及目前与所述物理存储关联的所有逻辑单元,
移除目前与所述物理存储关联的所述逻辑单元,以及
移除所述第二组逻辑单元中尚未与所述物理存储关联的逻辑单元。
13.一种存储管理装置,包括:
接收单元,被配置成从主机接收存储创建请求,所述存储创建请求指定所述主机期望的目标容量;以及
创建单元,被配置成为所述主机创建具有所述目标容量的第一组逻辑单元,将所述第一组逻辑单元与物理存储关联,以供所述主机使用,以及为所述主机创建具有超出所述目标容量的第一附加容量的第二组逻辑单元,而不将所述第二组逻辑单元与所述物理存储关联。
14.根据权利要求13所述的装置,其中所述接收单元还被配置成:从所述主机接收存储扩展请求,所述存储扩展请求指定所述主机期望的扩展容量;以及所述装置还包括:扩展容量单元,被配置成响应于所述存储扩展请求,至少部分地基于所述第二组逻辑单元,将所述扩展容量扩展给所述主机。
15.根据权利要求14所述的装置,所述扩展容量单元还被配置成:
响应于确定所述第一附加容量大于或等于所述扩展容量,从所述第二组逻辑单元中选择对应于所述扩展容量的逻辑单元;以及
将选择的所述逻辑单元与所述物理存储关联,以供所述主机使用。
16.根据权利要求14所述的装置,所述扩展容量单元还被配置成:
响应于确定所述第一附加容量小于所述扩展容量,基于所述扩展容量与所述第一附加容量之间的差量,为所述主机创建第三组逻辑单元;以及
将所述第三组逻辑单元与所述物理存储关联,以供所述主机使用。
17.根据权利要求16所述的装置,所述扩展容量单元还被配置成:
为所述主机创建具有超出所述扩展容量的第二附加容量的第四组逻辑单元,而不将所述第四组逻辑单元与所述物理存储关联。
18.根据权利要求13所述的装置,其中所述接收单元还被配置成:从所述主机接收存储移除请求;所述装置还包括移除容量单元,被配置成:响应于所述移除请求涉及目前与所述物理存储关联的所有逻辑单元,移除目前与所述物理存储关联的所述逻辑单元,以及移除所述第二组逻辑单元中尚未与所述物理存储关联的逻辑单元。
19.一种计算机可读存储介质,具有存储在其上的计算机可读程序指令,所述计算机可读程度指令用于执行根据权利要求1-7中任一项所述的方法。
CN201610154144.1A 2016-03-17 2016-03-17 存储管理方法及设备 Active CN107203329B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN201610154144.1A CN107203329B (zh) 2016-03-17 2016-03-17 存储管理方法及设备
US15/461,753 US10936193B2 (en) 2016-03-17 2017-03-17 Method and device for storage management

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201610154144.1A CN107203329B (zh) 2016-03-17 2016-03-17 存储管理方法及设备

Publications (2)

Publication Number Publication Date
CN107203329A true CN107203329A (zh) 2017-09-26
CN107203329B CN107203329B (zh) 2020-12-01

Family

ID=59855596

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201610154144.1A Active CN107203329B (zh) 2016-03-17 2016-03-17 存储管理方法及设备

Country Status (2)

Country Link
US (1) US10936193B2 (zh)
CN (1) CN107203329B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113495869A (zh) * 2020-03-20 2021-10-12 华为技术有限公司 文件系统空间的调整方法、装置和电子设备
CN113741793A (zh) * 2020-05-29 2021-12-03 华为技术有限公司 一种上报存储资源的方法、装置及系统

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102275706B1 (ko) * 2014-06-30 2021-07-09 삼성전자주식회사 데이터 저장 장치의 작동 방법과 이를 포함하는 데이터 처리 시스템의 작동 방법

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008003857A (ja) * 2006-06-22 2008-01-10 Fujitsu Ltd ストレージ装置の容量拡張方法、プログラム、およびストレージ装置
CN101840308A (zh) * 2009-10-28 2010-09-22 创新科存储技术有限公司 一种分级存储系统及其逻辑卷管理方法
CN101997919A (zh) * 2010-11-16 2011-03-30 杭州宏杉科技有限公司 一种存储资源的管理方法及管理装置
CN102096557A (zh) * 2010-12-31 2011-06-15 成都市华为赛门铁克科技有限公司 一种独立磁盘冗余阵列的扩容方法、装置及系统
CN102123176A (zh) * 2011-03-17 2011-07-13 杭州宏杉科技有限公司 一种网络存储系统空间分配管理方法及装置
US8135906B2 (en) * 2008-05-15 2012-03-13 Lsi Corporation Online storage capacity expansion of a raid storage system

Family Cites Families (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5894485A (en) * 1997-03-31 1999-04-13 Emc Corporation Disk array write protection at the sub-unit level
US6041394A (en) * 1997-09-24 2000-03-21 Emc Corporation Disk array write protection at the sub-unit level
US6343324B1 (en) * 1999-09-13 2002-01-29 International Business Machines Corporation Method and system for controlling access share storage devices in a network environment by configuring host-to-volume mapping data structures in the controller memory for granting and denying access to the devices
JP4175083B2 (ja) * 2002-10-29 2008-11-05 株式会社日立製作所 記憶装置の管理用計算機、およびプログラム
US7313719B1 (en) * 2004-02-06 2007-12-25 Symantec Operating Corporation Restore of backup to computer system with filesystem/volume attribute modification
US20050210028A1 (en) * 2004-03-18 2005-09-22 Shoji Kodama Data write protection in a storage area network and network attached storage mixed environment
US7328287B1 (en) * 2004-07-26 2008-02-05 Symantec Operating Corporation System and method for managing I/O access policies in a storage environment employing asymmetric distributed block virtualization
US7290108B2 (en) * 2005-03-25 2007-10-30 Hitachi, Ltd. Information processing system having volume guard function
US20080010421A1 (en) * 2006-07-10 2008-01-10 Inventec Corporation Snapshot expansion system and method thereof
US8074020B2 (en) * 2008-02-13 2011-12-06 International Business Machines Corporation On-line volume coalesce operation to enable on-line storage subsystem volume consolidation
US8135907B2 (en) * 2008-06-30 2012-03-13 Oracle America, Inc. Method and system for managing wear-level aware file systems
US8069322B2 (en) * 2008-08-15 2011-11-29 International Business Machines Corporation Active-active remote configuration of a storage system
US7974953B1 (en) * 2008-10-28 2011-07-05 Netapp, Inc. System and method for deletion of writeable PPIS
US8291159B2 (en) * 2009-03-12 2012-10-16 Vmware, Inc. Monitoring and updating mapping of physical storage allocation of virtual machine without changing identifier of the storage volume assigned to virtual machine
US20100306486A1 (en) * 2009-05-29 2010-12-02 Sridhar Balasubramanian Policy-based application aware storage array snapshot backup and restore technique
US8316161B1 (en) * 2010-09-30 2012-11-20 Emc Corporation Techniques for indicating a passive path state for a device
US8806154B1 (en) * 2011-05-06 2014-08-12 Chelsio Communications, Inc. Thin provisioning row snapshot with reference count map
US8793463B2 (en) * 2011-09-12 2014-07-29 Microsoft Corporation Allocation strategies for storage device sets
US9043567B1 (en) * 2012-03-28 2015-05-26 Netapp, Inc. Methods and systems for replicating an expandable storage volume
US9342703B2 (en) * 2012-11-30 2016-05-17 Red Hat Israel, Ltd. Managing storage permissions for logical volume managers
US10025673B1 (en) * 2013-09-20 2018-07-17 Amazon Technologies, Inc. Restoring partitioned database tables from backup
US9053002B2 (en) * 2013-11-12 2015-06-09 International Business Machines Corporation Thick and thin data volume management
US20160342609A1 (en) * 2015-05-21 2016-11-24 Netapp, Inc. Systems, methods, and computer program products providing an elastic snapshot repository
JP6554990B2 (ja) * 2015-08-11 2019-08-07 富士通株式会社 ストレージ制御装置およびストレージ制御プログラム
US9916110B2 (en) * 2016-02-23 2018-03-13 Red Hat, Inc. Size adjustable volumes for containers
US10324807B1 (en) * 2017-10-03 2019-06-18 EMC IP Holding Company LLC Fast native file system creation for backup files on deduplication systems

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008003857A (ja) * 2006-06-22 2008-01-10 Fujitsu Ltd ストレージ装置の容量拡張方法、プログラム、およびストレージ装置
US8135906B2 (en) * 2008-05-15 2012-03-13 Lsi Corporation Online storage capacity expansion of a raid storage system
CN101840308A (zh) * 2009-10-28 2010-09-22 创新科存储技术有限公司 一种分级存储系统及其逻辑卷管理方法
CN101997919A (zh) * 2010-11-16 2011-03-30 杭州宏杉科技有限公司 一种存储资源的管理方法及管理装置
CN102096557A (zh) * 2010-12-31 2011-06-15 成都市华为赛门铁克科技有限公司 一种独立磁盘冗余阵列的扩容方法、装置及系统
CN102123176A (zh) * 2011-03-17 2011-07-13 杭州宏杉科技有限公司 一种网络存储系统空间分配管理方法及装置

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113495869A (zh) * 2020-03-20 2021-10-12 华为技术有限公司 文件系统空间的调整方法、装置和电子设备
CN113495869B (zh) * 2020-03-20 2024-04-26 华为技术有限公司 文件系统空间的调整方法、装置和电子设备
CN113741793A (zh) * 2020-05-29 2021-12-03 华为技术有限公司 一种上报存储资源的方法、装置及系统
CN113741793B (zh) * 2020-05-29 2024-04-09 华为技术有限公司 一种上报存储资源的方法、装置及系统

Also Published As

Publication number Publication date
US20170269846A1 (en) 2017-09-21
US10936193B2 (en) 2021-03-02
CN107203329B (zh) 2020-12-01

Similar Documents

Publication Publication Date Title
CN107046563B (zh) 一种分布式高效云盘的实现方法、系统及云平台
CN104636080B (zh) 存储系统及用于其的方法
CN103765372B (zh) 配置用于输入/输出操作的对象存储系统
US20230229637A1 (en) Intelligent file system with transparent storage tiering
CN108351752A (zh) 存储虚拟化卸载
US20170220281A1 (en) Smart partitioning of storage access paths in shared storage services
CN103503414A (zh) 一种计算存储融合的集群系统
CN106168884A (zh) 访问对象存储系统的计算机系统
CN105074675B (zh) 具有层级化块存储装置的计算机系统、存储控制器及介质
KR20210075845A (ko) 네이티브 키-밸류 분산 스토리지 시스템
KR20140111589A (ko) 가상 기계들을 지원하는 플래시―기반 캐싱 해결책에서의 동적인 캐시 공유를 위한 시스템, 방법 및 컴퓨터―판독가능한 매체
CN106687926A (zh) 被克隆的虚拟机的负载均衡
CN103282889A (zh) 用于数据储存系统的端点高速缓存
CN106030500A (zh) 存储系统的数据迁移方法
US20230176763A1 (en) Increasing data performance by transferring data between storage tiers using workload characteristics
CN102221982A (zh) 块级虚拟化存储设备上实现重复数据删除的方法及系统
AU2020382999B2 (en) Intelligent data pool
US9552167B2 (en) Raid array transformation in a pooled storage system
CN104272242A (zh) 创建加密存储体
Xu et al. Rethink the storage of virtual machine images in clouds
CN107203329A (zh) 存储管理方法及设备
CN104994135B (zh) 存储系统中融合san及nas存储架构的方法及装置
Tarasov et al. Evaluating Docker storage performance: from workloads to graph drivers
US10725971B2 (en) Consistent hashing configurations supporting multi-site replication
JP7091457B2 (ja) 遠隔コピー操作中にバス・インターフェースを介してストレージ・コントローラに書き込まれるデータの管理

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
TA01 Transfer of patent application right
TA01 Transfer of patent application right

Effective date of registration: 20200413

Address after: Massachusetts, USA

Applicant after: EMC IP Holding Company LLC

Address before: Ma Sazhusaizhou

Applicant before: EMC Corp.

GR01 Patent grant
GR01 Patent grant