数据写入、读取方法与系统、数据读写系统与流程

文档序号:15163738发布日期:2018-08-14 17:10阅读:177来源:国知局

本发明涉及计算机技术领域,尤其涉及一种数据写入、读取方法与系统、数据读写系统。



背景技术:

计算机的操作系统在运行中产生数据时,需要对计算机硬盘进行写入操作,由操作系统向驱动发送写入扇区请求,驱动收到请求后向硬盘发送写控制指令,以将数据写入硬盘;而在对计算机硬盘进行读取操作时,则由操作系统向驱动发送读取扇区请求,驱动收到请求后向硬盘发送读控制指令,以从硬盘读取数据。

本发明人在实施本发明的过程中发现,现有技术中存在以下技术问题:

一方面,硬盘存在损坏的可能性,一旦出现硬盘坏道,硬盘存储的数据就会损坏;

另一方面,个人计算机的硬盘空间容量有限,容量满足不了需求。



技术实现要素:

本发明提出一种数据写入、读取方法与系统、数据读写系统,可降低存储数据丢失的概率。

本发明一方面提供一种数据写入方法,所述数据写入方法包括:

响应于计算机的操作系统发送的写入扇区请求,驱动根据所述写入扇区请求获取待写入的扇区数据和所述计算机的扇区编号;

所述驱动根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址;

所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据;

所述n个负载服务器分别将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

作为更优选的,所述驱动根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,包括:

所述驱动向元服务器发送所述扇区编号和所述唯一标识符;

所述元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址。

在一种可选的实施方式中,所述n个负载服务器分别将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储,包括:

每个所述负载服务器判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据;

当判定存储了所述历史数据时,擦除所述历史数据并将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储;

当判定没有所述历史数据时,将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

在一种可选的实施方式中,所述元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,包括:

所述元服务器判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录;

当判定有所述写入记录时,所述元服务器根据所述写入记录向所述驱动返回对应于所述唯一标识符且对应于所述扇区编号的n个负载服务器的地址;

当判定无所述写入记录时,所述元服务器向所述驱动返回n个可用的负载服务器的地址;

所述数据写入方法还包括:

每个所述负载服务器在对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储后向所述元服务器发送通知;

所述元服务器在接收到所述通知后,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录。

在一种可选的实施方式中,所述当判定无所述写入记录时,所述元服务器向所述驱动返回n个可用的负载服务器的地址,包括:

当判定无所述写入记录时,所述元服务器根据负载服务器群的每个负载服务器的资源空闲量计算所述负载服务器群的每个负载服务器的压力系数;

根据所述压力系数对所述负载服务器群的所有负载服务器进行排序;

从所述负载服务器群的所有负载服务器中选取所述压力系数最小的n个负载服务器;

向所述驱动返回所述压力系数最小的n个负载服务器的地址,作为n个可用的负载服务器的地址。

本发明还提供了一种数据读取方法,所述数据读取方法包括:

响应于计算机的操作系统发送的读取扇区请求,所述驱动根据所述写入扇区请求获取所述计算机的扇区编号;

所述驱动根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址;其中,所述n个负载服务器预先存储了对应于所述唯一标识符且对应于所述扇区编号的扇区数据;

所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求;

所述n个负载服务器分别根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动;

所述驱动将接收的所述扇区数据发送给所述操作系统。

作为更优选地,所述驱动根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址,包括

所述驱动向元服务器发送所述唯一标识符和所述扇区编号;

所述元服务器根据接收的所述唯一标识符、所述扇区编号将预先存储的对应于所述唯一标识符且对应于所述扇区编号的所有负载服务器的地址发送给所述驱动。

在一种可选的实施方式中,所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求,包括:

所述驱动根据所述唯一标识符和所述扇区编号获取对应于所述唯一标识符且对应于所述扇区编号的扇区容量;

所述驱动根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求;

所述驱动根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求;

所述n个负载服务器分别根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动,包括:

所述n个负载服务器分别根据接收的所述对应部分的数据的获取请求将所述对应部分的数据发送给所述驱动;

所述驱动将接收的所述扇区数据发送给所述操作系统,包括:

所述驱动将接收的n个所述对应部分的数据进行合成,以得到合成后的扇区数据;

所述驱动将所述合成后的扇区数据发送给所述操作系统。

本发明还提供一种数据写入系统,所述数据写入系统包括驱动和n个负载服务器;

所述驱动包括:

第一获取模块,用于响应于计算机的操作系统发送的写入扇区请求,根据所述写入扇区请求获取待写入的扇区数据和所述计算机的扇区编号;

第二获取模块,用于根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址;

第一发送模块,用于根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据;

所述负载服务器包括第一存储模块,用于将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

作为更优选地,所述数据写入系统还包括元服务器;

所述第二获取模块还包括第一发送单元,用于向元服务器发送所述扇区编号和所述唯一标识符;

所述元服务器包括第一返回模块,用于在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址。

在一种可选的实施方式中,所述第一存储模块包括:

历史数据判断单元,用于判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据;

擦除判定单元,用于当判定存储了所述历史数据时,擦除所述历史数据并将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储;

存储判定单元,用于当判定没有所述历史数据时,将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

在一种可选的实施方式中,所述第一返回模块包括:

第一判断单元,用于判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录;

第一判定单元,用于当判定有所述写入记录时,根据所述写入记录向所述驱动返回对应于所述唯一标识符且对应于所述扇区编号的n个负载服务器的地址;

第二判定单元,用于当判定无所述写入记录时,向所述驱动返回n个可用的负载服务器的地址;

所述负载服务器还包括第一通知模块,用于在对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储后向所述元服务器发送通知;

所述元服务器还包括第一记录模块,用于在接收到所述通知后,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录。

在一种可选的实施方式中,所述第二判定单元包括:

系数计算单元,用于当判定无所述写入记录时,根据负载服务器群的每个负载服务器的资源空闲量计算所述负载服务器群的每个负载服务器的压力系数;

第一排序单元,用于根据所述压力系数对所述负载服务器群的所有负载服务器进行排序;

服务器选取单元,用于从所述负载服务器群的所有负载服务器中选取所述压力系数最小的n个负载服务器;

地址返回单元,用于向所述驱动返回所述压力系数最小的n个负载服务器的地址,作为n个可用的负载服务器的地址。

本发明还提供了一种数据读取系统,所述数据读取系统包括驱动和n个负载服务器;

所述驱动包括:

第三获取模块,用于响应于计算机的操作系统发送的读取扇区请求,所述驱动根据所述写入扇区请求获取所述计算机的扇区编号;

第四获取模块,用于根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址;其中,所述n个负载服务器预先存储了对应于所述唯一标识符且对应于所述扇区编号的扇区数据;

所述驱动还包括:

第二发送模块,用于根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求;

所述负载服务器还包括第三发送模块,用于根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动;

所述驱动还包括第四发送模块,用于将接收的所述扇区数据发送给所述操作系统。

作为更优选地,所述数据读取系统还包括元服务器;

所述第四获取模块包括第二发送单元,用于向元服务器发送所述唯一标识符和所述扇区编号;

所述元服务器包括第二返回模块,用于根据接收的所述唯一标识符、所述扇区编号将预先存储的对应于所述唯一标识符且对应于所述扇区编号的所有负载服务器的地址发送给所述驱动。

在一种可选的实施方式中,所述第二发送模块包括:

容量获取单元,用于根据所述唯一标识符和所述扇区编号获取对应于所述唯一标识符且对应于所述扇区编号的扇区容量;

请求生成单元,用于根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求;

请求发送单元,用于根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求;

所述第三发送模块包括:

数据发送单元,用于根据接收的所述对应部分的数据的获取请求将所述对应部分的数据发送给所述驱动;

所述第三发送模块包括:

数据合成单元,用于将接收的n个所述对应部分的数据进行合成,以得到合成后的扇区数据;

数据返回单元,用于将所述合成后的扇区数据发送给所述操作系统。

本发明还提供了一种数据读写系统,所述数据读写系统包括上述任一实施例所述的数据写入系统和上述任一实施例所述数据读取系统。

相比于现有技术,本发明具有如下突出的有益效果:本发明提供了一种数据写入、读取方法与系统、数据读写系统,其中,所述方法包括:响应于计算机的操作系统发送的写入扇区请求,驱动根据所述写入扇区请求获取待写入的扇区数据和所述计算机的扇区编号;所述驱动根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址;所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据;所述n个负载服务器分别将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。本发明提供的数据写入、读取方法与系统、数据读写系统通过所述驱动获取所述扇区编号,以及根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,通过所述唯一标识符和所述扇区编号标识存储在负载服务器中的数据,从而实现将操作系统要写入本地计算机的扇区数据通过驱动存储至n个负载服务器,避免了因本地计算机硬盘的损坏而导致数据丢失,且通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

附图说明

图1是本发明提供的数据写入方法的第一实施例的流程示意图;

图2是本发明提供的数据读取方法的第一实施例的流程示意图;

图3是本发明提供的数据写入系统的第一实施例的模块示意图;

图4是本发明提供的数据读取系统的第一实施例的模块示意图;

图5是本发明提供的数据读写系统的第一实施例的模块示意图。

具体实施方式

下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

参见图1,是本发明提供的数据写入方法的第一实施例的流程示意图,所述数据写入方法包括:

s101,响应于计算机的操作系统发送的写入扇区请求,驱动根据所述写入扇区请求获取待写入的扇区数据和所述计算机的扇区编号;

s102,所述驱动根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址;

s103,所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据;

s104,所述n个负载服务器分别将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储;

在本实施例中,计算机的操作系统在需要将数据写入计算机的硬盘时,向驱动发送写入扇区请求;例如,操作系统在运行过程中产生数据时,或者需要将外部存储设备的数据写入计算机的硬盘时,则向驱动发送写入扇区请求。

在本实施例中,n为大于或等于1的正整数;所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据,包括:

所述驱动根据所述n个负载服务器的地址分别连接所述n个负载服务器;

所述驱动分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据。

在一种可选的实施方式中,所述驱动预先配置所述计算机的唯一标识符,包括:

在响应于计算机的操作系统发送的写入扇区请求前,所述驱动获取所述计算机的机器信息;

根据所述机器信息生成所述计算机的唯一标识符。

不同计算机的唯一标识符不同。每个所述负载服务器根据所述唯一标识符和所述扇区编号对所述扇区数据进行存储时,其存储结构可以认为是用一个哈希表(散列表)的索引结构存储,计算机的唯一标识符是哈希表的索引值;扇区编号也是哈希表的索引值。因此,在所述负载服务器存储的数据中,通过所述唯一标识符可以在负载服务器上索引到所述唯一标识符所指计算机对应的数据;通过所述唯一标识符和所述扇区编号可以在负载服务器上索引到所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。

即通过所述驱动获取所述扇区编号,以及根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,通过所述唯一标识符和所述扇区编号标识存储在负载服务器中的数据,从而实现将操作系统要写入本地计算机的扇区数据通过驱动存储至n个负载服务器,避免了因本地计算机硬盘的损坏而导致数据丢失,且通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

本发明还提供了一种数据写入方法的第二实施例,所述方法包括上述数据写入方法的第一实施例中的步骤s101~s104,还进一步限定了所述驱动根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,包括:

所述驱动向元服务器发送所述扇区编号和所述唯一标识符;

所述元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址。

在一种可选的实施方式中,所述元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,包括:所述元服务器根据所述扇区编号和所述唯一标识符获取n个负载服务器的地址;所述元服务器向对应于所述唯一标识符的驱动返回n个负载服务器的地址。即实现了当多个驱动向同一所述元服务器发送扇区编号和唯一标识符时,通过唯一标识符区分不同驱动。

在一种可选的实施方式中,所述驱动通过网络向所述元服务器发送所述扇区编号和预先配置的所述计算机的唯一标识符。

即通过元服务器为计算机调度用于写入扇区数据的负载服务器,以及通过唯一标识符标识计算机,便于实现通过一个元服务器为多个计算机进行服务,提高调度效率;通过元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,便于对负载服务器群进行统一管理,使得驱动快速获取负载服务器的地址,提高了写入效率。

本发明还提供了一种数据写入方法的第三实施例,所述方法包括上述数据写入方法的第一实施例中的步骤s101~s104,还进一步限定了所述n个负载服务器分别将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储,包括:

每个所述负载服务器判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据;

当判定存储了所述历史数据时,擦除所述历史数据并将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储;

当判定没有所述历史数据时,将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

即通过每个所述负载服务器判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据,以将历史数据进行擦除,即扇区数据覆盖了负载服务器上对应于所述唯一标识符且对应于所述扇区编号的历史数据,从而实现对应于所述唯一标识符且对应于所述扇区编号只保存最新数据,从而节省了负载服务器的存储空间。

本发明还提供了一种数据写入方法的第四实施例,所述方法包括上述数据写入方法的第一实施例中的步骤s101~s104,还进一步限定了所述元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,包括:

所述元服务器判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录;

当判定有所述写入记录时,所述元服务器根据所述写入记录向所述驱动返回对应于所述唯一标识符且对应于所述扇区编号的n个负载服务器的地址;

当判定无所述写入记录时,所述元服务器向所述驱动返回n个可用的负载服务器的地址;

所述数据写入方法还包括:

每个所述负载服务器在对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储后向所述元服务器发送通知;

所述元服务器在接收到所述通知后,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录。

需要说明的是,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录,则所述n个负载服务器和所述n个负载服务器的地址皆对应于所述唯一标识符;所述n个负载服务器和所述n个负载服务器的地址皆对应于所述唯一标识符且对应于所述扇区编号。

即通过所述元服务器判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录,来确定是否有写入过的负载服务器的地址,从而快速定位到具有写入记录的负载服务器,便于提高所述负载服务器判断存储了历史数据的概率,进一步提高了效率。

本发明还提供了一种数据写入方法的第五实施例,所述方法包括上述数据写入方法的第一实施例中的步骤s101~s104,还进一步限定了所述当判定无所述写入记录时,所述元服务器向所述驱动返回n个可用的负载服务器的地址,包括:

当判定无所述写入记录时,所述元服务器根据负载服务器群的每个负载服务器的资源空闲量计算所述负载服务器群的每个负载服务器的压力系数;

根据所述压力系数对所述负载服务器群的所有负载服务器进行排序;

从所述负载服务器群的所有负载服务器中选取所述压力系数最小的n个负载服务器;

向所述驱动返回所述压力系数最小的n个负载服务器的地址,作为n个可用的负载服务器的地址。

即通过当判定无所述写入记录时,选取所述压力系数最小的n个负载服务器,作为n个可用的负载服务器,以调度压力小的负载服务器进行存储,从而提高数据的写入效率。

参见图2,其是本发明提供的数据读取方法的第一实施例的流程示意图;所述方法包括:

s301,响应于计算机的操作系统发送的读取扇区请求,所述驱动根据所述写入扇区请求获取所述计算机的扇区编号;

s302,所述驱动根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址;其中,所述n个负载服务器预先存储了对应于所述唯一标识符且对应于所述扇区编号的扇区数据;

s303,所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求;

s304,所述n个负载服务器分别根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动;

s305,所述驱动将接收的所述扇区数据发送给所述操作系统。

在本实施例中,计算机的操作系统在需要读取硬盘的扇区数据时,向驱动发送读取扇区请求;例如,操作系统在运行过程中调用数据进行计算时,或者需要将扇区数据拷贝到外部存储设备时,则向驱动发送读取扇区请求。

在本实施例中,n为大于或等于1的正整数;所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求,包括:

所述驱动根据所述n个负载服务器的地址分别连接所述n个负载服务器;

所述驱动分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求。

在一种可选的实施方式中,所述驱动预先配置所述计算机的唯一标识符,包括:

在响应于计算机的操作系统发送的写入扇区请求前,所述驱动获取所述计算机的机器信息;

根据所述机器信息生成所述计算机的唯一标识符。

不同计算机的唯一标识符不同。每个所述负载服务器根据所述唯一标识符和所述扇区编号对所述扇区数据进行存储时,其存储结构可以认为是用一个哈希表(散列表)的索引结构存储,计算机的唯一标识符可以认为是哈希表的索引值;扇区编号也可以认为是哈希表的索引值。因此,在所述负载服务器存储的数据中,通过所述唯一标识符可以在负载服务器上索引到所述唯一标识符所指计算机对应的数据;通过所述唯一标识符和所述扇区编号可以在负载服务器上索引到所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。因此,所述对应于所述唯一标识符且对应于所述扇区编号的扇区数据为所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。

即通过所述驱动获取所述扇区编号,以及获取对应于预先配置的所述计算机的唯一标识符且对应于所述扇区编号的的n个负载服务器的地址,根据所述唯一标识符和所述扇区编号获取负载服务器中的数据,从而实现通过驱动从负载服务器获得操作系统要读取的扇区数据,避免了因本地计算机硬盘的损坏而导致数据丢失;通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

本发明还提供了一种数据读取方法的第二实施例,所述方法包括上述数据读取方法的第一实施例中的步骤s301~s305,还进一步限定了所述驱动根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址,包括

所述驱动向元服务器发送所述唯一标识符和所述扇区编号;

所述元服务器根据接收的所述唯一标识符、所述扇区编号将预先存储的对应于所述唯一标识符且对应于所述扇区编号的所有负载服务器的地址发送给所述驱动。

需要说明的是,若所述元服务器预先存储了所述唯一标识符、所述扇区编号和多个负载服务器的地址,则所述n个负载服务器和所述n个负载服务器的地址对应于所述唯一标识符;所述n个负载服务器和所述n个负载服务器的地址对应于所述唯一标识符且对应于所述扇区编号。

在一种可选的实施方式中,所述元服务器根据接收的所述唯一标识符、所述扇区编号将预先存储的对应于所述唯一标识符且对应于所述扇区编号的所有负载服务器的地址发送给所述驱动,包括:获取对应于所述唯一标识符和所述扇区编号的n个负载服务器的地址;向对应于所述唯一标识符的驱动返回所述n个负载服务器的地址。即通过元服务器为计算机查找用于读取扇区数据的负载服务器,以及通过唯一标识符区分不同计算机,便于实现通过一个元服务器为多个计算机进行服务,提高调度效率。

在一种可选的实施方式中,所述驱动通过网络向元服务器发送所述扇区编号和预先配置的所述计算机的唯一标识符。

即通过元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,便于对负载服务器群进行统一管理,使得驱动快速获取负载服务器的地址,提高了读取效率。

本发明还提供了一种数据读取方法的第三实施例,所述方法包括上述数据读取方法的第一实施例中的步骤s301~s305,还进一步限定了所述驱动根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求,包括:

所述驱动根据所述唯一标识符和所述扇区编号获取对应于所述唯一标识符且对应于所述扇区编号的扇区容量;

所述驱动根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求;

所述驱动根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求;

所述n个负载服务器分别根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动,包括:

所述n个负载服务器分别根据接收的所述对应部分的数据的获取请求将所述对应部分的数据发送给所述驱动;

所述驱动将接收的所述扇区数据发送给所述操作系统,包括:

所述驱动将接收的n个所述对应部分的数据进行合成,以得到合成后的扇区数据;

所述驱动将所述合成后的扇区数据发送给所述操作系统。

在本实施例中,扇区容量,又称为扇区大小,是指硬盘的扇区字节数。

在一种可选的实施方式中,扇区容量为512字节,n为3;所述驱动根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求,具体为:所述驱动将所述扇区容量将所述扇区数据分成分为172字节、170字节和170字节这3部分并生成3个分别对应大小为172字节的第一部分、大小为170字节的第二部分和大小为170字节的第三部分的获取请求。所述驱动根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求,具体为:所述驱动向3个分别与所述负载服务器的地址对应的负载服务器发送不同的所述对应部分的数据的获取请求;在一种可选的实施方式中,所述驱动随机对所述3个分别与所述负载服务器的地址对应的负载服务器进行编号,以得到第1号负载服务器、第2号负载服务器和第3号负载服务器;所述驱动向第1号负载服务器发送所述第一部分的获取请求;向第2号负载服务器发送所述第二部分的获取请求;向第3号负载服务器发送所述第三部分的获取请求。所述驱动将所述合成后的扇区数据发送给所述操作系统,具体为:所述驱动将接收的3部分的数据进行合成;所述驱动将合成后的数据发送给所述操作系统。

即通过将所述扇区容量分成n部分并生成对应每一部分的获取请求,以及根据所述n个负载服务器的地址向不同的所述负载服务器发送不同部分对应的获取请求,从而实现从每个负载服务器获取扇区的n分之1内容的数据,再由所述驱动将接收的n部分的数据进行合成,以及将合成后的数据发送给所述操作系统,从而实现向操作系统返回对应于所述扇区编号的扇区数据,进一步提高了获取数据的速度。

参见图3,其是本发明提供的数据写入系统的第一实施例的模块示意图;所述数据写入系统20包括驱动201和n个负载服务器203;

所述驱动201包括:

第一获取模块2011,用于响应于计算机的操作系统发送的写入扇区请求,根据所述写入扇区请求获取待写入的扇区数据和所述计算机的扇区编号;

第二获取模块2014,用于根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址;

第一发送模块2013,用于根据所述n个负载服务器的地址分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据;

所述负载服务器203包括第一存储模块2031,用于将接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

在本实施例中,计算机的操作系统在需要将数据写入计算机的硬盘时,向驱动发送写入扇区请求;例如,操作系统在运行过程中产生数据时,或者需要将外部存储设备的数据写入计算机的硬盘时,则向驱动发送写入扇区请求。

在本实施例中,n为大于或等于1的正整数;所述第一发送模块包括:

第一连接单元,用于根据所述n个负载服务器的地址分别连接所述n个负载服务器;

第三发送单元,用于分别向连接的所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据。

在一种可选的实施方式中,所述驱动预先配置所述计算机的唯一标识符,包括:

在响应于计算机的操作系统发送的写入扇区请求前,所述驱动获取所述计算机的机器信息;

根据所述机器信息生成所述计算机的唯一标识符。

不同计算机的唯一标识符不同。每个所述负载服务器根据所述唯一标识符和所述扇区编号对所述扇区数据进行存储时,其存储结构可以认为是用一个哈希表(散列表)的索引结构存储,计算机的唯一标识符可以认为是哈希表的索引值;扇区编号也可以认为是哈希表的索引值。因此,在所述负载服务器存储的数据中,通过所述唯一标识符可以在负载服务器上索引到所述唯一标识符所指计算机对应的数据;通过所述唯一标识符和所述扇区编号可以在负载服务器上索引到所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。

即通过所述驱动获取所述扇区编号,以及根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,通过所述唯一标识符和所述扇区编号标识存储在负载服务器中的数据,从而实现将操作系统要写入本地计算机的扇区数据通过驱动存储至n个负载服务器,避免了因本地计算机硬盘的损坏而导致数据丢失,且通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

本发明还提供了一种数据写入系统的第二实施例,其包括上述数据写入系统20的第一实施例的驱动201和n个负载服务器203,还进一步限定了,所述数据写入系统还包括元服务器;

所述第二获取模块还包括第一发送单元,用于向元服务器发送所述扇区编号和所述唯一标识符;

所述元服务器包括第一返回模块,用于在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址。

在一种可选的实施方式中,所述第一返回模块包括:第五发送单元,用于根据所述扇区编号和所述唯一标识符获取n个负载服务器的地址;第一返回单元,用于向对应于所述唯一标识符的驱动返回n个负载服务器的地址。即实现了当多个驱动向同一所述元服务器发送扇区编号和唯一标识符时,通过唯一标识符区分不同驱动。

在一种可选的实施方式中,所述驱动通过网络向所述元服务器发送所述扇区编号和预先配置的所述计算机的唯一标识符。

即通过元服务器为计算机调度用于写入扇区数据的负载服务器,以及通过唯一标识符标识计算机,便于实现通过一个元服务器为多个计算机进行服务,提高调度效率;通过元服务器在接收到所述扇区编号和所述唯一标识符后向所述驱动返回n个负载服务器的地址,便于对负载服务器群进行统一管理,使得驱动快速获取负载服务器的地址,提高了写入效率。

本发明还提供了一种数据写入系统的第三实施例,其包括上述数据写入系统20的第一实施例的驱动201和n个负载服务器203,还进一步限定了本发明还提供了一种数据写入系统的第三实施例,其包括上述数据写入系统20的第一实施例的驱动201和n个负载服务器203,还进一步限定了所述第一存储模块包括:

历史数据判断单元,用于判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据;

擦除判定单元,用于当判定存储了所述历史数据时,擦除所述历史数据并对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储;

存储判定单元,用于当判定没有所述历史数据时,对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储。

即通过每个所述负载服务器判断是否存储了对应于所述唯一标识符且对应于所述扇区编号的历史数据,以将历史数据进行擦除,即扇区数据覆盖了负载服务器上对应于所述唯一标识符且对应于所述扇区编号的历史数据,从而实现对应于所述唯一标识符且对应于所述扇区编号只保存最新数据,从而节省了负载服务器的存储空间。

本发明还提供了一种数据写入系统的第四实施例,其包括上述数据写入系统20的第一实施例的驱动201和n个负载服务器203,还进一步限定了所述第一返回模块包括:

第一判断单元,用于判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录;

第一判定单元,用于当判定有所述写入记录时,根据所述写入记录向所述驱动返回对应于所述唯一标识符且对应于所述扇区编号的n个负载服务器的地址;

第二判定单元,用于当判定无所述写入记录时,向所述驱动返回n个可用的负载服务器的地址;

所述负载服务器还包括第一通知模块,用于在对接收的所述唯一标识符、所述扇区编号和所述扇区数据进行对应存储后向所述元服务器发送通知;

所述元服务器还包括第一记录模块,用于在接收到所述通知后,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录。

需要说明的是,将所述唯一标识符、所述扇区编号和所述n个负载服务器的地址对应存储至所述写入记录,则所述n个负载服务器和所述n个负载服务器的地址皆对应于所述唯一标识符;所述n个负载服务器和所述n个负载服务器的地址皆对应于所述唯一标识符且对应于所述扇区编号。

即通过所述元服务器判断是否有对应于所述唯一标识符且对应于所述扇区编号的写入记录,来确定是否有写入过的负载服务器的地址,从而快速定位到具有写入记录的负载服务器,便于提高所述负载服务器判断存储了历史数据的概率,进一步提高了效率。

本发明还提供了一种数据写入系统的第五实施例,其包括上述数据写入系统20的第一实施例的驱动201和n个负载服务器203,还进一步限定了所述第二判定单元包括:

系数计算单元,用于当判定无所述写入记录时,根据负载服务器群的每个负载服务器的资源空闲量计算所述负载服务器群的每个负载服务器的压力系数;

第一排序单元,用于根据所述压力系数对所述负载服务器群的所有负载服务器进行排序;

服务器选取单元,用于从所述负载服务器群的所有负载服务器中选取所述压力系数最小的n个负载服务器;

地址返回单元,用于向所述驱动返回所述压力系数最小的n个负载服务器的地址,作为n个可用的负载服务器的地址。

即通过当判定无所述写入记录时,选取所述压力系数最小的n个负载服务器,作为n个可用的负载服务器,以调度压力小的负载服务器进行存储,从而提高数据的写入效率。

参见图4,其是本发明提供的数据读取系统的第一实施例的模块示意图;如图4所述,所述数据读取系统40包括驱动401和n个负载服务器403;

所述驱动401包括:

第三获取模块4011,用于响应于计算机的操作系统发送的读取扇区请求,所述驱动根据所述写入扇区请求获取所述计算机的扇区编号;

第四获取模块4014,用于根据预先配置的所述计算机的唯一标识符和所述扇区编号获取n个负载服务器的地址;其中,所述n个负载服务器预先存储了对应于所述唯一标识符且对应于所述扇区编号的扇区数据;

第二发送模块4013,用于根据所述n个负载服务器的地址分别向所述n个负载服务器发送对应于所述唯一标识符且对应于所述扇区编号的扇区数据的获取请求;

所述负载服务器403还包括第三发送模块4031,用于根据接收的所述获取请求将对应于所述唯一标识符且对应于所述扇区编号的扇区数据发送给驱动;

所述驱动还包括第四发送模块4015,用于将接收的所述扇区数据发送给所述操作系统。

在本实施例中,计算机的操作系统在需要读取硬盘的扇区数据时,向驱动发送读取扇区请求;例如,操作系统在运行过程中调用数据进行计算时,或者需要将扇区数据拷贝到外部存储设备时,则向驱动发送读取扇区请求。

在本实施例中,n为大于或等于1的正整数;所述第二发送模块包括:

第二连接单元,用于根据所述n个负载服务器的地址分别连接所述n个负载服务器;

第四发送单元,用于分别向所述n个负载服务器发送所述扇区编号、所述唯一标识符和所述扇区数据。

在一种可选的实施方式中,所述驱动预先配置所述计算机的唯一标识符,包括:

在响应于计算机的操作系统发送的写入扇区请求前,所述驱动获取所述计算机的机器信息;

根据所述机器信息生成所述计算机的唯一标识符。

不同计算机的唯一标识符不同。每个所述负载服务器根据所述唯一标识符和所述扇区编号对所述扇区数据进行存储时,其存储结构可以认为是用一个哈希表(散列表)的索引结构存储,计算机的唯一标识符可以认为是哈希表的索引值;扇区编号也可以认为是哈希表的索引值。因此,在所述负载服务器存储的数据中,通过所述唯一标识符可以在负载服务器上索引到所述唯一标识符所指计算机对应的数据;通过所述唯一标识符和所述扇区编号可以在负载服务器上索引到所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。因此,所述对应于所述唯一标识符且对应于所述扇区编号的扇区数据为所述唯一标识符所指计算机上所述扇区编号所指扇区对应的扇区数据。

即通过所述驱动获取所述扇区编号,以及获取对应于所述唯一标识符和所述扇区编号的n个负载服务器的地址,根据所述唯一标识符和所述扇区编号获取负载服务器中的数据,从而实现通过驱动从负载服务器获得操作系统要读取的扇区数据,避免了因本地计算机硬盘的损坏而导致数据丢失;通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

本发明还提供了一种数据读取系统的第二实施例,其包括上述数据读取系统40的第一实施例的驱动401和n个负载服务器403,还进一步限定了所述数据读取系统还包括元服务器;

所述第四获取模块包括第二发送单元,用于向元服务器发送所述唯一标识符和所述扇区编号;

所述元服务器包括第二返回模块,用于根据接收的所述唯一标识符、所述扇区编号将预先存储的对应于所述唯一标识符且对应于所述扇区编号的所有负载服务器的地址发送给所述驱动。

需要说明的是,若所述元服务器预先存储了所述唯一标识符、所述扇区编号和多个负载服务器的地址,则所述n个负载服务器和所述n个负载服务器的地址对应于所述唯一标识符;所述n个负载服务器和所述n个负载服务器的地址对应于所述唯一标识符且对应于所述扇区编号。

在一种可选的实施方式中,所述第二返回模块包括:第六发送单元,用于获取对应于所述唯一标识符和所述扇区编号的n个负载服务器的地址;第二返回单元,用于向对应于所述唯一标识符的驱动返回所述n个负载服务器的地址。即实现了当多个驱动向同一所述元服务器发送扇区编号和唯一标识符时,通过唯一标识符区分不同驱动。即通过元服务器为计算机查找用于读取扇区数据的负载服务器,以及通过唯一标识符区分不同计算机,便于实现通过一个元服务器为多个计算机进行服务,提高调度效率。

在一种可选的实施方式中,所述驱动通过网络向元服务器发送所述扇区编号和预先配置的所述计算机的唯一标识符。

即通过元服务器向所述驱动返回对应于接收的所述唯一标识符且对应于接收的所述扇区编号的n个负载服务器的地址,便于对负载服务器群进行统一管理,使得驱动快速获取负载服务器的地址,提高了写入效率。

本发明还提供了一种数据读取系统的第三实施例,其包括上述数据读取系统40的第一实施例的驱动401和n个负载服务器403,还进一步限定了所述第二发送模块包括:

容量获取单元,用于根据所述唯一标识符和所述扇区编号获取对应于所述唯一标识符且对应于所述扇区编号的扇区容量;

请求生成单元,用于根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求;

请求发送单元,用于根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求;

所述第三发送模块包括:

数据发送单元,用于根据接收的所述对应部分的数据的获取请求将所述对应部分的数据发送给所述驱动;

所述第三发送模块包括:

数据合成单元,用于将接收的n个所述对应部分的数据进行合成,以得到合成后的扇区数据;

数据返回单元,用于将所述合成后的扇区数据发送给所述操作系统。

在本实施例中,扇区容量,又称为扇区大小,是指硬盘的扇区字节数。

在一种可选的实施方式中,扇区容量为512字节,n为3;所述请求生成单元根据所述扇区容量将所述扇区数据分成n部分,并根据每部分生成对应于所述唯一标识符且对应于所述扇区编号的扇区数据的对应部分的数据的获取请求,具体为:所述请求生成单元将所述扇区容量将所述扇区数据分成分为172字节、170字节和170字节这3部分并生成3个分别对应大小为172字节的第一部分、大小为170字节的第二部分和大小为170字节的第三部分的获取请求。所述请求发送单元根据所述n个负载服务器的地址分别向不同的所述负载服务器发送不同的所述对应部分的数据的获取请求,具体为:所述请求发送单元向3个分别与所述负载服务器的地址对应的负载服务器发送不同的所述对应部分的数据的获取请求;在一种可选的实施方式中,所述请求发送单元随机对所述3个分别与所述负载服务器的地址对应的负载服务器进行编号,以得到第1号负载服务器、第2号负载服务器和第3号负载服务器;所述请求发送单元向第1号负载服务器发送所述第一部分的获取请求;向第2号负载服务器发送所述第二部分的获取请求;向第3号负载服务器发送所述第三部分的获取请求。所述数据返回单元将所述合成后的扇区数据发送给所述操作系统,具体为:所述数据返回单元将接收的3部分的数据进行合成;所述数据返回单元将合成后的数据发送给所述操作系统。

即通过将所述扇区容量分成n部分并生成对应每一部分的获取请求,以及根据所述n个负载服务器的地址向不同的所述负载服务器发送不同部分对应的获取请求,从而实现从每个负载服务器获取扇区的n分之1内容的数据,再将接收的n部分的数据进行合成,以及将合成后的数据发送给所述操作系统,从而实现向操作系统返回对应于所述扇区编号的扇区数据,进一步提高了获取数据的速度。

参见图5,其是本发明提供的数据读写系统的第一实施例的模块示意图;如图5所示,所述数据读写系统1包括如上述任一实施例所述的数据读写系统20和如上述任一实施例所述的数据读写系统40。

即通过所述驱动获取所述扇区编号,以及根据所述扇区编号和预先配置的所述计算机的唯一标识符获取n个负载服务器的地址,通过所述唯一标识符和所述扇区编号标识存储在负载服务器中的数据,从而实现将操作系统要写入本地计算机的扇区数据通过驱动存储至n个负载服务器;通过所述驱动获取所述扇区编号,以及获取对应于所述唯一标识符和所述扇区编号的n个负载服务器的地址,根据所述唯一标识符和所述扇区编号获取负载服务器中的数据,从而实现通过驱动从负载服务器获得操作系统要读取的扇区数据;避免了因本地计算机硬盘的损坏而导致数据丢失,且通过n个负载服务器对存储空间进行扩容,即使要写入的数据超过本地计算机硬盘空间容量,也无需更换硬盘,从而降低了扩容难度,节约了成本。

本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,所述的存储介质可为磁碟、光盘、只读存储记忆体(read-onlymemory,rom)或随机存储记忆体(randomaccessmemory,ram)等。

以上所述是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也视为本发明的保护范围。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1