CN115221117A - 一种可跨磁盘转移数据的方法及系统 - Google Patents
一种可跨磁盘转移数据的方法及系统 Download PDFInfo
- Publication number
- CN115221117A CN115221117A CN202211059869.4A CN202211059869A CN115221117A CN 115221117 A CN115221117 A CN 115221117A CN 202211059869 A CN202211059869 A CN 202211059869A CN 115221117 A CN115221117 A CN 115221117A
- Authority
- CN
- China
- Prior art keywords
- data
- directory
- partition
- transferred
- transferable
- 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.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/11—File system administration, e.g. details of archiving or snapshots
- G06F16/119—Details of migration of file systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1008—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1415—Saving, restoring, recovering or retrying at system level
- G06F11/1435—Saving, restoring, recovering or retrying at system level using file system or storage system metadata
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1415—Saving, restoring, recovering or retrying at system level
- G06F11/1438—Restarting or rejuvenating
-
- 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/0604—Improving or facilitating administration, e.g. storage management
-
- 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/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/0647—Migration mechanisms
-
- 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
Abstract
本发明公开了一种可跨磁盘转移数据的方法及系统,该方法包括:根据数据转移策略对系统分区中的数据进行扫描;分割足够的空闲存储区域建立新分区并分配未使用的盘符;转移数据,对转移完毕的数据设置与原始数据相同的属性和权限;若某个数据转移失败,则对该数据所在的一级子目录进行回滚操作;若某个一级子目录成功转移,则在该一级目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;对于进行回滚操作的一级子目录,在PE系统下进行数据转移。本发明动态获取待转移的数据信息,使得转移更加精确,并通过PE系统转移失败数据,保证数据的完整性。
Description
技术领域
本发明属于磁盘分区管理技术领域,尤其涉及一种能够跨磁盘转移数据以对系统分区进行扩展的方法及系统。
背景技术
Windows操作系统以及第三方管理磁盘管理软件仅支持使用系统分区所在磁盘上的空闲空间来对系统分区进行扩容,如果该磁盘上已经没有更多可用空间,就只能使用文件搬运的方式来释放系统分区的空间,难以有效利用其它磁盘的空间。
中国专利201010143006.6公开了一种搬移软件的方法及装置,通过将待搬移软件对应的文件拷贝到搬移的目标文件夹,并通过在原文件夹所在位置建立指向目标文件夹所在路径的链接文件,其使用拷贝的方法来搬移可以保证软件数据不丢失,且使用链接文件的方式可以保证在搬移前位置仍可以访问该软件,不影响软件性能。但该专利存在以下缺陷:
1)未对目标位置进行限制,用户很容易因为误操作而删除掉目标位置,因而影响所搬运数据的正常使用;
2)未对搬运后软件的权限和属性进行处理,存在软件搬运成功后无法正常运行的情况;
3)未对搬运不成功的数据进行处理,存在数据不完整的缺陷。
4)同时,该专利是单纯搬运软件,描述的过滤名单基于软件路径、软件名称和注册表键值,为xml结构较为静态。
中国专利201010586809.9公开了一种应用程序文件搬移方法及系统根据收集的待搬移应用程序文件占用信息,当删除应用程序文件所在源文件夹失败时,对应用程序文件进行解锁,从而实现应用程序文件的搬移,解决了搬移成功率低的问题,简化了应用程序文件的搬移操作,提高了应用程序文件搬移的自动化程度,及搬移的成功率。
但该专利仍然存在目标位置可能被误删导致数据无法使用、未处理搬运后文件目录的权限导致无法正常运行,和数据不完整的缺陷。同时,该专利提到当待搬移应用程序被占用,导致删除或搬运失败时,通过解锁的方式来处理,但此种方式对文件和程序有一定的破坏性。
发明内容
有鉴于此,本发明提供一种可跨磁盘转移数据的方法及系统,可实现跨磁盘转移数据以扩展系统分区。
为解决以上技术问题,本发明的技术方案为采用一种可跨磁盘转移数据的方法,包括:
根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录;
根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;
在分割出来的存储区域上建立新分区并分配未使用的盘符;
根据内存中存储的可转移数据的路径遍历可转移的数据,根据数据中的目录在新分区中创建同名目录,将系统分区中的可转移数据转移到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性和权限;
对已转移的数据删除其系统分区中的原始数据;
若某个数据转移失败,则对该数据所在的一级子目录进行回滚操作;
若某个一级子目录成功转移,则在该一级子目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件;
对于进行回滚操作的一级子目录,在PE系统下进行数据转移。
作为一种改进,建立新分区后对新分区进行隐藏。
作为一种进一步的改进,在根据数据中的目录在新分区中创建同名目录之前,先对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名。
作为另一种更进一步的改进,根据数据转移策略创建配置文件,所述配置文件包括若干对需要进行转移数据进行记录的配置项以及排除条件;
逐个处理配置文件中的配置项,读取对应的环境变量,统计每个配置项下所有的数据量;若数据为文件则直接累计,若数据为目录则进行递归累计;
将统计好的数据设置为待转移项。
作为一种改进,从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域的方法包括:
根据统计到的可转移的数据量设置所需空间大小;
遍历系统分区所在磁盘以外磁盘上的其他分区,若该分区空闲存储区域大于所需空间且空闲存储空间为已占用空间的N倍,则将该分区添加到分区列表;
从分区列表中选择一个分区;
从被选择的分区中分割一部分存储空间用于数据转移。
作为一种进一步的改进,所述所需空间为可转移数据量的1.2~1.5倍,所述N为1.1~1.3。
作为一种改进,数据转移完毕后将系统分区中对应的原始数据的权限设置为当前用户所有,属性设置可读写。
作为一种改进,所述在PE系统下进行数据转移的方法包括:
创建PE系统,生成ISO文件;
修改系统启动项为PE系统优先;
重启设备进入PE系统,在PE系统内进行数据转移。
本发明还提供一种可跨磁盘转移数据的系统,包括:
扫描模块,用于根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录;
存储空间分割模块,用于根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;并在分割出来的存储区域上建立新分区并分配未使用的盘符;
数据转移模块,用于将系统分区中的可转移数据转移到新分区中;
PE系统模块,用于对于进行回滚操作的一级目录,在PE系统下进行数据转移。
作为一种改进,所述数据转移模块包括:
重命名模块,用于在根据数据中的目录在新分区中创建同名目录之前,先对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名。
新目录创建模块,用于根据数据中的目录在新分区中创建同名目录;
转移模块,用于根据内存中存储的可转移数据的路径将系统分区中的可转移数据复制到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性;
数据操作模块,用于对已转移的数据删除其系统分区中的原始数据;
回滚模块,用于在某个数据转移失败,对该数据所在的一级目录进行回滚操作;
链接设置模块,用于在某个一级目录成功转移后,在该一级目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件。
本发明的有益之处在于:
1、本发明不仅可以转移Program File中的软件还能转移如Program Data、UserHome、Shell目录(“下载”、“视频”之类)等占用存储空间较大的数据目录,且搬运和排除项需要在运行时根据环境动态获取。具体需要转移的数据在运行时获取,提高了数据转移的准确性,与软件路径、软件名称和注册表键值都无关。
2、本发明通过对目录进行重命名操作的方式来监测所搬运的目录和文件被占用情况,跳过重命名失败的目录,以降低遇到正在被占用目录的情况减少无效操作。对于搬运到一半失败的目录,设置回滚程序和创建进入PE系统的程序,以保证搬运后的数据的一致性,和所搬运数据的完整性,减小了破坏数据的几率。
附图说明
图1为本发明总体流程图。
图2为扫描流程图。
图3为新分区创建流程图。
图4为数据转移流程图。
图5为本发明的结构原理图。
具体实施方式
为了使本领域的技术人员更好地理解本发明的技术方案,下面结合具体实施方式对本发明作进一步的详细说明。
Windows系统分区除了安装系统以外一般还用于安装软件存储软件数据和用户数据,而一般系统分区都不会划分得很大,因此在使用一段时间后随着数据的膨胀系统分区经常会出现空间不足的现象。
针对上述问题,如图1所示,本发明提供一种可跨磁盘转移数据的方法,包括:
S1根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录。由于文件几乎很少直接存储在根目录下尤其是在系统分区的根目录下,因此本实施例主要针对根目录下的一级目录进行扫描,当然也可指定其他目录。
如图2所示,具体又包括:
S11根据数据转移策略创建配置文件,所述配置文件包括若干对需要进行转移数据进行记录的配置项以及排除条件。配置文件中可指定需要转移的数据如Program Files、User Home以及Program Data目录,当然也可以是其他需要转移的数据。排除条件可以包括系统目录、Boot目录以及名称中带有Microsoft的目录,或者是其他不需要转移的目录如自身就是符号链接的目录。
S12逐个处理配置文件中的配置项,读取对应的环境变量,统计每个配置项下所有的数据量;若数据为文件则直接累计,若数据为目录则进行递归累计。
根据配置项读取对应的环境变量,例如Program Data读取的环境变量是AllusersProfile,Program Files读取的是ProgramFiles和ProgramW6432。此外,在读取以后,还要跟另外一个环境变量SystemDrive比较,判断上述目录到底在不在系统盘上。最后得到Program Data的值为:C:\ProgramData,而Program Files的值为:C:\Program Files和C:\Program Files (x86)。此外,如果配置文件还指定搬运“下载”、“视频”、“图片”等Shell目录,则需要读取系统设置,判断这些Shell目录是否本来就位于系统分区,如果没有则直接忽略。由于环境变量是实时动态的,使得本步骤的操作也是实时动态的,提高了数据的准确性。
具体统计的时候以C:\Program Files为例,首先枚举其中的全部项,如:其中有Git、Microsoft Office、Intel等目录。
其中Microsoft Office触发了排除条件,不需要分析,而另外一个目录Intel本身就是符号链接,也不分析。Git等目录没有被排除,则对这些目录进行递归分析,首先打开Git目录,遍历其中的项。遇到.exe等文件时,直接获得这些文件的大小并累计,遇到bin等目录时,递归进入这些目录,并用同样的方法进行大小累计。
所谓递归统计就是指假如有一个目录A,目录A下面有1、2、3这3个文件,还有一个子目录B,这些数据的顺序是1、B、2、3。统计的时候首先统计文件1的大小,然后遇到目录B的时候,进入目录B统计,直到目录B中的项统计完了,再接着统计2和3,如果目录B中还有子目录C,也采用一样的方法,遇到目录C先统计目录C内的数据。
S13将统计好的数据设置为待转移项。当某个目录如C:\ProgramData中的数据统计完毕后,就将C:\ProgramData下的一级子目录设为待转移项复制到内存中。
步骤S2~S3为新分区创建过程,如图3所示。
S2根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;具体包括:
S21根据统计到的可转移的数据量设置所需空间大小;本实施例中,所需空间为可转移数据量的1.2~1.5倍,当然上限可以不做限制,只不过占用太多空间没有必要。
S22遍历系统分区所在磁盘以外磁盘上的其他分区,若该分区空闲存储区域大于所需空间且空闲存储空间为已占用空间的N倍,则将该分区添加到分区列表;所述N为1.1~1.3,即选择的分区中闲置空间为已占用空间的1.1~1.3倍。例如,步骤1中统计的可转移数据为30GB,其所需空间为30*1.2~30*~1.5GB即36~45GB,此处推荐45GB。假设共有C、D、E、F、G、H六个分区,其中C、D分区在系统盘上直接略过,假设E分区总大小为1TB(1024GB),但已使用了900GB的空间,按照闲置空间为已占用空间的1.1~1.3倍(此处取1.2倍)的要求,需要留下至少1080GB空间,显然不能满足,于是E分区也被跳过。F分区大小为40GB,已使用空间为10GB,保留1.2倍空间后可用空间为28GB,不满足45GB的最小要求,也被跳过。G分区和H分区大小也都为1TB,已使用空间同样为10GB,剩余可用空间充足,可以被当作数据转移的目标分区。
S23从分区列表中选择一个分区;接上方实例,G分区或者H分区以及要从选中的分区上划分下来的大小都可由用户来指定。
S24从被选择的分区中分割一部分存储空间用于数据转移。假设用户选择了G分区,指定大小为50GB,则在用户选择了分区和大小后,调用已有的分区resize/move模块在G分区末尾划分出一片50GB大小的空间。
S3在分割出来的存储区域上建立新分区并分配未使用的盘符;利用上述划分出来的50GB空间新建一个NTFS分区,并分配一个未使用的盘符如I。另外,通过修改注册表,重启explorer.exe,以实现隐藏新建分区I,其目的在于避免用户误操作新分区内的数据。隐藏分区只是在Windows下不可见,实际上可通过其他方式操作,并不影响本发明的后续步骤。
步骤S4~S7为数据转移过程,如图4所示。
S4根据内存中存储的可转移数据的路径遍历可转移的数据,根据数据中的目录在新分区中创建同名目录,将系统分区中的可转移数据转移到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性;在创建同名目录之前,对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名。
对待转移目录重命名的目的在于判断其是否被系统或者其他程序占用,如果被占用会导致数据转移失败。通过提前判断占用与否能减小系统开销。具体地,通过调用APIMoveFile进行重命名。重命名可以是随机的,但为了避免重名,本实施例中通过读取精确到毫秒的本地时间进行重命名,例如将目录Git重命名为Git_2022_08_10_15_21_01。
若待转移目录C:\Program Files\Git被占用,则直接记录为失败等待后续处理。
若待转移目录C:\Program Files\Git未被占用,则在新建分区I上创建一个同路径同名目录I:\Program Files\Git。然后读取C:\Program Files\Git的权限和属性,并设置给I:\Program Files\Git,保证拥有C:\Program Files\Git读写权限的Windows账户也能对I:\Program Files\Git进行读写。然后遍历Git目录,如果遇到文件如.exe等,则直接拷贝到新分区中新的同名目录下,并同样设置权限和属性,确保文件访问正常,且文件的隐藏、只读等属性保留。例如Git目录下的LICENSE.txt是压缩文件,则需要调用API,将I:\Program Files\Git下的同名文件设置压缩属性,避免拷贝过程中的解压造成更多的空间占用,稀疏文件同理。
如果遇到bin等目录,则同样在目标位置建立bin目录,然后递归遍历bin目录进行转移。递归转移与递归统计类似,可参考上文,本步骤不再赘述。
S5对已转移的数据删除其系统分区中的原始数据;一个文件或目录转移完成后,则将系统分区中对应的原始数据的权限设置为当前用户所有,属性设置为可读写(方便删除),然后删除文件或目录。
S6若某个数据转移失败,则对该数据所在的一级子目录进行回滚操作;如果C:\Program Files\Git中有原始文件删除失败,则说明该文件正在被占用,此时Git目录无法被转移,需要进行回滚。回滚操作与转移操作相同,只不过数据转移方向相反,从I:\Program Files\Git往C:\Program Files\Git转移,同样需要设置权限等。如果有回滚的目录,还需要记录失败,方便后续处理。
另外,所谓一级子目录是指例如C:\Program Files\下的第一层子目录如Git。由于不同程序的数据一般都是通过一级子目录进行分别存储,因此回滚操作时以一级子目录为单位最为经济。回滚太多影响转移效率,回滚不够的话会导致数据的完整性受到损害。
S7若某个一级子目录成功转移,则在该一级子目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置。当C:\Program Files\Git被成功搬运后,删除C:\Program Files\Git,然后在C:\Program Files下建立一个符号链接。这样,C:\ProgramFiles\Git依然可以正常访问,但是实际上访问的目标目录已经是I:\Program Files\Git,该目录不再占用C分区的空间。
若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件。Shell目录(Shell Folders)如图片、文档、下载、桌面等目录的搬运相对特殊,这些目录本质上是分区上的某个目录,但是它们包含一个desktop.ini文件,desktop.ini文件指定了一些参数,当Shell目录被显示的时候,相对于普通的目录它们会有特定的图标和文字,比如叫做桌面、下载等。在转移后为了使其仍然能拥有特定的图标和文字,则需要调用系统API对这些Shell目录进行重定向,重定向完成后还需要设置Shell目录下的desktop.ini文件,确保Shell目录能正确显示图标和本地化。
S8对于进行回滚操作的一级子目录,在PE系统下进行数据转移。具体包括:创建PE系统,生成ISO文件;修改系统启动项为PE系统优先;重启设备进入PE系统,在PE系统内进行数据转移。
Windows PE系统(Windows Preinstallation Environment),即Windows预安装环境,是带有有限服务的最小Win32子系统,基于以保护模式运行的Windows XPProfessional及以上内核。 PE系统作为原有系统以外的系统,不会占用磁盘上的数据,因此在PE系统下对转移失败的数据重新进行转移,保证数据能够完全转移。转移时读取转移失败列表,然后按照上述转移方法进行转移即可。
如图5所示,本发明还提供一种可跨磁盘转移数据的系统,包括:
扫描模块,用于根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录;
存储空间分割模块,用于根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;并在分割出来的存储区域上建立新分区并分配未使用的盘符;
数据转移模块,用于将系统分区中的可转移数据转移到新分区中;
PE系统模块,用于对于进行回滚操作的一级子目录,在PE系统下进行数据转移。
其中,所述数据转移模块又具体包括:
重命名模块,用于在根据数据中的目录在新分区中创建同名目录之前,先对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名。
新目录创建模块,用于根据数据中的目录在新分区中创建同名目录;
转移模块,用于根据内存中存储的可转移数据的路径将系统分区中的可转移数据复制到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性;
数据操作模块,用于对已转移的数据删除其系统分区中的原始数据;并对转移后的数据设置与原始数据相同的属性;
回滚模块,用于在某个数据转移失败,对该数据所在的一级目录进行回滚操作;
链接设置模块,用于在某个一级目录成功转移后,在该一级目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件。
本发明通过对系统分区中的数据进行转移实现了跨磁盘对系统分区进行扩容,不管系统分区所在的磁盘上是否还有可用空间,只要有其他容量较大的磁盘就可以实现。本发明将在系统磁盘外的磁盘上划分出一块区域,并创建一个隐藏的分区,然后对系统分区的软件目录、用户个人目录等进行扫描,然后将大部分数据转移到隐藏分区中,并在系统分区中建立相应的符号链接,使得软件可以正常使用,文件也可以正常访问。
对比普通的文件转移方法,这种做法在逻辑上实现了扩容,隐藏分区中的空间也可以被系统分区使用,而不需要在之后的使用中反复进行转移。
同时,当检测到有指定的目录转移不成功,可通过进入PE系统继续执行,以保证选中的目录能够转移成功,解决了现有技术中转移数据不完整的问题。
以上仅是本发明的优选实施方式,应当指出的是,上述优选实施方式不应视为对本发明的限制,本发明的保护范围应当以权利要求所限定的范围为准。对于本技术领域的普通技术人员来说,在不脱离本发明的精神和范围内,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (10)
1.一种可跨磁盘转移数据的方法,其特征在于包括,
根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录;
根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;
在分割出来的存储区域上建立新分区并分配未使用的盘符;
根据内存中存储的可转移数据的路径遍历可转移的数据,根据数据中的目录在新分区中创建同名目录,将系统分区中的可转移数据转移到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性和权限;
对已转移的数据删除其系统分区中的原始数据;
若某个数据转移失败,则对该数据所在的一级子目录进行回滚操作;
若某个一级子目录成功转移,则在该一级目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件;
对于进行回滚操作的一级子目录,在PE系统下进行数据转移。
2.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于:建立新分区后对新分区进行隐藏。
3.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于:在根据数据中的目录在新分区中创建同名目录之前,先对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名。
4.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于所述根据数据转移策略对系统分区中的目标目录进行扫描的方法包括:
根据数据转移策略创建配置文件,所述配置文件包括若干对需要进行转移数据进行记录的配置项以及排除条件;
逐个处理配置文件中的配置项,读取对应的环境变量,统计每个配置项下所有的数据量;若数据为文件则直接累计,若数据为目录则进行递归累计;
将统计好的数据设置为待转移项。
5.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域的方法包括:
根据统计到的可转移的数据量设置所需空间大小;
遍历系统分区所在磁盘以外磁盘上的其他分区,若该分区空闲存储区域大于所需空间且空闲存储空间为已占用空间的N倍,则将该分区添加到分区列表;
从分区列表中选择一个分区;
从被选择的分区中分割一部分存储空间用于数据转移。
6.根据权利要求5所述的一种可跨磁盘转移数据的方法,其特征在于:所述所需空间为可转移数据量的1.2~1.5倍,所述N为1.1~1.3。
7.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于:数据转移完毕后将系统分区中对应的原始数据的权限设置为当前用户所有,属性设置可读写。
8.根据权利要求1所述的一种可跨磁盘转移数据的方法,其特征在于所述在PE系统下进行数据转移的方法包括:
创建PE系统,生成ISO文件;
修改系统启动项为PE系统优先;
重启设备进入PE系统,在PE系统内进行数据转移。
9.一种可跨磁盘转移数据的系统,其特征在于包括:
扫描模块,用于根据数据转移策略对系统分区中的数据进行扫描,排除数据转移策略中指定不转移的数据,统计可转移的数据量,并将可转移数据的路径复制到内存;所述数据包括文件和目录;
存储空间分割模块,用于根据可转移的数据量从系统分区所在磁盘以外的磁盘上的分区分割足够的空闲存储区域;并在分割出来的存储区域上建立新分区并分配未使用的盘符;
数据转移模块,用于将系统分区中的可转移数据转移到新分区中;
PE系统模块,用于对于进行回滚操作的一级子目录,在PE系统下进行数据转移。
10.根据权利要求9所述的一种可跨磁盘转移数据的系统,其特征在于所述数据转移模块包括:
重命名模块,用于在根据数据中的目录在新分区中创建同名目录之前,先对待转移的目录进行重命名,若重命名失败则认为该目录被占用,将该目录列为转移失败;若重命名成功则认为该目录未被占用,将目录名重新命名为原始目录名;
新目录创建模块,用于根据数据中的目录在新分区中创建同名目录;
转移模块,用于根据内存中存储的可转移数据的路径将系统分区中的可转移数据复制到新分区中对应的目录下,并对转移后的数据设置与原始数据相同的属性;
数据操作模块,用于对已转移的数据删除其系统分区中的原始数据;
回滚模块,用于在某个数据转移失败,对该数据所在的一级子目录进行回滚操作;
链接设置模块,用于在某个一级子目录成功转移后,在该一级子目录的原始位置新建一个符号链接,所述符号链接指向数据转移后的位置;若转移成功的目录为Shell目录,建立符号链接后创建对应的desktop.ini文件。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211059869.4A CN115221117A (zh) | 2022-08-31 | 2022-08-31 | 一种可跨磁盘转移数据的方法及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211059869.4A CN115221117A (zh) | 2022-08-31 | 2022-08-31 | 一种可跨磁盘转移数据的方法及系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115221117A true CN115221117A (zh) | 2022-10-21 |
Family
ID=83617135
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211059869.4A Pending CN115221117A (zh) | 2022-08-31 | 2022-08-31 | 一种可跨磁盘转移数据的方法及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115221117A (zh) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1995021416A1 (en) * | 1994-02-04 | 1995-08-10 | Cadence Design Systems Inc | Distributed file system providing transparent data management |
CN1987884A (zh) * | 2005-12-19 | 2007-06-27 | 国际商业机器公司 | 用于对资源内容进行访问控制的方法和系统 |
RU2008148040A (ru) * | 2008-11-27 | 2010-06-10 | ООО "НеоБИТ" (RU) | Способ адаптивного параметрического управления безопасностью информационных систем и система для его осуществления |
CN104965776A (zh) * | 2015-07-29 | 2015-10-07 | 广东欧珀移动通信有限公司 | 移动终端在恢复模式下查看日志的方法和系统 |
CN111045995A (zh) * | 2019-10-18 | 2020-04-21 | 苏州浪潮智能科技有限公司 | 一种基于软链接的文件保护的方法、设备及介质 |
CN112799600A (zh) * | 2021-02-09 | 2021-05-14 | 珠海豹趣科技有限公司 | 一种软件搬移方法、搬移软件的还原方法及装置 |
-
2022
- 2022-08-31 CN CN202211059869.4A patent/CN115221117A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1995021416A1 (en) * | 1994-02-04 | 1995-08-10 | Cadence Design Systems Inc | Distributed file system providing transparent data management |
CN1987884A (zh) * | 2005-12-19 | 2007-06-27 | 国际商业机器公司 | 用于对资源内容进行访问控制的方法和系统 |
RU2008148040A (ru) * | 2008-11-27 | 2010-06-10 | ООО "НеоБИТ" (RU) | Способ адаптивного параметрического управления безопасностью информационных систем и система для его осуществления |
CN104965776A (zh) * | 2015-07-29 | 2015-10-07 | 广东欧珀移动通信有限公司 | 移动终端在恢复模式下查看日志的方法和系统 |
CN111045995A (zh) * | 2019-10-18 | 2020-04-21 | 苏州浪潮智能科技有限公司 | 一种基于软链接的文件保护的方法、设备及介质 |
CN112799600A (zh) * | 2021-02-09 | 2021-05-14 | 珠海豹趣科技有限公司 | 一种软件搬移方法、搬移软件的还原方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3878412B2 (ja) | データを保存し使用し及び回復する方法 | |
JP4160933B2 (ja) | 超大規模ファイル・システムでのファイル・システム使用のすばやい復元 | |
KR100437199B1 (ko) | 컴퓨터시스템및그에저장된데이터를액세싱하기위한방법 | |
US9880759B2 (en) | Metadata for data storage array | |
US5778389A (en) | Method and system for synchronizing computer file directories | |
JP3545428B2 (ja) | 動的ファイル移動方法及びシステム | |
US6496837B1 (en) | Multiple attribute file directory manipulation and navigation system | |
US20060037079A1 (en) | System, method and program for scanning for viruses | |
US7805584B2 (en) | Method and system for restoring data | |
US9430331B1 (en) | Rapid incremental backup of changed files in a file system | |
US20040107199A1 (en) | Computer application backup method and system | |
WO2013035295A1 (en) | Storage system | |
US20030110190A1 (en) | Method and system for file space management | |
US10353636B2 (en) | Write filter with dynamically expandable overlay | |
US20060010177A1 (en) | File server for long term data archive | |
JP4402103B2 (ja) | データ記憶装置、そのデータ再配置方法、プログラム | |
CN1329840C (zh) | 文件归档 | |
MXPA05011696A (es) | Metodo y sistema para mantener consistencia de espacio de nombre con un sistema de archivo. | |
US20070061540A1 (en) | Data storage system using segmentable virtual volumes | |
WO2005081942A2 (en) | Hierarchical storage management | |
WO2002027526A1 (en) | Fast data retrieval based upon contiguous consolidation of records according to frequency of access | |
US7721191B2 (en) | File save method for HTML files using recovery files including a list with temporary and final names for replacement files | |
US8667035B2 (en) | Method of converting a filesystem while the filesystem remains in an active state | |
CN101996109A (zh) | 计算机系统及其控制方法和存储计算机程序的记录介质 | |
US6823348B2 (en) | File manager for storing several versions of a file |
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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20221021 |
|
RJ01 | Rejection of invention patent application after publication |