CN114003181A - 数据写镜像系统、方法、装置、电子设备及存储介质 - Google Patents
数据写镜像系统、方法、装置、电子设备及存储介质 Download PDFInfo
- Publication number
- CN114003181A CN114003181A CN202210000453.9A CN202210000453A CN114003181A CN 114003181 A CN114003181 A CN 114003181A CN 202210000453 A CN202210000453 A CN 202210000453A CN 114003181 A CN114003181 A CN 114003181A
- Authority
- CN
- China
- Prior art keywords
- controller
- memory
- data
- target
- memory space
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 35
- 230000015654 memory Effects 0.000 claims abstract description 191
- 238000012545 processing Methods 0.000 claims description 12
- 238000010586 diagram Methods 0.000 description 11
- 230000001360 synchronised effect Effects 0.000 description 5
- 125000004122 cyclic group Chemical group 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0608—Saving storage space on storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0625—Power saving in storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0629—Configuration or reconfiguration of storage systems
- G06F3/0631—Configuration or reconfiguration of storage systems by allocating resources to storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/0644—Management of space entities, e.g. partitions, extents, pools
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0658—Controller construction arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0674—Disk device
- G06F3/0676—Magnetic disk device
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
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)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
本发明涉及一种数据写镜像系统、方法、装置、电子设备及存储介质,所述系统包括:至少两个内存扩展卡、多个控制器、多个控制器CPU,其中,所述内存扩展卡设置于IO槽位;每个控制器上设置有一个控制器CPU,所述控制器的数量与所述控制器CPU的数量相同;所述多个控制器分别与所述至少两个内存扩展卡连接;每个所述内存扩展卡的内存空间按照控制器数量划分,为每个所述控制器划分对应的内存空间,由此系统,可以实现写缓存数据的稳定性的同时节约内存空间资源。
Description
技术领域
本发明涉及数据处理领域,尤其涉及一种数据写镜像系统、方法、装置、电子设备及存储介质。
背景技术
由于存储产品对数据可靠性要求非常高,同时又要兼顾存储性能,因此,在数据写入硬盘之前,需要先在内存中缓存,系统空闲或者缓存数据达到一定水位,再通过CPU单独的线程将缓存数据写入硬盘。但是,缓存中的数据是不安全的,当系统掉电或者控制器突然故障,必须有能力将缓存中的数据刷写到硬盘中,系统掉电时,可以采用BBU电池给系统供电保障缓存数据安全的写到硬盘,但是当控制器突然故障时,在目前的存储系统中,通常采用双写技术来保障控制器缓存数据不丢失,即本控的写数据除了在本地缓存中保留一份副本,还需要同时在其它单控或多控中备份,以保证本控出现故障使,其它控制器可以将本控未落盘的数据写入到硬盘中。
然而,传统基于本地内存的存储架构写镜像存在很多不足,以单框四控(即一个机箱包含四个控制器)为例如图1所示,每个控制器有自己的本地内存,控制器之间通过PCIe/CXL总线互联,本控的写数据在本地保留一份副本,同时通过PCIe/CXL互联总线同步给其它单控或多控备份。备份的方式有多种,其中比较典型的有两副本循环镜像和四副本全镜像,首先两副本循环镜像如图2所示,其原理是:控制器1缓存中除了本控的副本,同时还有控制器2的副本,控制器2缓存中除了本控的副本,同时还有控制器3的副本,控制器3缓存中除了本控的副本,同时还有控制器4的副本,控制器4缓存中除了本控的副本,同时还有控制器1的副本。这样每个控制器数据都在其它控制器保留了一份副本,当某个控制器故障了,可以将它另一个副本写到硬盘,但是,这样的两副本循环镜像最大的缺陷就是同一时间只能允许一个控制器故障,如果是两个或两个以上控制器故障,将会导致数据丢失。
另一种四副本全镜像如果3所示,每个控制器的缓存中除了本控副本,同时还有其它三个控制器的副本。四副本全镜像方式虽然解决了控制器同时坏1/2/3个的问题,但是全镜像要将相同副本同时保存四份,需占用较大的内存空间和总线带宽。因此,如何实现写缓存数据稳定性的同时节约内存空间资源成为亟待解决的问题。
发明内容
鉴于此,为解决上述技术问题或部分技术问题,本发明提供一种数据写镜像系统、方法、装置、电子设备及存储介质。
第一方面,本发明提供一种数据写镜像系统,包括:
至少两个内存扩展卡、多个控制器、多个控制器CPU,其中,所述内存扩展卡设置于IO槽位;
每个控制器上设置有一个控制器CPU,所述控制器的数量与所述控制器CPU的数量相同;
所述多个控制器分别与所述至少两个内存扩展卡连接;
将每个内存扩展卡的内存空间按照控制器数量划分,为每个控制器划分对应的内存空间。
可选的,所述控制器用于将目标数据同时写入多个内存扩展卡的对应内存空间中;
在所述内存扩展卡中任一内存空间占用量达到占用量阈值时,该内存空间对应的控制器将内存空间中的数据存储到目标硬盘。
可选的,所述控制器CPU用于访问对应控制器的内存空间和对应内存扩展卡中对应的内存区域。
第二方面,本发明提供一种数据写镜像方法,包括:
获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;
基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
在一个可能的实施方式中,所述方法还包括:
若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
在一个可能的实施方式中,所述方法还包括:
在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
第三方面,本发明提供一种数据写镜像装置,其特征在于,包括:
获取模块,用于获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;
存储模块,用于基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
在一个可能的实施方式中,所述装置还包括:故障处理模块,用于若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
第四方面,本发明提供一种电子设备,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的数据写镜像程序,以实现上述第二方面中所述的数据写镜像方法。
第五方面,本发明提供一种存储介质,包括:所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述第二方面中所述的数据写镜像方法。
本发明提供的数据写镜像系统,包括至少两个内存扩展卡、多个控制器、多个控制器CPU,其中,所述内存扩展卡设置于IO槽位;每个控制器上设置有一个控制器CPU,所述控制器的数量与所述控制器CPU的数量相同;所述多个控制器分别与所述至少两个内存扩展卡连接;将每个内存扩展卡的内存空间按照控制器数量划分,为每个控制器划分对应的内存空间,相比于现有技术中的两副本循环镜像系统同一时间只能允许一个控制器故障,如果是两个或两个以上控制器故障,将会导致数据丢失的情况和四副本全镜像要将相同副本同时保存四份占用较大的内存空间和总线带宽的情况,由本系统,可以实现写缓存数据稳定性的同时节约内存空间资源。
本发明提供的数据写镜像方案,通过获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间;若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中;相比于现有技术中的两副本循环镜像系统同一时间只能允许一个控制器故障,如果是两个或两个以上控制器故障,将会导致数据丢失的情况和四副本全镜像要将相同副本同时保存四份占用较大的内存空间和总线带宽的情况,由本方案,可以实现写缓存数据稳定性的同时节约内存空间资源。
附图说明
图1为单框四控镜像架构示意图;
图2为两副本循环镜像示意图;
图3为四副本全镜像示意图;
图4为本发明的数据写镜像系统架构示意图;
图5为本发明的至少两张内存扩展卡区域划分示意图;
图6为本发明的一种数据写镜像方法的流程示意图;
图7为本发明的一种数据写镜像装置的结构示意图;
图8为本发明的一种电子设备的结构示意图;
图9为不同控制器同时故障场景示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
为便于对本发明实施例的理解,下面将结合附图以具体实施例做进一步的解释说明,实施例并不构成对本发明实施例的限定。
图4为本发明的数据写镜像系统架构示意图,如图4所示,本发明的数据写镜像系统包括:至少两个内存扩展卡、多个控制器、多个控制器CPU;图中以两个内存扩展卡、四个控制器、四个控制器CPU为例,利用CXL2.0协议技术,将内存扩展卡独立出CPU的本地内存槽位,放置于IO槽位上,由于每个内存扩展卡上面的存储单元支持CXL2.0接口协议,并通过CXL2.0的Switch交换机可以与四个控制器同时连接,实现四个控制器对两张内存扩展卡均可以访问,本实施例中,将两张内存扩展卡的内存空间平均分为四个区域,分别分配给四个控制器,四个控制器将该内存区域与本地内存区域统一编址。
进一步的,每个控制器上设置有一个控制器CPU,控制器的数量与控制器CPU的数量相同;使每个控制器CPU既可以访问DIMM槽位上的内存空间,又可以访问IO槽位上内存扩展卡对应的内存区域,实现了全局内存空间。
进一步的,每个控制器的写镜像数据同时写到两张内存扩展卡的对应区域中,如图5所示,其中,写镜像数据包括元数据和用户数据等。在内存扩展卡中任一内存空间占用量达到占用量阈值(例如,80%)时,该内存空间对应的控制器将内存空间中的数据存储到目标硬盘,确保内存区域不会溢出。
本发明实施例提供的数据写镜像系统,包括至少两个内存扩展卡、多个控制器、多个控制器CPU,其中,所述内存扩展卡设置于IO槽位;每个控制器上设置有一个控制器CPU,所述控制器的数量与所述控制器CPU的数量相同;所述多个控制器分别与所述至少两个内存扩展卡连接;将每个内存扩展卡的内存空间按照控制器数量划分,为每个控制器划分对应的内存空间,相比于现有技术中的两副本循环镜像系统同一时间只能允许一个控制器故障,如果是两个或两个以上控制器故障,将会导致数据丢失的情况和四副本全镜像要将相同副本同时保存四份占用较大的内存空间和总线带宽的情况,由本系统,可以实现写缓存数据稳定性的同时节约内存空间资源。
图6为本发明的一种数据写镜像方法的流程示意图,如图6所示,该方法具体包括:
S61、获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息。
S62、基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
以下对S61~S62进行统一说明:
数据写镜像系统中的一个或多个控制器获取目标数据,其中,目标数据携带有目标存储控制器的标识信息,标识信息可以是控制器的名称、编号等信息,控制器基于标识信息确定目标存储控制器对应的两张内存扩展卡的对应内存空间,将目标数据同时写到两张内存扩展卡的对应内存空间中。
S63、若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
本实施例中,本发明的数据写镜像系统支持控制器四坏三,包括三控同时故障的场景,可靠性更高,如图9所示,当控制器1故障,对应内存区域由控制器2接管并把内存数据安全刷写到硬盘中;当控制器1和2同时故障,对应内存区域由控制器3接管并把内存数据安全刷写到硬盘中;当控制器1、2和3同时故障,对应内存区域由控制器4接管并把内存数据安全刷写到硬盘中。同理,控制器4故障,对应内存区域由控制器1接管并把内存数据安全刷写到硬盘中,依此类推,前面控制器故障,由后面紧挨着的控制器接管对应内存区域,最极限的场景可以保障控制器同时故障四个而不丢数据,极大提升系统可靠性。
本发明还可以有效节约内存空间,以一框四控为例,假如每控所需缓存空间大小相同,下表1呈现两副本循环镜像、四副本全镜像和基于全局内存的写镜像对内存空间的占用情况。
镜像方案 | 内存空间占用 |
两副本循环镜像 | 8 |
四副本全镜像 | 16 |
基于全局内存的写镜像 | 8 |
表1
从表1中可以看出,四副本全镜像在相同情况下需要16个内存区域,两副本循环镜像和基于全局内存的写镜像最优,只需要个8内存区域,因此,基于全局内存的写镜像系统不仅有效提升数据可靠性,系统稳定性,同时还节约内存空间资源。
S64、在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
本发明实施例中,在控制器将目标数据同时写到两张内存扩展卡的对应内存空间中时,若内存卡中对应的内存空间的占用量达到占用量阈值(例如,80%)时,将内存空间的全部数据存储到目标硬盘,确保内存区域不会溢出。
本发明实施例提供的数据写镜像方法,通过获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间;若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中;相比于现有技术中的两副本循环镜像系统同一时间只能允许一个控制器故障,如果是两个或两个以上控制器故障,将会导致数据丢失的情况和四副本全镜像要将相同副本同时保存四份占用较大的内存空间和总线带宽的情况,由本方法,可以实现写缓存数据稳定性的同时节约内存空间资源。
图7为本发明的一种数据写镜像装置的结构示意图,具体包括:
获取模块701,用于获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;
存储模块702,用于基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
故障处理模块703,用于若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
在一个可能的实施方式中,所述存储模块702,具体用于在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
本实施例提供的数据写镜像装置可以是如图7中所示的数据写镜像装置,可执行如图6中数据写镜像方法的所有步骤,进而实现图6所示数据写镜像方法的技术效果,具体请参照图6相关描述,为简洁描述,在此不作赘述。
图8为本发明实施例提供的一种电子设备的结构示意图,图8所示的电子设备800包括:至少一个处理器801、存储器802、至少一个网络接口804和其他用户接口803。电子设备800中的各个组件通过总线系统805耦合在一起。可理解,总线系统805用于实现这些组件之间的连接通信。总线系统805除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图8中将各种总线都标为总线系统805。
其中,用户接口803可以包括显示器、键盘或者点击设备(例如,鼠标,轨迹球(trackball)、触感板或者触摸屏等。
可以理解,本发明实施例中的存储器802可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(Read-Only Memory,ROM)、可编程只读存储器 (Programmable ROM,PROM)、可擦除可编程只读存储器(Erasable PROM,EPROM)、电可擦除可编程只读存储器(Electrically EPROM,EEPROM)或闪存。易失性存储器可以是随机存取存储器(Random Access Memory,RAM),其用作外部高速缓存。通过示例性但不是限制性说明,许多形式的RAM可用,例如静态随机存取存储器(Static RAM,SRAM)、动态随机存取存储器 (Dynamic RAM,DRAM)、同步动态随机存取存储器(Synchronous DRAM,SDRAM)、双倍数据速率同步动态随机存取存储器(Double DataRate SDRAM,DDRSDRAM)、增强型同步动态随机存取存储器(Enhanced SDRAM,ESDRAM)、同步连接动态随机存取存储器(Synch link DRAM,SLDRAM)和直接内存总线随机存取存储器(Direct Rambus RAM,DRRAM)。本文描述的存储器802旨在包括但不限于这些和任意其它适合类型的存储器。
在一些实施方式中,存储器802存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统8021和应用程序8022。
其中,操作系统8021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序8022,包含各种应用程序,例如媒体播放器(Media Player)、浏览器(Browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序8022中。
在本发明实施例中,通过调用存储器802存储的程序或指令,具体的,可以是应用程序8022中存储的程序或指令,处理器801用于执行各方法实施例所提供的方法步骤,例如包括:
获取目标数据;基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
在一个可能的实施方式中,若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
在一个可能的实施方式中,在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
上述本发明实施例揭示的方法可以应用于处理器801中,或者由处理器801实现。处理器801可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器801中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器801可以是通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(FieldProgrammable Gate Array, FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本发明实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件单元组合执行完成。软件单元可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器802,处理器801读取存储器802中的信息,结合其硬件完成上述方法的步骤。
可以理解的是,本文描述的这些实施例可以用硬件、软件、固件、中间件、微码或其组合来实现。对于硬件实现,处理单元可以实现在一个或多个专用集成电路(ApplicationSpecific Integrated Circuits,ASIC)、数字信号处理器(Digital Signal Processing,DSP)、数字信号处理设备(DSPDevice,DSPD)、可编程逻辑设备(Programmable LogicDevice,PLD)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)、通用处理器、控制器、微控制器、微处理器、用于执行本申请所述功能的其它电子单元或其组合中。
对于软件实现,可通过执行本文所述功能的单元来实现本文所述的技术。软件代码可存储在存储器中并通过处理器执行。存储器可以在处理器中或在处理器外部实现。
本实施例提供的电子设备可以是如图8中所示的电子设备,可执行如图6中数据写镜像方法的所有步骤,进而实现图6所示数据写镜像方法的技术效果,具体请参照图6相关描述,为简洁描述,在此不作赘述。
本发明实施例还提供了一种存储介质(计算机可读存储介质)。这里的存储介质存储有一个或者多个程序。其中,存储介质可以包括易失性存储器,例如随机存取存储器;存储器也可以包括非易失性存储器,例如只读存储器、快闪存储器、硬盘或固态硬盘;存储器还可以包括上述种类的存储器的组合。
当存储介质中一个或者多个程序可被一个或者多个处理器执行,以实现上述在电子设备侧执行的数据写镜像方法。
所述处理器用于执行存储器中存储的数据写镜像程序,以实现以下在电子设备侧执行的数据写镜像方法的步骤:
获取目标数据;基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
在一个可能的实施方式中,若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
在一个可能的实施方式中,在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
专业人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种数据写镜像系统,其特征在于,包括:至少两个内存扩展卡、多个控制器、多个控制器CPU,其中,所述内存扩展卡设置于IO槽位;
每个控制器上设置有一个控制器CPU,所述控制器的数量与所述控制器CPU的数量相同;
所述多个控制器分别与所述至少两个内存扩展卡连接;
每个所述内存扩展卡的内存空间按照控制器数量划分,为每个所述控制器划分对应的内存空间。
2.根据权利要求1所述的系统,其特征在于,所述控制器用于将目标数据同时写入多个内存扩展卡的对应内存空间中;
在所述内存扩展卡中任一内存空间占用量达到占用量阈值时,该内存空间对应的控制器将内存空间中的数据存储到目标硬盘。
3.根据权利要求2所述的系统,其特征在于,所述控制器CPU用于访问对应控制器的内存空间和对应内存扩展卡中对应的内存区域。
4.一种数据写镜像方法,应用于如权利要求1-3任一所述的数据写镜像系统,其特征在于,包括:
获取目标数据,其中,所述目标数据携带有目标存储控制器的标识信息;
基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
6.根据权利要求4所述的方法,其特征在于,所述方法还包括:
在所述内存空间占用量达到占用量阈值时,将所述内存空间中的全部数据存储到目标硬盘。
7.一种数据写镜像装置,其特征在于,包括:
获取模块,用于获取目标数据,所述目标数据携带有目标存储控制器的标识信息;
存储模块,用于基于所述标识信息,将所述目标数据存储到全部内存扩展卡中所述目标存储控制器对应的内存空间。
8.根据权利要求7所述的装置,其特征在于,还包括:
故障处理模块,用于若第一控制器出现故障,则向第二控制器发送故障消息,以使所述第二控制器访问内存扩展卡中所述第一控制器对应的内存空间中的目标数据,将所述目标数据存储到目标硬盘中。
9.一种电子设备,其特征在于,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的数据写镜像程序,以实现权利要求4~6中任一项所述的数据写镜像方法。
10.一种存储介质,其特征在于,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现权利要求4~6中任一项所述的数据写镜像方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210000453.9A CN114003181B (zh) | 2022-01-04 | 2022-01-04 | 数据写镜像系统、方法、装置、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210000453.9A CN114003181B (zh) | 2022-01-04 | 2022-01-04 | 数据写镜像系统、方法、装置、电子设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114003181A true CN114003181A (zh) | 2022-02-01 |
CN114003181B CN114003181B (zh) | 2022-05-20 |
Family
ID=79932484
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210000453.9A Active CN114003181B (zh) | 2022-01-04 | 2022-01-04 | 数据写镜像系统、方法、装置、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114003181B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117389483A (zh) * | 2023-12-11 | 2024-01-12 | 北京开源芯片研究院 | 一种内存管理方法、装置、电子设备及可读存储介质 |
CN117632808A (zh) * | 2024-01-24 | 2024-03-01 | 苏州元脑智能科技有限公司 | 多控存储阵列、存储系统、数据处理方法以及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102567227A (zh) * | 2012-01-13 | 2012-07-11 | 北京邦诺存储科技有限公司 | 共享缓存设备的双控制器存储系统和方法 |
WO2016041127A1 (zh) * | 2014-09-15 | 2016-03-24 | 华为技术有限公司 | 重复数据删除方法和存储阵列 |
WO2018120171A1 (zh) * | 2016-12-30 | 2018-07-05 | 华为技术有限公司 | 一种用于存储过程的执行方法、设备以及系统 |
WO2021012169A1 (zh) * | 2019-07-22 | 2021-01-28 | 华为技术有限公司 | 一种提高存储系统可靠性的方法和相关装置 |
-
2022
- 2022-01-04 CN CN202210000453.9A patent/CN114003181B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102567227A (zh) * | 2012-01-13 | 2012-07-11 | 北京邦诺存储科技有限公司 | 共享缓存设备的双控制器存储系统和方法 |
WO2016041127A1 (zh) * | 2014-09-15 | 2016-03-24 | 华为技术有限公司 | 重复数据删除方法和存储阵列 |
WO2018120171A1 (zh) * | 2016-12-30 | 2018-07-05 | 华为技术有限公司 | 一种用于存储过程的执行方法、设备以及系统 |
WO2021012169A1 (zh) * | 2019-07-22 | 2021-01-28 | 华为技术有限公司 | 一种提高存储系统可靠性的方法和相关装置 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117389483A (zh) * | 2023-12-11 | 2024-01-12 | 北京开源芯片研究院 | 一种内存管理方法、装置、电子设备及可读存储介质 |
CN117389483B (zh) * | 2023-12-11 | 2024-02-23 | 北京开源芯片研究院 | 一种内存管理方法、装置、电子设备及可读存储介质 |
CN117632808A (zh) * | 2024-01-24 | 2024-03-01 | 苏州元脑智能科技有限公司 | 多控存储阵列、存储系统、数据处理方法以及存储介质 |
CN117632808B (zh) * | 2024-01-24 | 2024-04-26 | 苏州元脑智能科技有限公司 | 多控存储阵列、存储系统、数据处理方法以及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN114003181B (zh) | 2022-05-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN114003181B (zh) | 数据写镜像系统、方法、装置、电子设备及存储介质 | |
US10261906B2 (en) | Data accessing method and apparatus | |
US9009580B2 (en) | System and method for selective error checking | |
CN102317925B (zh) | 存储器系统和控制存储器系统的方法 | |
US20040133743A1 (en) | RAID apparatus and logical device expansion method thereof | |
US11334415B2 (en) | Data storage device and method for sharing memory of controller thereof | |
US11030088B2 (en) | Pseudo main memory system | |
US11561715B2 (en) | Method and apparatus for presearching stored data | |
JPWO2010016115A1 (ja) | ディスクアレイ装置の制御ユニット、データ転送装置及び復電処理方法 | |
US20040103247A1 (en) | Storage control apparatus and control method thereof | |
US20230163789A1 (en) | Stripe management method, storage system, stripe management apparatus, and storage medium | |
CN110795279B (zh) | 用于促进dram数据缓存转储和机架级电池备份的系统和方法 | |
US20240160528A1 (en) | Data Storage Method and Apparatus in Storage System | |
KR20180044095A (ko) | 전자 시스템 및 그것의 동작 방법 | |
CN113031876A (zh) | 一种数据处理方法、装置、设备及可读存储介质 | |
US20130166860A1 (en) | Memory access control device and computer system | |
CN111611223A (zh) | 非易失性数据的访问方法、系统、电子设备和介质 | |
CN117687835A (zh) | 数据处理系统、内存镜像方法、装置和计算设备 | |
EP3822796A1 (en) | Memory interleaving method and device | |
EP0323123A2 (en) | A storage control system in a computer system | |
CN116774911A (zh) | 内存管理方法和装置 | |
CN110119245B (zh) | 用于操作nand闪存物理空间以扩展存储器容量的方法和系统 | |
CN114610243A (zh) | 一种精简卷转换方法、系统、存储介质及设备 | |
CN111897676A (zh) | 一种基于数据库索引的文件备份方法及装置 | |
CN113448722A (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 |