CN107894874A - 基于超融合存储系统的数据读写控制方法、终端及系统 - Google Patents

基于超融合存储系统的数据读写控制方法、终端及系统 Download PDF

Info

Publication number
CN107894874A
CN107894874A CN201711147517.3A CN201711147517A CN107894874A CN 107894874 A CN107894874 A CN 107894874A CN 201711147517 A CN201711147517 A CN 201711147517A CN 107894874 A CN107894874 A CN 107894874A
Authority
CN
China
Prior art keywords
virtual volume
volume controller
read
manager
local node
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
CN201711147517.3A
Other languages
English (en)
Other versions
CN107894874B (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.)
Beijing Lenovo Super Fusion Technology Co Ltd
Original Assignee
Beijing Lenovo Super Fusion Technology Co Ltd
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 Beijing Lenovo Super Fusion Technology Co Ltd filed Critical Beijing Lenovo Super Fusion Technology Co Ltd
Priority to CN201711147517.3A priority Critical patent/CN107894874B/zh
Publication of CN107894874A publication Critical patent/CN107894874A/zh
Application granted granted Critical
Publication of CN107894874B publication Critical patent/CN107894874B/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
    • 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/0662Virtualisation aspects
    • G06F3/0665Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
    • 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]

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

基于超融合存储系统的数据读写控制方法、终端及系统
技术领域
本发明涉及数据存储技术领域,尤其涉及一种基于超融合存储系统的数据读写控制方法、终端及系统。
背景技术
超融合是基于软件定义技术构建大规模数据中心的启发,结合虚拟化技术和企业IT的场景,为企业实现可扩展的IT基础架构,其中,虚拟化技术是基于虚拟机实现整合服务器集群,降低了对各种规模数据的存储、保护以及管理的复杂性。并且,在超融合系统中,采用分布式架构对虚拟卷中的数据进行存储,虚拟卷可以理解为是虚拟机上的虚拟存储标识,类似于计算机硬盘的磁盘分区,可以实现在虚拟卷中的数据,当将同一个虚拟卷的数据写入到多个目标主机进行备份时,可以防止由于一个目标主机崩溃而导致在其上的虚拟机无法运行,进而不能对虚拟卷中的数据进行读写操作。
目前,采用同一台控制主机管理对所有虚拟卷中的数据进行读写、修复、迁移等操作,并基于上述操作生成控制信息,发送至不同的目标主机,实现对在目标主机中备份的虚拟卷中的数据进行相应的操作。然而,现有的方法是仅使用同一台控制主机接收所有对虚拟卷中的数据进行读写、修复、迁移等操作请求,当控制主机在同一时间段内接收到的操作请求数量是很大的,并且这些操作请求呈现高并发状态时,则控制主机需要管理的操作量很大的,对应生成的控制信息的数据量也是很大的,因此,控制主机可能负载过大或者满载,相比较分布式架构中的其他主机处于负载很小或者空闲状态的情况,所以分布式架构中的处理资源不能被有效利用,造成资源浪费。
发明内容
鉴于上述问题,本发明提供一种基于超融合存储系统的数据读写控制方法、终端及系统,主要目的在于利用分散在不同主机上的虚拟卷控制器实现对虚拟卷中的数据的读写、修复、迁移等操作的管理,实现了分布式架构中处理资源的有效利用。
为了解决上述问题,本发明主要提供如下技术方案:
第一方面,本发明提供了一种基于超融合存储系统的数据读写控制方法,该方法包括:
当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作;
若不存在所述虚拟卷控制器,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制器;
基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
可选的,基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作包括:
当所述管理器反馈不存在所述虚拟卷管理器时,在本地节点创建所述虚拟卷管理器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作;
将创建结果反馈给所述管理器进行记录。
可选的,基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作包括:
当所述管理器反馈所述虚拟卷控制器位于其他节点中时,提取所述其他节点的位置信息,以确定所述虚拟卷控制器的位置信息;
基于所述位置信息,将所述读写请求发送至所述虚拟卷控制器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
可选的,所述方法还包括:
在所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作时,对执行所述读写操作对应的数据进行备份。
可选的,所述对执行所述读写操作对应的数据进行备份包括:
当所述数据为首次写操作时,获取所述虚拟卷的位置信息,以及所述读写操作对应数据的备份数量,并根据所述位置信息和所述备份数量确定数据备份的其他节点的位置信息,将所述数据备份在对应的其他节点中;
当所述数据为数据修改操作时,获取备份有原数据的其他节点的位置信息,并根据所述位置信息将所述数据替换所述其他节点中备份的原数据。
可选的,根据所述位置信息和所述备份数量确定数据备份的其他节点的位置信息包括:
根据所述位置信息按照距离本地节点由近到远的顺序对其他节点排序;
根据所述排序筛选出节点负载小于阈值的待选节点;
从所述待选节点中选择与备份数量相同个数的其他节点。
可选的,在根据所述读写请求在本地节点查找对应的虚拟卷控制器之前,所述方法还包括:
利用读写模块识别所接收读写请求的来源;
若所述读写请求来自于其他节点,则在本地节点已创建的虚拟卷控制器中查找对应的虚拟卷控制器,并执行相应的读写操作。
可选的,所述方法还包括:
获取本地节点中已创建的虚拟卷控制器的运行状态;
若所述运行状态正常,则向所述管理器发送对应虚拟卷控制器的心跳,以便所述管理器确认所述虚拟卷控制器运行正常;
若所述运行状态异常,则注销所述虚拟卷控制器,并向管理器发送注销结果。
可选的,注销所述虚拟卷控制器,并向管理器发送注销结果包括:
判断所述虚拟卷控制器的异常运行状态的持续时间是否达到阈值;
若达到,则注销所述虚拟卷控制器;
当注销成功后,将所述注销结果发送至所述管理器。
第二方面,本发明还提供了一种基于超融合存储系统的数据读写控制方法,该方法包括:
管理器接收本地节点发送的创建虚拟卷控制器的请求;
根据所述请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;
若存在,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;
若不存在,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
可选的,当所述超融合存储系统中不存在所述虚拟卷控制器时,所述方法还包括:
获取所述本地节点中已创建的虚拟卷控制器的数量;
当所述数量超过阈值时,则通过预置规则确定创建所述虚拟卷控制器的其他节点;
向所述其他节点发送创建所述虚拟卷控制器的信息,以便所述其他节点创建所述虚拟卷控制器,并反馈创建结果;
若所述虚拟卷控制器成功创建在其他节点中,则将所述其他节点的位置信息反馈给所述本地节点。
可选的,在接收本地节点发送的创建虚拟卷控制器的请求之前,所述方法还包括:
统计超融合存储系统中所有的虚拟卷控制器以及对应的节点位置,得到虚拟卷控制器列表;
接收所述超融合存储系统中各个节点发送的虚拟卷控制器的心跳信息;
根据所述心跳信息判断所述虚拟卷控制器的运行状态;
当接收到虚拟卷控制器的运行状态异常或者注销信息时,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息。
可选的,根据所述心跳信息判断所述虚拟卷控制器的运行状态包括:
当在预置时间段内没有接收到所述虚拟卷控制器列表中包含的第一虚拟卷控制器的心跳信息时,确定所述第一虚拟卷控制器的运行状态为异常。
可选的,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息之后,所述方法还包括:
根据超融合存储系统中各个节点的负载情况选择一个其他节点;
向所述其他节点中发送创建所述虚拟卷控制器的信息。
第三方面,本发明提供了一种基于超融合存储系统的数据读写控制装置,该装置包括:
查找单元,用于当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作;
发送单元,用于当本地节点不存在所述查找单元查找的所述虚拟卷控制器时,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制器;
执行单元,用于基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
可选的,所述执行单元包括:
创建模块,用于当所述管理器反馈不存在所述虚拟卷管理器时,在本地节点创建所述虚拟卷管理器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作;
反馈模块,用于将所述创建模块创建结果反馈给所述管理器进行记录。
可选的,所述执行单元包括:
提取模块,用于当所述管理器反馈所述虚拟卷控制器位于其他节点中时,提取所述其他节点的位置信息,以确定所述虚拟卷控制器的位置信息;
发送模块,用于基于所述提取模块提取的所述位置信息,将所述读写请求发送至所述虚拟卷控制器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
可选的,所述装置还包括:
备份单元,用于在所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作时,对执行所述读写操作对应的数据进行备份。
可选的,所述备份单元包括:
第一获取模块,用于当所述数据为首次写操作时,获取所述虚拟卷的位置信息,以及所述读写操作对应数据的备份数量;
确定模块,用于根据所述第一获取模块获取的位置信息和所述备份数量确定数据备份的其他节点的位置信息;
备份模块,用于将所述数据备份在所述确定模块确定的对应的其他节点中;
第二获取模块,用于当所述数据为数据修改操作时,获取备份有原数据的其他节点的位置信息;
替换模块,用于根据所述第二获取模块获取的位置信息将所述数据替换所述其他节点中备份的原数据。
可选的,所述确定模块包括:
排序子模块,用于根据所述位置信息按照距离本地节点由近到远的顺序对其他节点排序;
筛选子模块,用于根据所述排序子模块的排序筛选出节点负载小于阈值的待选节点;
选择子模块,用于从所述筛选子模块筛选出的待选节点中选择与备份数量相同个数的其他节点。
可选的,所述装置还包括:
识别单元,用于在所述查找单元根据所述读写请求在本地节点查找对应的虚拟卷控制器之前,利用读写模块识别所接收读写请求的来源;
所述查找单元还用于,当所述识别单元识别所述读写请求来自于其他节点,则在本地节点已创建的虚拟卷控制器中查找对应的虚拟卷控制器,并执行相应的读写操作。
可选的,所述装置还包括:
获取单元还用于,获取本地节点中已创建的虚拟卷控制器的运行状态;
所述发送单元还用于,当所述获取单元获取的本地节点中已创建的虚拟卷控制器的运行状态正常时,则向所述管理器发送对应虚拟卷控制器的心跳,以便所述管理器确认所述虚拟卷控制器运行正常;
注销单元,用于当所述获取单元获取的本地节点中已创建的虚拟卷控制器的运行状态异常时,则注销所述虚拟卷控制器;
所述发送单元还用于,向管理器发送所述注销单元注销结果。
可选的,所述注销单元包括:
判断模块,用于判断所述虚拟卷控制器的异常运行状态的持续时间是否达到阈值;
注销模块,当所述判断模块判断的所述持续时间达到阈值时,则注销所述虚拟卷控制器;
发送模块,当所述注销模块注销所述虚拟卷控制器成功后,将所述注销结果发送至所述管理器。
第四方面,本发明还提供了一种基于超融合存储系统的数据读写控制装置,该装置包括:
接收单元,用于接收本地节点发送的创建虚拟卷控制器的请求;
判断单元,用于根据所述接收单元接收的请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;
第一反馈单元,用于当所述判断单元判断所述超融合存储系统中存在所述虚拟卷控制器时,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;
第二反馈单元,用于当所述判断单元判断所述超融合存储系统中不存在所述虚拟卷控制器时,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
可选的,所述装置还包括:
获取单元,用于当所述判断单元判断超融合存储系统中不存在所述虚拟卷控制器时,获取所述本地节点中已创建的虚拟卷控制器的数量;
确定单元,用于当所述获取单元获取的数量超过阈值时,则通过预置规则确定创建所述虚拟卷控制器的其他节点;
发送单元,用于向所述其他节点发送创建所述虚拟卷控制器的信息,以便所述其他节点创建所述虚拟卷控制器,并反馈创建结果;
所述第一反馈单元还用于,当所述虚拟卷控制器成功创建在其他节点中时,则将所述其他节点的位置信息反馈给所述本地节点。
可选的,所述装置还包括:
统计单元,用于在所述接收单元接收本地节点发送的创建虚拟卷控制器的请求之前,统计超融合存储系统中所有的虚拟卷控制器以及对应的节点位置,得到虚拟卷控制器列表;
所述接收单元还用于,接收所述超融合存储系统中各个节点发送的虚拟卷控制器的心跳信息;
所述判断单元还用于,根据所述接收单元接收的心跳信息判断所述虚拟卷控制器的运行状态;
删除单元,用于当接收到虚拟卷控制器的运行状态异常或者注销信息时,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息。
可选的,所述判断单元还用于,当在预置时间段内没有接收到所述虚拟卷控制器列表中包含的第一虚拟卷控制器的心跳信息时,确定所述第一虚拟卷控制器的运行状态为异常。
可选的,所述装置还包括:
选择单元,用于所述删除单元在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息之后,根据超融合存储系统中各个节点的负载情况选择一个其他节点;
所述发送单元还用于,向所述选择单元选择的其他节点中发送创建所述虚拟卷控制器的信息。
第五方面,本发明提供一种存储终端,所述终端中包括处理器和存储介质,所述处理器和所述存储介质在进行数据读写控制操作时,能够执行如上述所述的基于超融合存储系统的数据读写控制方法,用于通过虚拟卷控制器控制对应虚拟卷执行读写操作。
第六方面,本发明提供一种控制终端,所述终端中包括处理器和存储介质,所述处理器和所述存储介质在进行数据读写控制操作时,能够执行如上述所述的基于超融合存储系统的数据读写控制方法,用于运行管理器以监控所述超融合存储系统中各个节点内的虚拟卷控制器。
第七方面,本发明提供一种基于超融合存储系统的数据读写控制系统,所述系统中包括有上述所述的存储终端以及上述所述的控制终端。
借由上述技术方案,本发明提供的基于超融合存储系统的数据读写控制方法、终端及系统,相比较现有技术采用同一台控制主机管理超融合存储系统中所有对虚拟卷中数据的读写、修复、迁移等操作请求,当控制主机接收的请求处于高并发状态时,则控制主机需要处理的数据量是很大的,而此时其他主机处于负载很小或者空闲状态,据此,导致在系统中处理资源不能被有效利用的问题。本发明采用虚拟卷控制器控制对虚拟卷中数据的读写、修复、迁移等操作请求,同时一个虚拟卷控制器用于控制在超融合存储系统中创建的虚拟机所对应的虚拟卷的读写、修复、迁移等操作,防止当对虚拟卷的处理请求被不同的虚拟卷控制器接收时,会出现对虚拟卷中数据的处理操作不一致的问题。基于上述虚拟卷对应唯一虚拟卷控制器,当查找本地主机不存在虚拟卷对应的虚拟卷控制器时,本地主机向管理器发送在本地主机创建虚拟卷控制器的请求,管理器会判断系统中其他主机是否存在该虚拟卷对应的虚拟卷控制器,当其存在于其他主机上时,根据管理器的反馈,将对虚拟卷的处理操作请求发送至虚拟卷控制器所在的其他主机,在实现管理器对分散在不同主机的虚拟卷控制器进行管理同时,能够实现多个虚拟卷控制器可以分散在不同的主机上工作,避免多个虚拟卷控制器都在同一个主机上工作导致负载过大而其他主机空闲的问题,进而提高了超融合存储系统中处理资源的有效利用。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了本发明实施例提供的第一种基于超融合存储系统的数据读写控制方法流程图;
图2示出了本发明实施例提供的第二种基于超融合存储系统的数据读写控制方法流程图;
图3示出了本发明实施例提供的第三种基于超融合存储系统的数据读写控制方法流程图;
图4示出了本发明实施例提供的第四种基于超融合存储系统的数据读写控制方法流程图;
图5出了本发明实施例提供的第五种基于超融合存储系统的数据读写控制方法流程图;
图6示出了本发明实施例提供的第一种基于超融合存储系统的数据读写控制装置的组成框图;
图7示出了本发明实施例提供的第二种基于超融合存储系统的数据读写控制装置的组成框图;
图8示出了本发明实施例提供的第三种基于超融合存储系统的数据读写控制装置的组成框图;
图9示出了本发明实施例提供的第四种基于超融合存储系统的数据读写控制装置的组成框图;
图10示出了本发明实施例提供的一种基于超融合存储系统的数据读写控制系统结构示意图。
具体实施方式
下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
本发明实施例提供了一种基于超融合存储系统的数据读写控制方法,该方法是根据虚拟卷和虚拟卷控制器的唯一对应关系,将虚拟卷控制器分散在不同节点工作,提高了超融合存储系统中处理资源的有效利用,如图1 所示,该方法应用于系统中的一个节点中,以下称为本地节点,对此本发明实施例提供以下具体步骤:
101、当接收到本地节点的读写请求时,根据读写请求在本地节点查找对应的虚拟卷控制器。
其中,虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作。超融合存储系统采用以虚拟化技术为中心的策略将数据存储、数据保护和网络管理整合成一个可扩展的整体架构,在虚拟机上运行分布式存储服务。虚拟卷是用于根据虚拟机运行需求而建立存储分配,类似于在计算机硬盘中建立磁盘分区,并实现在虚拟卷中存储数据。在本发明实施例中,采用虚拟卷控制器对虚拟卷的读写操作请求进行控制,并且每个虚拟卷对应有唯一的虚拟卷控制器,即当请求对虚拟卷的数据执行读写操作时,需要其唯一对应的虚拟卷控制器响应读写操作请求后,才可以执行相应的读写操作。
对于本发明实施例,基于虚拟卷与虚拟卷控制器之间的唯一对应关系,在分布式存储架构中,当本地节点接收到对虚拟卷的读写请求时,则查找本地节点是否存在该虚拟卷对应的虚拟卷控制器,若存在,则虚拟卷控制器响应上述读写请求,执行对虚拟卷的数据的读写操作,若不存在,则需要查找该虚拟卷对应的虚拟卷控制器在其他节点的位置。
需要说明的是,本发明实施例中对虚拟卷的数据处理请求不仅限于读写请求,也可以是修复、迁移等等数据处理请求,本发明实施例仅通过例举读写请求,以便于陈述实现虚拟卷控制器对其唯一对应的虚拟卷的控制管理,因此,对于上述其他数据处理请求的情况,在此不作出一一例举。
102、若本地节点不存在对应的虚拟卷控制器,则向管理器发送在本地节点创建虚拟卷控制器的请求。
其中,管理器用于管理超融合存储系统中所有虚拟卷对应的虚拟卷控制器。超融合存储系统中存在的多个虚拟卷控制器会是根据一定的哈希算法,分散在分布式架构中不同的节点上,以便于系统中处理资源的有效利用,并且,在不同节点上均设置有管理器,通过存储所有虚拟卷控制器的位置信息,(位置信息中包含该虚拟卷控制器所在节点的互联网协议地址 (Internet Protocol Address,IP地址))以及其与虚拟卷的一一对应关系,实现对系统中所有虚拟卷控制器的管理,即通过查找管理器可以获知系统中是否存在虚拟卷对应的虚拟卷控制器以及其位置信息。
对于本发明实施例,基于虚拟卷与虚拟卷控制器之间的唯一对应关系,且需要虚拟卷控制器响应对虚拟卷的读写请求,才能执行相关的读写操作,因此,在分布式存储架构中,当本地节点接收对虚拟卷的读写请求时,先在本地节点查找对应的虚拟卷控制器,若确定本地节点不存在该虚拟卷对应的虚拟卷控制器,则需要向管理器发送在本地节点创建对应虚拟卷控制器的请求。
103、基于管理器反馈请求的信息,实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
在本发明实施例中,当本地节点向管理器发送在本地节点创建对应的虚拟卷控制器的请求后,管理器对该请求作出反馈,反馈的信息创建虚拟卷控制器或者反馈对应虚拟卷控制器的位置信息,目的都是为了给出对应的虚拟卷控制器的位置信息,继而根据虚拟卷与对其控制的虚拟卷控制器的唯一对应关系,将读写请求发送至对应的虚拟卷控制器,使得对应的虚拟卷控制器接收到对虚拟卷的读写请求,从而能够实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
本发明实施例提供的一种基于超融合存储系统的数据读写控制方法,应用于本地节点,基于虚拟卷与虚拟卷控制器的唯一对应关系,当本地节点接收对虚拟卷的读写请求时,根据上述唯一对应关系,查找对应的虚拟卷控制器,不管是在本地查找到对应虚拟卷控制器或者是根据管理器反馈信息获知对应虚拟卷控制器的位置信息,在将对虚拟卷的读写请求发送至对应的虚拟卷控制器时,都可以找到对应的虚拟卷控制器响应对虚拟卷的读写请求,即实现了将虚拟卷控制器分散在系统中的不同节点上工作,避免多个虚拟卷控制器都在同一个主机上工作导致负载过大而其他主机空闲的问题,进而提高了超融合存储系统中处理资源的有效利用。
为了对上述实施例做出更加详细的说明,本发明实施例还提供了另一种基于超融合存储系统的数据读写控制方法,该方法是通过本地节点将虚拟卷控制器的心跳信息发送管理器,实现对虚拟卷控制器运行状态的监控,以及将对虚拟卷的读写操作对应的数据备份在其他节点上,实现各个节点资源的有效利用,如图2所示,该方法应用于本地节点,对此本发明实施例提供以下具体步骤:
201、当接收到本地节点的读写请求时,根据读写请求在本地节点查找对应的虚拟卷控制器。
在超融合存储系统中,虚拟卷控制器控制对应唯一的虚拟卷,对于本步骤具体的描述,可以参考上述步骤101,此处不再赘述。
需要说明的是,在执行本步骤之前,利用读写模块识别所接收读写请求的来源,即利用本地节点的读写模块判断接收的读写请求是来自于分布式架构中的本地节点还是其他节点,当判断读写请求来自于其他节点时,则表明该读写请求对应的虚拟卷所在节点上不存在其对应的虚拟卷控制器,所以基于管理器判断超融合存储系统中存在对应的虚拟卷控制器以及反馈的虚拟卷控制器所在其他节点的位置信息,确定在本地节点存在该虚拟卷对应的虚拟卷控制器,所以将读写请求发送至本地节点。因此,在确定读写请求来自于其他节点时,可以确定本地节点中必然存在对应的虚拟卷控制器,则可以在本地节点已创建的虚拟卷控制器中查找对应的虚拟卷控制器,并执行相应的读写操作。或者,当判断读写请求来自于本地节点时,则无法确定本地节点是否存在对应的虚拟卷控制器,那么需要获知虚拟卷控制器的位置信息,以便于将对虚拟卷的读写请求发送至对应的虚拟卷控制器,使得虚拟卷控制器可以响应该读写请求。
202、若本地节点不存在对应的虚拟卷控制器,则向管理器发送在本地节点创建虚拟卷控制器的请求。
其中,管理器用于管理超融合存储系统中所有虚拟卷对应的虚拟卷控制器。在本发明实施例中,对本步骤的具体描述,请参考步骤102,此处不再赘述。
203、基于管理器反馈请求的信息,实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
在本发明实施例中,当管理器接收到本地节点发送的创建虚拟卷控制器的请求后,相应的,管理器会对请求作出反馈,但是反馈的信息存在两种不同的情况,包括:一种情况是管理器反馈超融合存储系统中不存在对应的虚拟卷控制器;另一种情况是管理器反馈对应的虚拟卷控制器位于其他节点中。对应于上述管理器反馈的信息存在两种不同的情况,实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作,具体的描述包括:
第一,当管理器反馈不存在对应的虚拟卷管理器时,在本地节点创建虚拟卷管理器,以实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作,并将创建结果反馈给管理器进行记录。
在本发明实施例中,当管理器反馈在超融合存储系统中不存在对应的虚拟卷控制器时,则在本地节点创建对应的虚拟卷控制器,那么该虚拟卷控制器的位置信息是其所在的本地节点的位置信息,在创建完成后,将该虚拟卷控制器的位置信息以及虚拟卷与创建的虚拟卷控制器的唯一对应关系信息反馈给管理器,并在管理器中记录上述新增的信息,以便管理器实现管理超融合存储系统中存在的所有虚拟卷控制器。当在本地节点创建对应的虚拟卷控制器后,可以在本地节点实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
第二,当管理器反馈对应的虚拟卷控制器位于其他节点中时,提取其他节点的位置信息,以确定该虚拟卷控制器的位置信息。
在本发明实施例中,当管理器反馈对应的虚拟卷控制器存在于其他节点中时,查询管理器中存储的其他节点的位置信息,以便根据其他节点的位置信息确定在其上的虚拟卷控制器的位置信息,即其他节点的位置信息就是在其上的虚拟卷控制器的位置信息,提取该位置信息中包含IP地址信息,根据该IP地址信息,可以将对虚拟卷的读写请求发送至对应的虚拟卷控制器,以便对应的虚拟卷控制器响应读写请求,实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
204、在虚拟卷控制器控制对应的虚拟卷执行相应的读写操作时,对执行读写操作对应的数据进行备份。
其中,在虚拟卷控制器控制对应的虚拟卷执行相应的读写操作过程中,对虚拟卷执行的读写操作存在两种方式,包括:一种方式是对虚拟卷执行首次写操作;另一种方式是对虚拟卷执行修改操作。基于上述两种方式将对虚拟卷执行读写操作对应的数据进行备份的具体方法,描述如下:
第一,当执行读写操作对应的数据为首次写操作时,获取虚拟卷的位置信息,以及读写操作对应数据的备份数量,并根据该虚拟卷的位置信息和备份数量确定数据备份的其他节点的位置信息,将数据备份在对应的其他节点中。
其中,获取虚拟卷的位置信息是指可以通过虚拟卷控制器所在的节点上的读写模块识别响应的读写请求来自于本地节点或者其他节点,从而可以获得该读写请求对应的虚拟卷所在的节点,进而根据节点的位置信息确定该虚拟卷的位置信息。
其中,获取读写操作对应数据的备份数量是指可以根据系统预置的备份数量,对该数据进行备份。其中,系统预置的备份数量不限定是由系统管理员在运行该系统前所设定的数值,或者是根据虚拟卷所在的节点确定的备份数量,亦或是解析读写请求所得到的用户指定的备份数量。
在本发明实施例中,对于根据虚拟卷的位置信息和备份数量确定数据备份的其他节点的位置信息作进一步细化描述如下,包括:
首先,根据虚拟卷的位置信息按照距离本地节点由近到远的顺序对其他节点排序。在分布式架构中,根据虚拟卷所在节点的位置信息,将其他节点按照距离本地节点由近到远的顺序进行排序,目的在于将备份数据存储在与本地节点距离较近的节点上,以便于本地节点能够快速获取对虚拟卷执行读写操作对应的数据备份。
其次,根据对其他节点的排序筛选出节点负载小于阈值的待选节点。依次将其他节点的负载与阈值作比较,其中,阈值用于判断是否存在负载很小或者负载空闲的其他节点,以便于当将数据备份到负载很小或者负载空闲的其他节点时,可以实现对分布式架构中的处理资源的有效利用。并且根据上述将其他节点按照距离本地节点由近到远的顺序进行排序,可以挑选出距离本地节点近,同时负载小于阈值的节点,作为备份数据的待选节点。
最后,从待选节点中选择与备份数量相同个数的其他节点。在本发明实施例中,根据备份数量从待选节点中选择出相同数量的节点,实现对数据的多次备份,获取选出的其他节点的位置信息,用于后续将数据备份到选择出的其他节点上。
例如,在节点A上执行对虚拟卷的读写操作,将数据a首次写入虚拟卷中,根据系统预置的备份数量,比如,系统预置的备份数量是三份,则对数据a进行三份备份,且备份到其他节点上。根据距离虚拟卷A所在节点的由近到远的顺序,选出节点B、C以及D,并且上述三个节点的负载都小于阈值,获取节点节点B、C以及D的位置信息,用于后续将数据a备份到节点B、C以及D中。
对于本发明实施例,在从待选节点中选择与备份数量相同个数的其他节点后,确定其他节点的位置信息,将对虚拟卷的读写操作对应的数据备份到不同的其他节点上。
第二,当执行读写操作对应的数据为数据修改操作时,获取备份有原数据的其他节点的位置信息,并根据其他节点的位置信息将数据替换其他节点中备份的原数据。
在本发明实施例中,为了保证超融合存储系统中同一个虚拟卷在不同节点上存储数据的一致性,因此,当对虚拟卷执行数据修改操作时,则需要对该虚拟卷备份在其他节点上的原数据一并进行相同的数据修改操作,据此,具体的方法,包括:首先,虚拟卷控制器控制对应的虚拟卷执行数据修改操作;其次,获取备份有该虚拟卷中原数据的其他节点的位置信息;最后,根据其他节点的位置信息,将该虚拟卷备份在其他节点的原数据替换为本次数据修改操作后对应的数据。
205、获取本地节点中已创建的虚拟卷控制器的运行状态。
在本发明实施例中,获取本地节点中已创建的虚拟卷控制器的运行状态,用于在本地节点实现监控虚拟卷控制器的工作状态,比如虚拟卷控制器是否能够正常启动,是否可以响应对虚拟卷进行读写操作的请求。由于虚拟卷控制器在超融合存储系统中的工作是存在一定生命周期的,因此,当管理器在对所有虚拟卷控制器进行管理时,需要确定超融合存储系统中是否存在工作异常的虚拟卷控制器,以便于及时采取相应的措施,比如注销虚拟卷控制器、重新创建虚拟卷控制器等等。
206a、当本地节点中已创建的虚拟卷控制器的运行状态正常时,则向管理器发送对应虚拟卷控制器的心跳。
在本步骤中,目的是以便管理器确认虚拟卷控制器运行正常。
206b、当本地节点中已创建的虚拟卷控制器的运行状态异常时,则注销虚拟卷控制器,并向管理器发送注销结果,以便于管理器更新记录的虚拟卷控制器的相关信息。
其中,对注销虚拟卷控制器,并向管理器发送注销结果作出进一步的细化描述,如下:
在虚拟卷控制器所在节点判断虚拟卷控制器的异常运行状态的持续时间是否达到阈值,其中,阈值是预先设置的,用于判断虚拟卷控制器响应对虚拟卷的读写请求时运行的持续时间是否异常,当虚拟卷控制器作出响应的持续时间达到阈值时,则表明虚拟卷控制器运行异常,则注销虚拟卷控制器,以便于保证超融合存储系统中各个节点上的虚拟卷控制器是能够正常工作的,当注销成功后,将注销结果发送至管理器,用于更新管理器的存储信息,删除管理器中该虚拟卷控制器的位置信息以及该虚拟卷控制器与虚拟卷的唯一对应关系,以便于后续管理器接收到创建对应的虚拟卷控制器请求时,管理器反馈允许在节点上创建对应的虚拟卷控制器的信息。
在本发明实施例中,仅是例举对本地节点实现监控虚拟卷控制器的工作状态的一种方法,由于在分布式架构中不同节点是等同的,因此,此处不对其他节点实现监控虚拟卷控制器的工作状态的描述作出一一例举。
对应于上述本发明的上述两个实施例,在本地节点通过虚拟卷控制器控制对应虚拟卷执行读写操作,本发明实施例还提供了一种基于超融合存储系统的数据读写控制方法,该方法是通过管理器对系统中所有虚拟卷控制器进行管理,使得本地节点能够获知虚拟卷对应的虚拟卷控制器的位置信息,以便于将对虚拟卷的读写请求发送至对应的虚拟卷控制器,实现虚拟卷控制器分散在不同节点工作,提高处理资源的有效利用,具体如图3 所示,该方法应用于管理器,对此本发明实施例提供以下具体步骤:
301、接收本地节点发送的创建虚拟卷控制器的请求。
在本发明实施例中,当本地节点接收对虚拟卷的读写请求时,在本地节点上查找虚拟卷对应的唯一虚拟卷控制器,若本地节点不存在对应的虚拟卷控制器,基于管理器对超融合存储系统中所有的虚拟卷控制器进行管理,本地节点为了获取对应的虚拟卷控制器的位置信息,则需要向管理器发送在本地节点创建虚拟卷控制器的请求,该请求的目的是由管理器判断当前系统中是否运行有对应的虚拟卷管理器,若存在则向本地节点反馈对应的位置信息,若不存在则允许在本地节点中创建该虚拟卷控制器。
302、根据请求判断超融合存储系统中是否存在虚拟卷对应的虚拟卷控制器。
基于超融合存储系统中,虚拟卷与虚拟卷控制器的唯一对应关系,当管理器接收本地节点发送的创建虚拟卷控制器的请求时,需要查询管理器存储的关于虚拟卷控制器的信息,用于确定在超融合存储系统中是否已经存在对应的虚拟卷控制器。
需要指出的是,管理器中所保存的虚拟卷控制器的相关信息是由系统中的各个节点定期上报,并汇总得到的数据信息。
303a、若超融合存储系统中存在虚拟卷对应的虚拟卷控制器,则将虚拟卷控制器所在的其他节点的位置信息反馈给本地节点,以便于本地节点将虚拟卷控制器对应的读写请求发送至其他节点。
在本发明实施例中,当确定超融合存储系统中存在虚拟卷对应的虚拟卷控制器时,即不需要重新创建对应的虚拟卷控制器,则将虚拟卷控制器所在的其他节点的位置信息反馈给本地节点,本地节点通过其他节点的位置信息,可以确定对应的虚拟卷控制器的位置信息,将对虚拟卷执行读写请求发送至对应的虚拟卷控制器,请求其响应相关的读写请求。
303b、若超融合存储系统中不存在虚拟卷对应的虚拟卷控制器,则向本地节点反馈创建虚拟卷控制器的信息,以便本地节点根据信息创建虚拟卷控制器,并反馈创建结果。
在本发明实施例中,当确定超融合存储系统中不存在虚拟卷对应的虚拟卷控制器时,即需要创建虚拟卷对应的虚拟卷控制器,则管理器向本地节点反馈创建虚拟卷控制器的信息,并且当本地节点根据反馈信息创建虚拟卷控制器时,以确保创建的虚拟卷控制器与其控制管理的虚拟卷是唯一对应关系。
本发明实施例提供的一种基于超融合存储系统的数据读写控制方法,该方法应用于管理器,当管理器接收本地节点发送的创建虚拟卷控制器的请求,通过反馈对应虚拟卷控制器在其他节点的位置信息或者反馈创建对应虚拟卷控制器的信息,实现对系统中所有虚拟卷控制器的监控以及维护,并且将上述反馈信息发送至本地节点,以便于本地节点获知对应虚拟卷控制器的位置信息,并将对虚拟卷的读写请求发送至对应的虚拟卷控制器,实现虚拟卷控制器即使分散在不同节点,也能够执行相应的工作,避免多个虚拟卷控制器都在同一个主机上工作导致负载过大而其他主机空闲的问题,进而提高了超融合存储系统中处理资源的有效利用。
为了对上述实施例做出更加详细的说明,本发明实施例还提供了另一种基于超融合存储系统的数据读写控制方法,该方法进一步实现了管理器对所有虚拟卷控制器的监控以及维护,如图4所示,该方法应用于管理器,对此本发明实施例提供以下具体步骤:
401、统计超融合存储系统中所有的虚拟卷控制器以及对应的节点位置,得到虚拟卷控制器列表。
对于本发明实施例,管理器存在于超融合存储系统中的每个节点,可以监控每个节点上的虚拟卷控制器是否运行正常以及获知虚拟卷控制器所在节点的位置信息,通过统计所有虚拟卷控制器以及对应的节点位置,可以将虚拟卷控制器所在节点的位置信息以及虚拟卷控制器与其控制的虚拟卷的唯一对应关系,形成虚拟卷控制器列表,存储在管理器中,如表一所示,当在本地节点创建或者注销虚拟卷控制器时,管理器会更新其虚拟卷控制器列表,实现对所有虚拟卷控制器的监控管理,并且当接收创建对应的虚拟卷控制器请求时,可以做出正确的反馈信息。
表一
序号 虚拟卷控制器 虚拟卷控制器所在节点位置 控制的虚拟卷
1 虚拟卷控制器A 219.143.201.61 虚拟卷a
2 虚拟卷控制器B 220.194.38.5 虚拟卷b
其中,如表一所示,虚拟卷控制器A、虚拟卷控制器B分别在不同节点上,虚拟卷控制器A所在节点的IP地址是219.143.201.61以及虚拟卷控制器B所在节点的IP地址是220.194.38.5,据此,可以获得虚拟卷控制器 A和虚拟卷控制器B的位置信息,并且通过查询表一,还可以获得虚拟卷控制器A控制其唯一对应的虚拟卷虚拟卷a以及虚拟卷控制器B控制其唯一对应的虚拟卷虚拟卷b,上述表一中的“A”“B”“a”“b”仅是为了清晰陈述虚拟卷控制器列表中的数据而对虚拟卷控制器和虚拟卷进行的标号,在本发明实施例中可以采用其他标记方法,用于区别不同的虚拟卷控制器和虚拟卷,本发明实施例对此不作具体限定。
402、接收超融合存储系统中各个节点发送的虚拟卷控制器的心跳信息。
在超融合存储系统中,虚拟卷控制器是存在一定生命周期的,当其出现运行异常时,则需要在本地节点注销异常工作的虚拟卷控制器,防止异常工作的虚拟卷控制器不能响应对虚拟卷的读写请求,导致无法执行对虚拟卷的读写操作。因此,管理器需要基于接收各个节点发送的虚拟卷控制器的心跳信息监控虚拟卷控制器的运行状态,其中,心跳信息是用于证明虚拟卷控制器在正常工作,并能够与管理器实现请求与响应的交互的信息,比如,在预置时间段内,虚拟卷控制器向管理器发送其所在节点的位置信息,管理器接收发送的位置信息,并与虚拟卷控制列表中的数据比对是一致的,则该虚拟卷控制器运行正常。
403、根据心跳信息判断虚拟卷控制器的运行状态。
在本发明实施例中,当在预置时间段内没有接收到虚拟卷控制器列表中包含的第一虚拟卷控制器的心跳信息时,确定第一虚拟卷控制器的运行状态为异常。例如,比照虚拟卷控制器列表,当在预置时间段内,管理器没有接收到列表中虚拟卷控制器对应的心跳信息时,则确定该虚拟卷控制器运行异常。
404、当接收到虚拟卷控制器的运行状态异常或者注销信息时,在虚拟卷控制器列表中删除虚拟卷控制器对应的相关信息。
基于上述根据心跳信息监控虚拟卷控制器的运行状态方法,当管理器判断虚拟卷控制器处于运行异常时或者当本地节点注销运行异常的虚拟卷控制器而反馈的注销结果时,管理器在虚拟卷控制器列表中删除虚拟卷控制器对应的相关信息。
需要说明的是,在虚拟卷控制器列表中删除虚拟卷控制器对应的相关信息之后,需要重新创建虚拟卷对应的虚拟卷控制器,并且建立虚拟卷与虚拟卷控制器唯一对应关系,用于控制执行对虚拟卷的读写请求。其中,重新创建对应的虚拟卷控制器的具体描述,如下:
根据超融合存储系统中各个节点的负载情况选择一个其他节点,即通过比对各个节点的负载情况,选择在负载很小或者负载空闲的节点上创建虚拟卷控制器,以便于对超融合存储系统的处理资源的有效利用,在确定选择的节点后,管理器向该节点发送创建虚拟卷控制器的信息。
405、接收本地节点发送的创建虚拟卷控制器的请求。
关于本步骤的描述,具体的,可以参考步骤301,此处不再赘述。
406、根据请求判断超融合存储系统中是否存在虚拟卷对应的虚拟卷控制器。
关于本步骤的描述,具体的,可以参考步骤302,此处不再赘述。
407a、若超融合存储系统中存在虚拟卷对应的虚拟卷控制器,则将虚拟卷控制器所在的其他节点的位置信息反馈给本地节点,以便于本地节点将虚拟卷控制器对应的读写请求发送至其他节点。
关于本步骤的描述,具体的,可以参考步骤303,此处不再赘述。
407b、若超融合存储系统中不存在虚拟卷对应的虚拟卷控制器,则向本地节点反馈创建虚拟卷控制器的信息,以便于本地节点根据信息创建虚拟卷控制器。
在本发明实施例中,基于管理器向本地节点反馈创建虚拟卷控制器的信息,本地节点接收其反馈信息并可以在本地节点执行建立虚拟卷控制器的操作。但是,为了实现虚拟卷控制器分散在系统中不同的节点上工作,系统设置阈值以及预置规则,用于将管理器反馈的创建虚拟卷控制器的信息发送至其他节点,以实现在不同节点创建虚拟卷控制器,具体的,在其他节点上创建虚拟卷控制器的步骤,如下:
第一、获取本地节点中已创建的虚拟卷控制器的数量。通过查询管理器中虚拟卷控制器列表,可以得到在本地节点中的虚拟卷控制器数量。
第二、当数量超过阈值时,则通过预置规则确定用于创建虚拟卷控制器的其他节点。其中,阈值是系统预先设置的,用于确定在各个节点上允许存在的虚拟卷控制器的数量,以便防止多个虚拟卷控制器集中存在一个节点中,避免单节点崩溃导致的系统大面积瘫痪或无法执行读写操作的情况出现。预置规则是指选择适当的其他节点用于在其上创建虚拟卷控制器的规则,比如,采用的预置规则是通过比较各个节点的负载情况,从其中选择负载很小或者负载空闲的其他节点且该节点上存在的虚拟卷控制器数量小于阈值。对此具体预置规则,本发明实施例不做具体限定。对于本发明实施例,当本地节点存在的虚拟卷控制器的数量超过阈值时,则系统不允许在本地节点创建虚拟卷控制器,需要根据预置规则确定适当的其他节点,以便于后续在其他节点上创建虚拟卷控制器。
第三、向其他节点发送创建虚拟卷控制器的信息,以便于其他节点创建虚拟卷控制器,并反馈创建结果。在确定创建虚拟卷控制器所在的其他节点后,将创建虚拟卷控制器的信息发送至其他节点,由其他节点执行创建虚拟卷控制器的操作。
第四、若虚拟卷控制器成功创建在其他节点中,则将其他节点的位置信息反馈给本地节点,以便于本地节点将执行对虚拟卷的读写请求发送至其他节点上的虚拟卷控制器,实现虚拟卷控制器响应对虚拟卷的读写请求。
进一步的,在本发明实施例的超融合存储系统中,管理器可以设置在每一个节点上或者设置在系统中确定的一个节点上,那么对于管理器和本地节点的信息交互而实现对虚拟卷控制器进行管理的具体方式如下:
在超融合存储系统的分布式架构中,本地节点的输入/输出模块接收对虚拟卷的读写请求,其中,输入/输出模块存在于主机的处理器中,用于控制管理主机的读写操作,当本地节点接收读写请求后,首先,本地节点查询本地是否存在虚拟卷对应的虚拟卷控制器,若存在,则将读写请求发送至对应的虚拟卷控制器,若不存在,则向管理器发送创建对应的虚拟卷控制器的请求,基于虚拟卷控制器控制其唯一对应的虚拟卷,管理器根据虚拟卷控制器列表判断在系统中是否存在对应的虚拟卷控制器,反馈是否创建虚拟卷控制器的信息,若对应的虚拟卷控制器存在于其他节点,则将其他节点的位置发送至本地节点,以便于本地节点将读写请求发送至其他节点上的虚拟卷控制器,实现虚拟卷控制器响应读写请求。此外,管理器基于本地节点发送的虚拟卷控制器的心跳信息,实现监控所有虚拟卷控制器的运行状态,当其运行状态存在异常时,管理器删除虚拟卷控制器列表中对应的虚拟卷控制器信息,实现对所有虚拟卷控制器的维护。
为了更加详细地说明本发明实施例所提供的一种基于超融合存储系统的数据读写控制方法,以下将综合上述的四种方法加以说明,在本实施例中通过本地节点与管理器的交互实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作,如图5所示,该方法所包括的具体步骤为:
501、当接收到本地节点的读写请求时,本地节点根据读写请求在本地节点查找对应的虚拟卷控制器。
其中,虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作。
在本发明实施例中,基于虚拟卷与虚拟卷控制器的唯一对应关系,在分布式存储架构中,当本地节点接收到对虚拟卷的读写请求时,则查找本地节点是否存在该虚拟卷对应的虚拟卷控制器,若存在,则虚拟卷控制器响应上述读写请求,执行对虚拟卷的数据的读写操作,若不存在,则需要查找该虚拟卷对应的虚拟卷控制器在其他节点的位置。
502、若本地节点不存在对应的虚拟卷控制器,则本地节点向管理器发送在本地节点创建虚拟卷控制器的请求。
其中,管理器用于管理超融合存储系统中所有虚拟卷对应的虚拟卷控制器。
在本发明实施例中,基于虚拟卷与虚拟卷控制器的唯一对应关系,且需要虚拟卷控制器响应对虚拟卷的读写请求,才能执行相关的读写操作,因此,当查找本地节点的虚拟卷控制器后,确定本地节点不存在响应对虚拟卷执行读写请求的虚拟卷控制器时,,则需要向管理器发送在本地节点创建对应虚拟卷控制器的请求。
503、管理器根据请求判断超融合存储系统中是否存在对应的虚拟卷控制器。
在本发明实施例中,当管理器接收到本地节点发送的创建虚拟卷控制器的请求时,需要查询管理器存储的关于虚拟卷控制器的信息,用于确定在超融合存储系统中是否已经存在对应的虚拟卷控制器。
504a、若超融合存储系统中存在对应的虚拟卷控制器,则管理器将对应的虚拟卷控制器所在的其他节点的位置信息反馈给本地节点,以便本地节点将虚拟卷控制器对应的读写请求发送至其他节点。
在本发明实施例中,当确定超融合存储系统中存在虚拟卷对应的虚拟卷控制器时,即不需要重新创建对应的虚拟卷控制器,则将虚拟卷控制器所在的其他节点的位置信息反馈给本地节点,本地节点通过其他节点的位置信息,可以确定对应的虚拟卷控制器的位置信息,将对虚拟卷执行读写请求发送至对应的虚拟卷控制器,请求其响应相关的读写请求。
504b、若超融合存储系统中不存在对应的虚拟卷控制器,则管理器向本地节点反馈创建虚拟卷控制器的信息,以便本地节点根据信息创建虚拟卷控制器,并反馈创建结果。
在本发明实施例中,当确定超融合存储系统中不存在虚拟卷对应的虚拟卷控制器时,即需要创建虚拟卷对应的虚拟卷控制器,则管理器向本地节点反馈创建虚拟卷控制器的信息,并且当本地节点根据反馈信息创建虚拟卷控制器时,以确保创建的虚拟卷控制器与其控制管理的虚拟卷是唯一对应关系。
505、基于管理器反馈请求的信息,本地节点实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
在本发明实施例中,当本地节点向管理器发送在本地节点创建对应的虚拟卷控制器的请求后,管理器对该请求作出反馈,目的是给出对应的虚拟卷控制器的位置信息,继而根据虚拟卷与对其控制的虚拟卷控制器的唯一对应关系,将读写请求发送至对应的虚拟卷控制器,使得对应的虚拟卷控制器接收到对虚拟卷的读写请求,从而能够实现虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
进一步的,作为对上述图1及图2所示方法的实现,本发明另一实施例还提供了一种基于超融合存储系统的数据读写控制装置。该装置实施例与前述方法实施例对应,为便于阅读,本装置实施例不再对前述方法实施例中的细节内容进行逐一赘述,但应当明确,本实施例中的装置能够对应实现前述方法实施例中的全部内容。该装置应用于通过虚拟卷控制器控制对应虚拟卷执行读写操作,具体如图6所示,该装置包括:
查找单元601,用于当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作;
发送单元602,用于当本地节点不存在所述查找单元601查找的所述虚拟卷控制器时,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制;
执行单元603,用于基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作;
进一步的,如图7所示,所述执行单元603包括:
创建模块6031,用于当所述管理器反馈不存在所述虚拟卷管理器时,在本地节点创建所述虚拟卷管理器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作;
反馈模块6032,用于将所述创建模块6031创建结果反馈给所述管理器进行记录。
进一步的,如图7所示,所述执行单元603包括:
提取模块6033,用于当所述管理器反馈所述虚拟卷控制器位于其他节点中时,提取所述其他节点的位置信息,以确定所述虚拟卷控制器的位置信息;
发送模块6034,用于基于所述提取模块6033提取的所述位置信息,将所述读写请求发送至所述虚拟卷控制器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
进一步的,如图7所示,所述装置还包括:
备份单元604,用于在所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作时,对执行所述读写操作对应的数据进行备份。
进一步的,如图7所示,所述备份单元604包括:
第一获取模块6041,用于当所述数据为首次写操作时,获取所述虚拟卷的位置信息,以及所述读写操作对应数据的备份数量;
确定模块6042,用于根据所述第一获取模块6041获取的位置信息和所述备份数量确定数据备份的其他节点的位置信息;
备份模块6043,用于将所述数据备份在所述确定模块6042确定的对应的其他节点中;
第二获取模块6044,用于当所述数据为数据修改操作时,获取备份有原数据的其他节点的位置信息;
替换模块6045,用于根据所述第二获取模块6044获取的位置信息将所述数据替换所述其他节点中备份的原数据。
进一步的,如图7所示,所述确定模块6042包括:
排序子模块60421,用于根据所述位置信息按照距离本地节点由近到远的顺序对其他节点排序;
筛选子模块60422,用于根据所述排序子模块60421的排序筛选出节点负载小于阈值的待选节点;
选择子模块60423,用于从所述筛选子模块60422筛选的待选节点中选择与备份数量相同个数的其他节点。
进一步的,如图7所示,所述装置还包括:
识别单元605,用于在所述查找单元601根据所述读写请求在本地节点查找对应的虚拟卷控制器之前,利用读写模块识别所接收读写请求的来源;
所述查找单元601,还用于当所述识别单元605识别读写请求来自于其他节点,则在本地节点已创建的虚拟卷控制器中查找对应的虚拟卷控制器,并执行相应的读写操作。
进一步的,如图7所示,所述装置还包括:
获取单元606,用于获取本地节点中已创建的虚拟卷控制器的运行状态;
所述发送单元602还用于,当所述获取单元606获取的本地节点中已创建的虚拟卷控制器的运行状态正常时,则向所述管理器发送对应虚拟卷控制器的心跳,以便所述管理器确认所述虚拟卷控制器运行正常;
注销单元607,用于当所述获取单元606获取的本地节点中已创建的虚拟卷控制器的运行状态异常时,则注销所述虚拟卷控制器;
所述发送单元602还用于,向管理器发送注销单元607注销结果。
进一步的,如图6所示,所述注销单元607包括:
判断模块6071,用于判断所述虚拟卷控制器的异常运行状态的持续时间是否达到阈值;
注销模块6072,当所述判断模块6071判断的所述持续时间达到阈值时,则注销所述虚拟卷控制器;
发送模块6073,当所述注销模块6072注销所述虚拟卷控制器成功后,将所述注销结果发送至所述管理器。
进一步的,作为对上述图3及图4所示方法的实现,本发明另一实施例还提供了一种基于超融合存储系统的数据读写控制装置。该装置实施例与前述方法实施例对应,为便于阅读,本装置实施例不再对前述方法实施例中的细节内容进行逐一赘述,但应当明确,本实施例中的装置能够对应实现前述方法实施例中的全部内容。该装置应用于运行管理器以监控所述超融合存储系统中各个节点内的虚拟卷控制器,具体如图8所示,该装置包括:
接收单元701,用于接收本地节点发送的创建虚拟卷控制器的请求;
判断单元702,用于根据所述接收单元701接收的请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;
第一反馈单元703,用于当所述判断单元702判断所述超融合存储系统中存在所述虚拟卷控制器时,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;
第二反馈单元704,用于当所述判断单元702判断所述超融合存储系统中不存在所述虚拟卷控制器时,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
进一步的,如图8所示,所述装置还包括:
获取单元705,用于当所述判断单元702判断超融合存储系统中不存在所述虚拟卷控制器时,获取所述本地节点中已创建的虚拟卷控制器的数量;
确定单元706,用于当所述获取单元705获取的数量超过阈值时,则通过预置规则确定创建所述虚拟卷控制器的其他节点;
发送单元707,用于向所述确定单元706确定的其他节点发送创建所述虚拟卷控制器的信息,以便所述其他节点创建所述虚拟卷控制器,并反馈创建结果;
所述第一反馈单元703还用于,当所述虚拟卷控制器成功创建在其他节点中时,则将所述其他节点的位置信息反馈给所述本地节点。
进一步的,如图9所示,所述装置还包括:
统计单元708,用于在所述接收单元701接收本地节点发送的创建虚拟卷控制器的请求之前,统计超融合存储系统中所有的虚拟卷控制器以及对应的节点位置,得到虚拟卷控制器列表;
所述接收单元701,还用于接收所述超融合存储系统中各个节点发送的虚拟卷控制器的心跳信息;
所述判断单元702,还用于根据所述接收单元接收的心跳信息判断所述虚拟卷控制器的运行状态;
删除单元709,用于当接收到虚拟卷控制器的运行状态异常或者注销信息时,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息。
进一步的,如图9所示,所述判断单元702还用于,当在预置时间段内没有接收到所述虚拟卷控制器列表中包含的第一虚拟卷控制器的心跳信息时,确定所述第一虚拟卷控制器的运行状态为异常。
进一步的,如图9所示,所述装置还包括:
选择单元710,用于所述删除单元709在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息之后,根据超融合存储系统中各个节点的负载情况选择一个其他节点;
所述发送单元707还用于,向所述选择单元710选择的其他节点中发送创建所述虚拟卷控制器的信息。
进一步的,作为对上述方法的实现以及上述基于超融合存储系统的数据读写控制方法、终端及系统,本发明实施例还提供一种存储终端,所述存储终端设置有如上述如图5及图6所示所述的基于超融合存储系统的数据读写控制装置,该存储终端对应于超融合存储系统中的节点服务器或主机等硬件设备,用于通过虚拟卷控制器控制对应虚拟卷执行读写操作。
进一步的,本发明实施例还提供一种基于超融合存储系统的数据读写控制系统,如图10所示,所述系统包括含有上述图6、7基于超融合存储系统的数据读写控制装置的存储终端81以及含有上述图8、9基于超融合存储系统的数据读写控制装置的控制终端82。
其中,所述存储终端81,可以是超融合存储系统中的所有节点服务器或主机等硬件设备,用于向管理器发送创建对应虚拟卷控制器的请求,并根据管理器反馈是否创建虚拟卷控制器或者反馈对应虚拟卷的位置信息,将对虚拟卷的读写请求发送至对应的虚拟卷控制器,实现虚拟卷控制器控制对应虚拟卷执行读写操作。
其中,所述控制终端82,可以是超融合存储系统中的一个或多个节点服务器或主机等硬件设备,在其上存在管理器,用于接收本地节点发送的创建对应虚拟卷控制器的请求,并反馈是否创建虚拟卷控制器或者反馈对应虚拟卷控制器的位置信息,实现监控超融合存储系统中各个节点内的虚拟卷控制器。
需要说明的是,上述的存储终端与控制终端在一些应用场景中也可以全部设置在同一个节点服务器或主机等硬件设备中。
综上所述,本发明实施例提供了一种基于超融合存储系统的数据读写控制方法、终端及系统,采用虚拟卷控制器控制管理对虚拟卷中数据的读写、修复、迁移等操作请求,同时一个虚拟卷控制器用于控制在超融合存储系统中创建的虚拟机所对应的唯一虚拟卷的读写、修复、迁移等操作,防止当对虚拟卷的处理请求被不同的虚拟卷控制器接收时,会出现对虚拟卷中数据的处理操作不一致的问题。基于上述虚拟卷对应唯一虚拟卷控制器,当查找本地主机不存在虚拟卷对应的虚拟卷控制器时,本地主机向管理器发送在本地主机创建虚拟卷控制器的请求,管理器会判断系统中其他主机是否存在该虚拟卷对应的虚拟卷控制器,若当其存在于其他主机上时,根据管理器的反馈,将对虚拟卷的处理操作请求发送至虚拟卷控制器所在的其他主机,若当系统中不存在对应的虚拟卷控制器时,则反馈创建对应虚拟卷控制器的信息,并且管理器基于存储的虚拟卷控制器列表信息,选择出负载较小的主机,并在其上创建虚拟卷控制器,以便于确保各个主机的负载均衡,上述管理器对虚拟卷控制器的调度管理,实现多个虚拟卷控制器可以分散在不同的主机上工作,并且根据各个主机的负载情况,实现管理器对虚拟卷控制器的有效调度,避免出现本地主机负载过大,而其他主机空闲的问题,进而提高了超融合存储系统中处理资源的有效利用。此外,在预置时间段内,管理器通过接收不同虚拟卷控制器发送的心跳信息,监控虚拟卷控制器是否运行正常,由于虚拟卷控制器是存在一定生命周期的,当虚拟卷控制器运行异常或者被注销,管理器删除虚拟卷控制器列表中的相应虚拟卷控制器信息,防止由于虚拟卷控制器运行异常或者被注销而导致的不能响应执行对虚拟卷中数据的读写请求,避免本地主机无法执行对虚拟卷中数据的读写操作。
所述存储终端包括处理器和存储器,上述查找单元、发送单元、和执行单元等均作为程序单元存储在存储器中,由处理器执行存储在存储器中的上述程序单元来实现相应的功能。
所述控制终端包括处理器和存储器,上述接收单元、判断单元、第一反馈单元和第二反馈单元等均作为程序单元存储在存储器中,由处理器执行存储在存储器中的上述程序单元来实现相应的功能。
处理器中包含内核,由内核去存储器中调取相应的程序单元。内核可以设置一个或以上,通过调整内核参数来提高了超融合存储系统中处理资源的有效利用。存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM),存储器包括至少一个存储芯片。
本发明实施例提供了一种设备,设备包括处理器、存储器及存储在存储器上并可在处理器上运行的程序,处理器执行程序时实现以下步骤:
当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作;
若不存在所述虚拟卷控制器,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制器;
基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
本发明实施例还提供了另外一种设备,设备包括处理器、存储器及存储在存储器上并可在处理器上运行的程序,处理器执行程序时实现以下步骤:
接收本地节点发送的创建虚拟卷控制器的请求;
根据所述请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;
若存在,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;
若不存在,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
在存储终端,本申请还提供了一种计算机程序产品,当在数据处理设备上执行时,适于执行初始化有如下方法步骤的程序代码:当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的唯一虚拟卷的读写操作;若不存在所述虚拟卷控制器,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制器;基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
在控制终端,本申请还提供了一种计算机程序产品,当在数据处理设备上执行时,适于执行初始化有如下方法步骤的程序代码:管理器接收本地节点发送的创建虚拟卷控制器的请求;根据所述请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;若存在,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;若不存在,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/ 输出接口、网络接口和内存。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。存储器是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器 (DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括要素的过程、方法、商品或者设备中还存在另外的相同要素。
本领域技术人员应明白,本申请的实施例可提供为方法、系统或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
以上仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。

Claims (17)

1.一种基于超融合存储系统的数据读写控制方法,其特征在于,所述方法包括:
当接收到本地节点的读写请求时,根据所述读写请求在本地节点查找对应的虚拟卷控制器,所述虚拟卷控制器用于控制超融合存储系统中创建的虚拟机所对应的虚拟卷的读写操作;
若不存在所述虚拟卷控制器,则向管理器发送在本地节点创建所述虚拟卷控制器的请求,所述管理器用于管理所述超融合存储系统中所有虚拟卷对应的虚拟卷控制器;
基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
2.根据权利要求1所述方法,其特征在于,基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作包括:
当所述管理器反馈不存在所述虚拟卷管理器时,在本地节点创建所述虚拟卷管理器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作;
将创建结果反馈给所述管理器进行记录。
3.根据权利要求1所述方法,其特征在于,基于所述管理器反馈所述请求的信息,实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作包括:
当所述管理器反馈所述虚拟卷控制器位于其他节点中时,提取所述其他节点的位置信息,以确定所述虚拟卷控制器的位置信息;
基于所述位置信息,将所述读写请求发送至所述虚拟卷控制器,以实现所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作。
4.根据权利要求1所述方法,其特征在于,所述方法还包括:
在所述虚拟卷控制器控制对应的虚拟卷执行相应的读写操作时,对执行所述读写操作对应的数据进行备份。
5.根据权利要求1所述方法,其特征在于,所述对执行所述读写操作对应的数据进行备份包括:
当所述数据为首次写操作时,获取所述虚拟卷的位置信息,以及所述读写操作对应数据的备份数量,并根据所述位置信息和所述备份数量确定数据备份的其他节点的位置信息,将所述数据备份在对应的其他节点中;
当所述数据为数据修改操作时,获取备份有原数据的其他节点的位置信息,并根据所述位置信息将所述数据替换所述其他节点中备份的原数据。
6.根据权利要求5所述方法,其特征在于,根据所述位置信息和所述备份数量确定数据备份的其他节点的位置信息包括:
根据所述位置信息按照距离本地节点由近到远的顺序对其他节点排序;
根据所述排序筛选出节点负载小于阈值的待选节点;
从所述待选节点中选择与备份数量相同个数的其他节点。
7.根据权利要求1所述方法,其特征在于,在根据所述读写请求在本地节点查找对应的虚拟卷控制器之前,所述方法还包括:
利用读写模块识别所接收读写请求的来源;
若所述读写请求来自于其他节点,则在本地节点已创建的虚拟卷控制器中查找对应的虚拟卷控制器,并执行相应的读写操作。
8.根据权利要求1所述方法,其特征在于,所述方法还包括:
获取本地节点中已创建的虚拟卷控制器的运行状态;
若所述运行状态正常,则向所述管理器发送对应虚拟卷控制器的心跳,以便所述管理器确认所述虚拟卷控制器运行正常;
若所述运行状态异常,则注销所述虚拟卷控制器,并向管理器发送注销结果。
9.根据权利要求8所述方法,其特征在于,注销所述虚拟卷控制器,并向管理器发送注销结果包括:
判断所述虚拟卷控制器的异常运行状态的持续时间是否达到阈值;
若达到,则注销所述虚拟卷控制器;
当注销成功后,将所述注销结果发送至所述管理器。
10.一种基于超融合存储系统的数据读写控制方法,其特征在于,所述方法包括:
管理器接收本地节点发送的创建虚拟卷控制器的请求;
根据所述请求判断所述超融合存储系统中是否存在所述虚拟卷控制器;
若存在,则将所述虚拟卷控制器所在的其他节点的位置信息反馈给所述本地节点,以便所述本地节点将所述虚拟卷控制器对应的读写请求发送至所述其他节点;
若不存在,则向所述本地节点反馈创建所述虚拟卷控制器的信息,以便本地节点根据所述信息创建所述虚拟卷控制器,并反馈创建结果。
11.根据权利要求10所述的方法,其特征在于,当所述超融合存储系统中不存在所述虚拟卷控制器时,所述方法还包括:
获取所述本地节点中已创建的虚拟卷控制器的数量;
当所述数量超过阈值时,则通过预置规则确定创建所述虚拟卷控制器的其他节点;
向所述其他节点发送创建所述虚拟卷控制器的信息,以便所述其他节点创建所述虚拟卷控制器,并反馈创建结果;
若所述虚拟卷控制器成功创建在其他节点中,则将所述其他节点的位置信息反馈给所述本地节点。
12.根据权利要求10所述的方法,其特征在于,在接收本地节点发送的创建虚拟卷控制器的请求之前,所述方法还包括:
统计超融合存储系统中所有的虚拟卷控制器以及对应的节点位置,得到虚拟卷控制器列表;
接收所述超融合存储系统中各个节点发送的虚拟卷控制器的心跳信息;
根据所述心跳信息判断所述虚拟卷控制器的运行状态;
当接收到虚拟卷控制器的运行状态异常或者注销信息时,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息。
13.根据权利要求12所述的方法,其特征在于,根据所述心跳信息判断所述虚拟卷控制器的运行状态包括:
当在预置时间段内没有接收到所述虚拟卷控制器列表中包含的第一虚拟卷控制器的心跳信息时,确定所述第一虚拟卷控制器的运行状态为异常。
14.根据权利要求12所述的方法,其特征在于,在所述虚拟卷控制器列表中删除所述虚拟卷控制器对应的相关信息之后,所述方法还包括:
根据超融合存储系统中各个节点的负载情况选择一个其他节点;
向所述其他节点中发送创建所述虚拟卷控制器的信息。
15.一种存储终端,其特征在于,所述终端中包括处理器和存储介质,所述处理器和所述存储介质在进行数据读写控制操作时,能够执行如权利要求1至权利要求9中任一项所述的基于超融合存储系统的数据读写控制方法,用于通过虚拟卷控制器控制对应虚拟卷执行读写操作。
16.一种控制终端,其特征在于,所述终端中包括处理器和存储介质,所述处理器和所述存储介质在进行数据读写控制操作时,能够执行如权利要求10至权利要求14中任一项所述的基于超融合存储系统的数据读写控制方法,用于运行管理器以监控所述超融合存储系统中各个节点内的虚拟卷控制器。
17.一种基于超融合存储系统的数据读写控制系统,其特征在于,所述系统中包括有如权利要求15所述的存储终端以及如权利要求16所述的控制终端。
CN201711147517.3A 2017-11-17 2017-11-17 基于超融合存储系统的数据读写控制方法、终端及系统 Active CN107894874B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711147517.3A CN107894874B (zh) 2017-11-17 2017-11-17 基于超融合存储系统的数据读写控制方法、终端及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711147517.3A CN107894874B (zh) 2017-11-17 2017-11-17 基于超融合存储系统的数据读写控制方法、终端及系统

Publications (2)

Publication Number Publication Date
CN107894874A true CN107894874A (zh) 2018-04-10
CN107894874B CN107894874B (zh) 2020-08-21

Family

ID=61805464

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711147517.3A Active CN107894874B (zh) 2017-11-17 2017-11-17 基于超融合存储系统的数据读写控制方法、终端及系统

Country Status (1)

Country Link
CN (1) CN107894874B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109086364A (zh) * 2018-07-19 2018-12-25 深圳市网心科技有限公司 数据管理方法、数据管理设备及存储介质
CN111130939A (zh) * 2019-12-26 2020-05-08 深圳前海环融联易信息科技服务有限公司 一种流量控制方法、装置、计算机设备及存储介质
TWI697786B (zh) * 2019-05-24 2020-07-01 威聯通科技股份有限公司 基於超融合基礎架構的虛擬機器建立方法
CN112433675A (zh) * 2020-11-23 2021-03-02 山东可信云信息技术研究院 一种针对超融合架构的存储空间优化方法及系统

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1684029A (zh) * 2004-04-14 2005-10-19 株式会社日立制作所 存储系统
CN101751228A (zh) * 2009-12-29 2010-06-23 成都市华为赛门铁克科技有限公司 磁盘阵列的实现方法和数据读写方法及装置
CN102624911A (zh) * 2012-03-14 2012-08-01 中山大学 一种基于集群的可视媒体存储系统
US20160139813A1 (en) * 2008-09-16 2016-05-19 Micron Technology, Inc. Re-building mapping information for memory devices

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1684029A (zh) * 2004-04-14 2005-10-19 株式会社日立制作所 存储系统
US20160139813A1 (en) * 2008-09-16 2016-05-19 Micron Technology, Inc. Re-building mapping information for memory devices
CN101751228A (zh) * 2009-12-29 2010-06-23 成都市华为赛门铁克科技有限公司 磁盘阵列的实现方法和数据读写方法及装置
CN102624911A (zh) * 2012-03-14 2012-08-01 中山大学 一种基于集群的可视媒体存储系统

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
杨树庆: "集群化的虚拟共享卷服务系统研究", 《中国优秀博硕士学位论文全文数据库(硕士)信息科技辑》 *

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109086364A (zh) * 2018-07-19 2018-12-25 深圳市网心科技有限公司 数据管理方法、数据管理设备及存储介质
TWI697786B (zh) * 2019-05-24 2020-07-01 威聯通科技股份有限公司 基於超融合基礎架構的虛擬機器建立方法
CN111130939A (zh) * 2019-12-26 2020-05-08 深圳前海环融联易信息科技服务有限公司 一种流量控制方法、装置、计算机设备及存储介质
CN111130939B (zh) * 2019-12-26 2021-09-10 深圳前海环融联易信息科技服务有限公司 一种流量控制方法、装置、计算机设备及存储介质
CN112433675A (zh) * 2020-11-23 2021-03-02 山东可信云信息技术研究院 一种针对超融合架构的存储空间优化方法及系统
CN112433675B (zh) * 2020-11-23 2024-03-08 山东可信云信息技术研究院 一种针对超融合架构的存储空间优化方法及系统

Also Published As

Publication number Publication date
CN107894874B (zh) 2020-08-21

Similar Documents

Publication Publication Date Title
US10613780B1 (en) Multi-node removal
CN109857445B (zh) 存储系统和控制软件配置方法
US10177994B2 (en) Fault tolerant federation of computing clusters
CN107894874A (zh) 基于超融合存储系统的数据读写控制方法、终端及系统
US9756128B2 (en) Switched direct attached shared storage architecture
US9489443B1 (en) Scheduling of splits and moves of database partitions
US9590843B2 (en) Method and system for providing distributed management in a networked virtualization environment
CN104780071B (zh) 虚拟交换机的升级方法及装置
CN112099918A (zh) 容器化环境中的集群的实时迁移
US9720606B2 (en) Methods and structure for online migration of data in storage systems comprising a plurality of storage devices
CN105429776B (zh) 一种虚拟化网络功能管理的方法和系统
US11249788B2 (en) Cloud management platform, and virtual machine management method and system
DE202015009861U1 (de) Systeme zur Bereitstellung von Ressourcen
CN106664216A (zh) 一种切换vnf的方法和装置
CN108319623A (zh) 一种数据重分布方法、装置及数据库集群
CN108319618B (zh) 一种分布式存储系统的数据分布控制方法、系统及装置
CN105827678B (zh) 一种基于高可用架构下的通信方法和节点
CN113296882A (zh) 容器编排方法、设备、系统及存储介质
CN111930716A (zh) 一种数据库扩容方法、装置及系统
CN107864055A (zh) 虚拟化系统的管理方法及平台
CN107682411A (zh) 一种大规模sdn控制器集群及网络系统
CN108170507A (zh) 虚拟应用管理方法/系统、计算机可读存储介质及服务端
CN104793981A (zh) 一种虚拟机集群的在线快照管理方法及装置
CN104461779B (zh) 一种分布式数据的存储方法、装置及系统
CN110413369A (zh) 用于虚拟化环境中的备份的系统和方法

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
GR01 Patent grant
GR01 Patent grant