CN114968967A - 文件管理方法、装置、设备和存储介质 - Google Patents
文件管理方法、装置、设备和存储介质 Download PDFInfo
- Publication number
- CN114968967A CN114968967A CN202210677417.6A CN202210677417A CN114968967A CN 114968967 A CN114968967 A CN 114968967A CN 202210677417 A CN202210677417 A CN 202210677417A CN 114968967 A CN114968967 A CN 114968967A
- Authority
- CN
- China
- Prior art keywords
- shared file
- content
- file
- writing
- time
- 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/18—File system types
- G06F16/182—Distributed file systems
-
- 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/13—File access structures, e.g. distributed indices
-
- 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/16—File or folder operations, e.g. details of user interfaces specifically adapted to file systems
-
- 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/17—Details of further file system functions
- G06F16/176—Support for shared access to files; File sharing support
-
- 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/18—File system types
- G06F16/1873—Versioning file systems, temporal file systems, e.g. file system supporting different historic versions of files
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开提供了一种文件管理方法、装置、设备和存储介质,涉及分布式技术领域,尤其涉及资源管理技术。具体实现方案为:响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开;在共享文件异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间;响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息;其中,内容属性信息中包括最新修改时间。根据本公开的技术,实现了对异常打开的共享文件的正常写入。
Description
技术领域
本公开涉及分布式技术领域,尤其涉及资源管理技术,具体涉及一种文件管理方法、装置、设备和存储介质。
背景技术
分布式文件系统(Distributed File System,DFS)是指文件系统管理的物理存储资源通过计算机网络与节点相连;或是若干不同的逻辑磁盘分区或卷标组合在一起而形成的完整的有层次的文件系统。DFS为分布在网络上任意位置的资源提供一个逻辑上的树形文件系统结构,从而使用户访问分布在网络上的共享文件更加简便。
发明内容
本公开提供了一种文件管理方法、装置、设备和存储介质。
根据本公开的一方面,提供了一种文件管理方法,包括:
响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开;
在共享文件异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间;
响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息;
其中,内容属性信息中包括最新修改时间。
根据本公开的另一方面,提供了一种电子设备,包括:
至少一个处理器;以及
与至少一个处理器通信连接的存储器;其中,
存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行本公开实施例提供的任意一种文件管理方法。
根据本公开的又一方面,还提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,计算机指令用于使计算机执行本公开实施例提供的任意一种文件管理方法。
根据本公开的技术,实现了对异常打开的共享文件的正常写入。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1A是本公开实施例提供的一种文件管理系统的结构图;
图1B是本公开实施例提供的一种文件管理方法的流程图;
图2是本公开实施例提供的另一种文件管理方法的流程图;
图3是本公开实施例提供的另一种文件管理方法的流程图;
图4是本公开实施例提供的另一种文件管理方法的流程图;
图5是本公开实施例提供的另一种文件管理方法的流程图;
图6是本公开实施例提供的一种文件管理装置的结构图;
图7是用来实现本公开实施例的文件管理方法的电子设备的框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
为了便于理解,首先对本公开涉及的文件管理系统的具体结构进行说明。
参见图1A所示的文件管理系统,包括至少一个客户端10、管理节点20和存储节点30;客户端10分别与管理节点20和存储节点30通信连接;
其中,存储节点30中用于存储共享文件中实际写入的内容;
管理节点20中用于存储共享文件的元数据;其中,元数据可以包括共享文件的版本标识和内容属性信息;其中,内容属性信息可以包括最新修改时间。
客户端10在具备对存储节点30中的共享文件的写入需求时,向管理节点20发送对共享文件的文件打开请求;
管理节点20响应于文件打开请求,在共享文件为已打开状态的情况下,根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开,并在异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间;将当前版本标识和写入空间反馈至客户端10
客户端10根据所分配的写入空间向存储节点30的共享文件中写入内容,并在写入完成之后,根据自身持有的目标版本标识向管理节点20发起对共享文件的属性更新请求;
管理节点20响应于属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息。
示例性的,存储节点30可以是分布式文件系统中的存储节点。
为了降低对管理节点20的存储能力的要求,可选的,还可以设置一个专用于持久化共享文件对应元数据的数据库,并在需要是进行元数据的查询获取。
基于上述文件管理系统,本公开实施例还提供了文件管理方法和点文件管理装置,适用于基于图1A所示文件管理系统的基础上,对分布式文件系统中的共享文件进行内容写入的场景中。本公开实施例所提供的各文件管理方法,可以由文件管理装置执行,该装置可以采用软件和/或硬件实现,并具体配置于电子设备中,该电子设备可以是物理机或虚拟机,本公开对此不作任何限定。
以下,将对文件管理方法的相关内容进行详述。
参见图1B所示的文件管理方法,包括:
S101、响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开。
其中,共享文件为可供多方(如至少一个客户端)进行内容写入和读取的文件,通常为分布式文件系统中的文件。
为了便于在多方同时写入的情况,避免写入冲突的情况,通常会设置共享文件的打开状态,用于表征共享文件当前时刻是否被写入占用。其中,打开状态包括已打开状态和待打开状态。其中,已打开状态表征共享文件当前时刻已被客户端写入占用,在该状态下,仅允许该文件打开请求的发起方(例如前述客户端)在共享文件中进行内容写入,禁止第三方在共享文件中进行内容写入;待打开状态表征共享文件当前时刻未被写入占用,在该状态下允许任一通信设备(如前述客户端)申请打开共享文件,并分配共享文件中的写入空间,并在所分配的写入空间中进行内容写入。
其中,共享文件的最新修改时间,用于表征共享文件最近一次被修改,例如被写入时的时间戳信息。
其中,共享文件异常打开可以理解为共享文件被过长打开的情况,通常为申请打开的客户端在共享文件中写入内容过程中出现异常挂机或掉线的情况。
在一个可选实施例中,根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开,可以是:根据共享文件的最新修改时间,确定共享文件的过长打开时段;若当前时间处于过长打开时段,则确定共享文件被异常打开;否则,确定共享文件未被异常打开。
示例性的,可以预先设置最长打开时长,并将最新修改时间和最长打开时长的和值,作为过长打开时段的起始时间;若当前时间超出该过长打开时段的起始时间,则确定当前时间处于过长打开时段,此时确定共享文件被异常打开;若当前时间未超出该过长打开时段的起始时间,则确定当前时间未处于过长打开时段,此时确定共享文件未被异常打开。
S102、在共享文件异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间。
其中,版本标识用于唯一表征共享文件版本,随着共享文件被写入,版本标识不断变化。当前版本标识可以理解为当前时刻共享文件所使用的版本标识。为了便于管理,版本标识中可以包括版本号,通过增量版本号的方式,实现对当前版本标识的不断更新。
S103、响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息;内容属性信息中包括最新修改时间。
当共享文件在已打开状态的情况下,通常禁止对新的文件打开请求进行响应。然而,当共享文件处于异常打开的已打开状态时,禁止对新的文件打开请求进行响应,将会出现共享文件无法继续实现文件写入,影响共享文件的正常使用。因此,此时会参照共享文件为待打开状态的情况进行响应。
为了便于理解,以下将首先对共享文件在待打开状态的情况进行详细说明。
若共享文件为待打开状态,则认定共享文件未被任一方进行内容写入,此时可以通过调整共享文件的打开状态为已打开状态,开启写入权限,并调整共享文件的当前版本标识,同时为文件打开请求发起方分配新的写入空间;相应的,后续文件打开请求发起方可以在该写入空间中进行内容写入,并在写入完成后,根据自身持有的版本标识发起对共享文件的属性更新请求,进行共享文件的当前版本标识和属性更新请求中的版本标识的一致性,控制调整共享文件的内容属性信息。
需要说明的是,由于共享文件可能会由于本次文件打开请求发起方在进行内容写入时写入时间过长、写入过程异常挂机或掉线等原因,导致共享文件的当前版本标识已在为该发起方分配写入空间之后进行调整,因此,可能存在共享文件的当前版本标识与属性更新请求中的版本标识不一致的情况,因此,需要根据两者的一致性,确定是否该发起方在共享文件中的内容写入操作是否有效,根据内容写入操作的有效性,进行内容属性信息中最新修改时间的调整。
具体的,若内容写入操作有效,则将共享文件的最新修改时间调整为共享文件的本次写入时间;若内容写入操作无效,则禁止调整最新修改时间。
进一步的,内容属性信息中还可以包括内容有效性信息。示例性的,若内容写入操作有效,则调整共享文件的内容有效性信息中的有效内容长度;若内容写入操作无效,则将本次写入内容标记为无效,以便与有效写入的内容加以区分。其中,无效的写入内容无法进行内容读取。
示例性的,调整共享文件的内容有效性信息中的有效内容长度,可以是在最新的有效内容长度的基础上,叠加本次写入内容的写入长度。
相应的,在共享文件异常打开的情况下,为了便于其他方进行内容写入,需要重新响应本次的文件打开请求,恢复对共享文件的正常写入。
在一个可选实施例中,在共享文件异常打开的情况下,调整共享文件的当前版本标识,从而与前次异常打开情况下的版本标识加以区分,避免出现版本混淆。进一步的,分配共享文件中写入内容的写入空间,避免本次内容写入与前次异常打开的内容写入过程出现写冲突的情况。
进一步的,在本次的写入空间内写入完成之后,文件打开请求的发起方会发起对共享文件的属性更新请求,以便共享文件的内容属性信息与本次内容写入后的情况保持一致。
示例性的,可以根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息。
具体的,若当前版本标识和属性更新请求中的目标版本标识相一致,则认为共享文件在本次写入过程中,未出现多方并行写入的情况,因此,可以直接调整共享文件的内容属性信息中的最新修改时间;若当前版本标识和属性更新请求中的目标版本标识不一致,则认为在本次写入过程中,在启动撰写之后,出现至少部分时间多方并行写入的情况,因此,认定本次写入无效,因此无需调整共享文件的内容属性信息中的最新修改时间。
本公开实施例通过在共享文件为已打开状态的情况下,引入当前时间和共享文件的最新修改时间,进行共享文件异常打开判定,从而在共享文件异常打开的情况下,重新进行写入空间的分配,便于推进共享文件的正常写入。同时,进行当前版本标识的调整,并将当前版本标识作为后续调整最新修改时间的依据,避免异常打开对应的文件打开请求发起方恢复正常后,仍旧进行最新修改时间修改带来的最新修改时间混淆,保证了对共享文件在异常打开情况下的有效管理。
在一个可选实施例中,在上述各技术方案的基础上,还可以追加以下方案:在共享文件为待打开状态的情况下,调整共享文件至已打开状态,并继续执行对共享文件的当前版本标识的调整和写入空间的分配操作,以及对共享文件的属性更新请求的响应操作,从而完善了共享文件在待打开状态下的文件管理机制,保证了文件管理方案的合理性和全面性。需要说明的是,在待打开状态下,与未打开状态下相同的处理步骤,可参见其他实施例的相关表述。
在上述各技术方案的基础上,本公开还提供了一个可选实施例,在该可选实施例中,对异常打开的识别操作进行了优化改进。需要说明的是,在本公开实施例中未详述部分,可参见其他实施例中的相关表述,在此不再赘述。
参见图2所示的一种文件管理方法,包括:
S201、响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则确定当前时间与共享文件的最新修改时间之间的时间差值。
其中,时间差值可以理解为当前时间与共享文件的最新修改时间之间的时间长度,该时间长度可用于衡量前次文件打开请求的文件写入时长。
S202、根据时间差值,识别共享文件是否异常打开。
示例性的,若时间差值较大,则表明共享文件的前次文件打开请求对应写入时长过长,前次文件打开请求发起方异常挂机或掉线的可能性较大;若时间差值较小,则表明共享文件的前次文件打开请求对应写入时长较短,前次文件打开请求发起方异常挂机或掉线的可能性较小。
为了便于进行时间差值较大或较小的评判,在一个可选实施例中,可以引入预设时长阈值,根据时间差值与预设时长阈值的大小,映射时间差值的过大过小情况,作为共享文件异常打开与否的评判依据。
在一个具体实施例中,若时间差值大于预设时长阈值,则认为前次文件打开请求对应写入时长过长,确定共享文件异常打开;若时间差值不大于预设时长阈值,则认为前次文件打开请求对应写入时长征程,确定共享文件未异常打开。其中,预设时长阈值可以由技术人员根据需要或经验值进行设置或调整,本公开实施例对预设时长阈值的具体数值不作任何限定。
可以理解的是,通过引入时间差值和预设时长阈值的大小关系,进行共享文件异常打开与否的评判依据,使得共享文件异常打开与否的确定操作更加方便快捷,有助于提高异常打开识别效率,进而有助于提高文件管理效率。
S203、在共享文件异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间。
S204、响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息;其中,内容属性信息中包括最新修改时间。
本公开实施例通过引入当前时间和共享文件的最新修改时间之间的时间差值,进行共享文件异常打开与否的评判依据,从而将异常打开情况与时间差值相关联,而时间差值能够侧面反映前次文件打开请求对应写入过程的写入时长,从而能够有效识别出由于写入方挂机或掉线等导致写入时长过长的情况,有助于提高异常打开识别的有效性和查全率。
在上述各技术方案的基础上,本公开还提供了一个可选实施例,在该可选实施例中,将写入空间的分配机制进行了优化改进。
进一步参见图3所示的一种文件管理方法,包括:
S301、响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开。
S302、在共享文件异常打开的情况下,调整共享文件的当前版本标识,并将已分配的最新内容区块设置为密封状态;其中,密封状态用于指示禁止在相应内容区块中写入数据。
S303、重新分配内容区块作为在共享文件中写入内容的写入空间。
在共享文件采用顺次连接的区块进行数据存储的应用场景中,可以在单次写入过程进行内容区块的分配,从而使得文件打开请求发起方能够通过在所分配内容区块中写入内容,实现了对不同写入内容的区分设置,又能够通过内容区块的依次拼接,不断实现对共享文件的写入更新。
由于不同写入方(通常与当次文件打开请求发起方相同)单次写入数据的大小通常不同,因此,共享文件中不同内容区块的大小通常不同。
为了避免本次写入与前次写入出现内容区块混淆或写入混乱的情况发生,通常会在本次分配内容区块之前,关闭前次已分配的最新内容区块,也即禁止在前次已分配的最新内容区块中进行内容写入。为了方便管理,可以在各内容区块中设置状态信息,并通过设置该状态信息的具体数值,实现对内容区块中允许内容写入与否的控制。
示例性的,可以在本次分配内容区块之前,将已分配的最新内容区块设置为指示禁止在相应内容区块中写入数据的密封状态。
在一个可选实施例中,重新分配内容区块作为在共享文件中写入内容的写入空间,可以是,重新分配内容区块的标识,用于进行共享文件中已分配内容区块的区分,以及分配该标识对应的初始地址,作为在共享文件中写入内容的写入空间对应的初始地址。
示例性的,还可以将重新分配的内容区块的状态信息设置为开启状态,用于指示可以在相应内容区块中进行内容写入,并在下次需要重新分配内容区块时,先将该内容区块的状态信息切换为密封状态,再进行内容区块的重新分配。
S304、响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容属性信息;其中,内容属性信息中包括最新修改时间。
本公开实施例通过引入内容区块作为共享文件中单次写入内容的存储空间,并在进行新的内容区块分配之前,将已分配的最新内容区块设置为密封状态,从而禁止在该最新内容区块中再次写入数据,避免了对已写入内容的误操作,保证了已写入内容的准确性。
在上述各技术方案的基础上,本公开还提供了一个可选实施例,在该可选实施例中,将内容属性信息细化为包括最新修改时间和/或内容有效性信息,从而丰富了内容属性信息的调整机制。
进一步参见图4所示的一种文件管理方法,包括:
S401、响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开。
S402、在共享文件异常打开的情况下,调整共享文件的当前版本标识,并分配在共享文件中写入内容的写入空间。
S403A、响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的最新修改时间。
S403B、响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识的一致性,控制调整共享文件的内容有效性信息。
其中,属性更新请求用于指示对共享文件的内容属性信息进行修改。其中,属性更新请求可以由共享文件的写入方在写入空间写入完成后进行发起。需要说明的是,属性更新请求可以在一次写入完成后进行发起,还可以在累计多次写入完成后,将多次写入过程作为一次连续吸入过程,进行一次发起。
其中,内容属性信息可以包括最新修改时间和/或内容有效性信息。
其中,最新修改时间用于表征共享文件最近一次被修改,例如被写入的时间戳信息。
其中,内容有效性信息能够反映共享文件的写入内容的有效性和/或有效写入内容的统计情况。
可选的,内容有效性信息中可以包括有效内容长度,用于反映共享文件中有效写入内容的统计情况。或者可选的,内容有效性信息中可以包括有效和/或无效标记,用于表征本次所写入内容的有效性。
其中,目标版本标识即为属性更新请求中所携带的版本标识,可以理解为写入方作为文件打开请求的请求方发送文件打开请求后,所接收到的版本标识,如果本次写入过程中不存在其他方介入时,目标版本标识将与前述当前版本标识相一致;若本次写入过程中存在其他方介入时,目标版本标识将与当前版本标识不一致。
在一个可选实施例中,若目标版本标识与当前版本标识一致,则表明本次写入过程中不存在其他方介入,此时认定本次写入有效,关联调整共享文件的最新修改时间,从而保证最新修改时间与共享文件的实际修改情况相一致。
在一个可选实施例中,若目标版本标识与当前版本标识不一致,则表明本次写入过程中存在其他方介入,此时认定本次写入无效,禁止调整共享文件的最新修改时间,避免最新修改时间与共享文件中有效写入内容的实际修改情况不一致。
可以理解的是,通过目标版本标识和当前版本标识的一致性,控制进行共享文件的最新修改时间的调整,能够赋予最新修改时间具备共享文件的有效写入修改的特性,有助于对共享文件的可持续化管理。
在一个可选实施例中,若目标版本标识和当前版本标识一致,则表明本次写入过程中不存在其他方介入,此时认定本次写入有效,可以根据属性更新请求中写入内容长度,调整有效内容长度。进一步的,还可以标记本次写入内容有效。
在一个可选实施例中,若目标版本标识和当前版本标识不一致,则表明本次写入过程中存在其他方介入,此时认定本次写入无效,禁止调整内容有效性信息中的有效内容长度。进一步的,还可以标记本次写入内容无效,与有效内容加以区分。其中,标记无效的内容在共享文件中无法进行内容读取。
可以理解的是,通过目标版本标识和当前版本标识的一致性,控制进行有效内容长度的调整,能够实现对共享文件中有效内容的准确性统计,便于了解共享文件的有效内容存储情况。同时,通过目标版本标识和当前版本标识的一致性,控制进行共享文件的内容无效标记,便于将无效写入内容与有效写入内容加以区分,实现对不同类别写入内容的全方位管理。
在上述各技术方案的基础上,本公开还提供了一个优选实施例,在该优选实施例中,对分布式文件系统中的共享文件的写入过程进行有效管理。
参见图5所示的文件管理方法,包括:
S501、客户端向管理节点发送对共享文件的打开请求。
S502、管理节点响应于打开请求,查看共享文件的状态信息。
S503、管理节点判断状态信息是否为已打开状态;若否,则执行S504;否则,执行S515。
S504、管理节点更新共享文件的当前版本标识,并将共享文件的状态信息修改为已打开状态,并将已分配的最新内容区块设置为密封状态,为本次写入重新分配内容区块。
S505、管理节点向客户端反馈当前版本标识和重新分配的内容区块的区块标识。
S506、客户端向存储节点中所接收区块标识对应内容区块中写入内容。
S507、客户端在本次写入完成后,针对共享文件向管理节点发送包括本次写入对应的目标版本标识、本次写入长度和本次写入时间的属性更新请求。
S508、管理节点判断目标版本标识与共享文件的当前版本标识是否一致;若是,则执行S509;否则,执行S513。
S509、管理节点根据本次写入时间,调整共享文件的最新修改时间和有效内容长度;继续执行S510。
S510、管理节点向客户端反馈本次写入成功。
S511、客户端向管理节点发送对共享文件的关闭请求。
S512、管理节点将共享文件设置为未打开状态。
S513、管理节点标记本次写入内容无效,禁止调整共享文件的最新修改时间和有效内容长度。
S514、管理节点向客户端反馈本次写入失败。
S515、管理节点确定当前时间与共享文件的最新修改时间的时间差值。
S516、管理节点判断时间差值是否大于预设时长阈值;若是,则执行S517;否则,执行S518。
S517、管理节点将共享文件设置为已打开状态;返回执行S504。
S518、管理节点向客户端反馈打开失败。
本公开实施例的技术方案通过引入当前版本标识和共享文件的状态信息,能够保证任何时刻,对于一个共享文件,均只有一个客户端在打开写,避免出现写冲突的情况发生。
进一步,上述技术方案无需设置一主多从的管理节点,不会受限于管理节点的内存限制,从而保证了系统中同时可打开的共享文件的数量,保证了分布式文件系统中多文件并行写能力。
进一步的,通过引入当前时间与最新修改时间之间的时间差值,能够在共享文件异常打开的情况下,通过强制写入的方式,退出异常打开的状态,保证分布式文件系统中共享文件的正常共享写入。
作为上述各文件管理方法的实现,本公开还提供了一种实施上述各文件管理方法的执行装置的可选实施例。进一步参见图6所示的一种文件管理装置600,包括:异常打开识别模块601、写入空间分配模块602和内容属性调整模块603。其中,
异常打开识别模块601,用于响应于对共享文件的文件打开请求,在共享文件为已打开状态的情况下,则根据当前时间和共享文件的最新修改时间,识别共享文件是否异常打开;
写入空间分配模块602,用于在共享文件异常打开的情况下,调整共享文件的当前版本标识的一致性,并分配在共享文件中写入内容的写入空间;
内容属性调整模块603,用于响应于在写入空间写入完成后发起的对共享文件的属性更新请求,根据当前版本标识和属性更新请求中的目标版本标识,控制调整共享文件的内容属性信息;
其中,内容属性信息中包括最新修改时间。
本公开实施例通过在共享文件为已打开状态的情况下,引入当前时间和共享文件的最新修改时间,进行共享文件异常打开判定,从而在共享文件异常打开的情况下,重新进行写入空间的分配,便于推进共享文件的正常写入。同时,进行当前版本标识的调整,并将当前版本标识作为后续调整最新修改时间的依据,避免异常打开对应的文件打开请求发起方恢复正常后,仍旧进行最新修改时间修改带来的最新修改时间混淆,保证了对共享文件在异常打开情况下的有效管理。
在一个可选实施例中,异常打开识别模块601,包括:
时间差值确定单元,用于确定当前时间与共享文件的最新修改时间之间的时间差值;
异常打开识别单元,用于根据时间差值,识别共享文件是否异常打开。
在一个可选实施例中,异常打开识别单元,包括:
异常打开确定子单元,用于若时间差值大于预设时长阈值,则确定共享文件异常打开;
非异常打开确定子单元,用于若时间差值不大于预设时长阈值,则确定共享文件未异常打开。
在一个可选实施例中,写入空间分配单元,包括:
密封状态设置子单元,用于将已分配的最新内容区块设置为密封状态;其中,密封状态用于指示禁止在相应内容区块中写入数据;
内容区块分配子单元,用于重新分配内容区块作为在共享文件中写入内容的写入空间。
在一个可选实施例中,该装置600,还包括:
待打开状态响应模块,用于在共享文件为待打开状态的情况下,调整共享文件至已打开状态,并继续执行对共享文件的当前版本标识的调整和写入空间的分配操作,以及对共享文件的属性更新请求的响应操作。
在一个可选实施例中,内容属性调整模块603,包括最新修改时间调整单元,具体用于:
若目标版本标识和当前版本标识一致,则调整共享文件的最新修改时间;
若目标版本标识与当前版本标识不一致,则禁止调整共享文件的最新修改时间。
在一个可选实施例中,内容属性信息还包括内容有效性信息;
内容属性调整模块603,包括内容有消息调整单元,具体用于:
若目标版本标识和当前版本标识一致,则根据属性更新请求中的写入内容长度,调整内容有效性信息中的有效内容长度;
若目标版本标识与当前版本标识不一致,则标记属性更新请求对应写入内容无效,禁止调整内容有效性信息中的有效内容长度。
上述文件管理装置可执行本公开任意实施例所提供的文件管理方法,具备执行文件管理方法相应的功能模块和有益效果。
本公开的技术方案中,所涉及的共享文件的最新修改时间、文件打开请求、属性更新请求、当前版本标识等和内容属性信息等的收集、存储、使用、加工、传输、提供和公开等处理,均符合相关法律法规的规定,且不违背公序良俗。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图7示出了可以用来实施本公开的实施例的示例电子设备700的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图7所示,设备700包括计算单元701,其可以根据存储在只读存储器(ROM)702中的计算机程序或者从存储单元708加载到随机访问存储器(RAM)703中的计算机程序,来执行各种适当的动作和处理。在RAM 703中,还可存储节点700操作所需的各种程序和数据。计算单元701、ROM 702以及RAM 703通过总线704彼此相连。输入/输出(I/O)接口705也连接至总线704。
设备700中的多个部件连接至I/O接口705,包括:输入单元706,例如键盘、鼠标等;输出单元707,例如各种类型的显示器、扬声器等;存储单元708,例如磁盘、光盘等;以及通信单元709,例如网卡、调制解调器、无线通信收发机等。通信单元709允许设备700通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元701可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元701的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元701执行上文所描述的各个方法和处理,例如文件管理方法。例如,在一些实施例中,文件管理方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元708。在一些实施例中,计算机程序的部分或者全部可以经由ROM 702和/或通信单元709而被载入和/或安装到设备700上。当计算机程序加载到RAM 703并由计算单元701执行时,可以执行上文描述的文件管理方法的一个或多个步骤。备选地,在其他实施例中,计算单元701可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行文件管理方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、复杂可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式系统的服务器,或者是结合了区块链的服务器。
人工智能是研究使计算机来模拟人的某些思维过程和智能行为(如学习、推理、思考、规划等)的学科,既有硬件层面的技术也有软件层面的技术。人工智能硬件技术一般包括如传感器、专用人工智能芯片、云计算、分布式存储、大数据处理等技术;人工智能软件技术主要包括计算机视觉技术、语音识别技术、自然语言处理技术及机器学习/深度学习技术、大数据处理技术、知识图谱技术等几大方向。
云计算(cloud computing),指的是通过网络接入弹性可扩展的共享物理或虚拟资源池,资源可以包括服务器、操作系统、网络、软件、应用和存储节点等,并可以按需、自服务的方式对资源进行部署和管理的技术体系。通过云计算技术,可以为人工智能、区块链等技术应用、模型训练提供高效强大的数据处理能力。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开提供的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。
Claims (17)
1.一种文件管理方法,包括:
响应于对共享文件的文件打开请求,在所述共享文件为已打开状态的情况下,则根据当前时间和所述共享文件的最新修改时间,识别所述共享文件是否异常打开;
在所述共享文件异常打开的情况下,调整所述共享文件的当前版本标识,并分配在所述共享文件中写入内容的写入空间;
响应于在所述写入空间写入完成后发起的对所述共享文件的属性更新请求,根据所述当前版本标识和所述属性更新请求中的目标版本标识的一致性,控制调整所述共享文件的内容属性信息;
其中,所述内容属性信息中包括所述最新修改时间。
2.根据权利要求1所述的方法,其中,所述根据当前时间和所述共享文件的最新修改时间,识别所述共享文件是否异常打开,包括:
确定所述当前时间与所述共享文件的所述最新修改时间之间的时间差值;
根据所述时间差值,识别所述共享文件是否异常打开。
3.根据权利要求2所述的方法,其中,所述根据所述时间差值,识别所述共享文件是否异常打开,包括:
若所述时间差值大于预设时长阈值,则确定所述共享文件异常打开;
若所述时间差值不大于所述预设时长阈值,则确定所述共享文件未异常打开。
4.根据权利要求1-3所述的方法,其中,其中,所述分配在所述共享文件中写入内容的写入空间,包括:
将已分配的最新内容区块设置为密封状态;其中,所述密封状态用于指示禁止在相应内容区块中写入数据;
重新分配内容区块作为在所述共享文件中写入内容的写入空间。
5.根据权利要求1-4任一项所述的方法,还包括:
在所述共享文件为待打开状态的情况下,调整所述共享文件至已打开状态,并继续执行对所述共享文件的当前版本标识的调整和写入空间的分配操作,以及对共享文件的属性更新请求的响应操作。
6.根据权利要求1-5任一项所述的方法,其中,所述根据所述当前版本标识和所述属性更新请求中的目标版本标识的一致性,控制调整所述共享文件的内容属性信息,包括:
若所述目标版本标识和所述当前版本标识一致,则调整所述共享文件的最新修改时间;
若所述目标版本标识与所述当前版本标识不一致,则禁止调整所述共享文件的最新修改时间。
7.根据权利要求1-6任一项所述的方法,其中,所述内容属性信息还包括内容有效性信息;
所述根据所述当前版本标识和所述属性更新请求中的目标版本标识的一致性,控制调整所述共享文件的内容属性信息,包括:
若所述目标版本标识和所述当前版本标识一致,则根据所述属性更新请求中的写入内容长度,调整所述内容有效性信息中的有效内容长度;
若所述目标版本标识与所述当前版本标识不一致,则标记所述属性更新请求对应写入内容无效,禁止调整所述内容有效性信息中的有效内容长度。
8.一种文件管理装置,包括:
异常打开识别模块,用于响应于对共享文件的文件打开请求,在所述共享文件为已打开状态的情况下,则根据当前时间和所述共享文件的最新修改时间,识别所述共享文件是否异常打开;
写入空间分配模块,用于在所述共享文件异常打开的情况下,调整所述共享文件的当前版本标识的一致性,并分配在所述共享文件中写入内容的写入空间;
内容属性调整模块,用于响应于在所述写入空间写入完成后发起的对所述共享文件的属性更新请求,根据所述当前版本标识和所述属性更新请求中的目标版本标识,控制调整所述共享文件的内容属性信息;
其中,所述内容属性信息中包括所述最新修改时间。
9.根据权利要求8所述的装置,其中,所述异常打开识别模块,包括:
时间差值确定单元,用于确定所述当前时间与所述共享文件的所述最新修改时间之间的时间差值;
异常打开识别单元,用于根据所述时间差值,识别所述共享文件是否异常打开。
10.根据权利要求9所述的装置,其中,所述异常打开识别单元,包括:
异常打开确定子单元,用于若所述时间差值大于预设时长阈值,则确定所述共享文件异常打开;
非异常打开确定子单元,用于若所述时间差值不大于所述预设时长阈值,则确定所述共享文件未异常打开。
11.根据权利要求8-10任一项所述的装置,其中,所述写入空间分配单元,包括:
密封状态设置子单元,用于将已分配的最新内容区块设置为密封状态;其中,所述密封状态用于指示禁止在相应内容区块中写入数据;
内容区块分配子单元,用于重新分配内容区块作为在所述共享文件中写入内容的写入空间。
12.根据权利要求8-11任一项所述的装置,还包括:
待打开状态响应模块,用于在所述共享文件为待打开状态的情况下,调整所述共享文件至已打开状态,并继续执行对所述共享文件的当前版本标识的调整和写入空间的分配操作,以及对共享文件的属性更新请求的响应操作。
13.根据权利要求8-12所述的装置,其中,所述内容属性调整模块,包括最新修改时间调整单元,具体用于:
若所述目标版本标识和所述当前版本标识一致,则调整所述共享文件的最新修改时间;
若所述目标版本标识与所述当前版本标识不一致,则禁止调整所述共享文件的最新修改时间。
14.根据权利要求8-13任一项所述的装置,其中,所述内容属性信息还包括内容有效性信息;
所述内容属性调整模块,包括内容有消息调整单元,具体用于:
若所述目标版本标识和所述当前版本标识一致,则根据所述属性更新请求中的写入内容长度,调整所述内容有效性信息中的有效内容长度;
若所述目标版本标识与所述当前版本标识不一致,则标记所述属性更新请求对应写入内容无效,禁止调整所述内容有效性信息中的有效内容长度。
15.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-7中任一项所述的文件管理方法。
16.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使计算机执行根据权利要求1-7中任一项所述的文件管理方法。
17.一种计算机程序产品,包括计算机程序/指令,所述计算机程序/指令被处理器执行时实现权利要求1-7中任一项所述文件管理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210677417.6A CN114968967A (zh) | 2022-06-15 | 2022-06-15 | 文件管理方法、装置、设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210677417.6A CN114968967A (zh) | 2022-06-15 | 2022-06-15 | 文件管理方法、装置、设备和存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114968967A true CN114968967A (zh) | 2022-08-30 |
Family
ID=82963802
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210677417.6A Pending CN114968967A (zh) | 2022-06-15 | 2022-06-15 | 文件管理方法、装置、设备和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114968967A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115168908A (zh) * | 2022-09-05 | 2022-10-11 | 深圳市科力锐科技有限公司 | 文件保护方法、装置、设备及存储介质 |
CN116932779A (zh) * | 2023-08-14 | 2023-10-24 | 企查查科技股份有限公司 | 知识图谱的数据处理方法和装置 |
-
2022
- 2022-06-15 CN CN202210677417.6A patent/CN114968967A/zh active Pending
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115168908A (zh) * | 2022-09-05 | 2022-10-11 | 深圳市科力锐科技有限公司 | 文件保护方法、装置、设备及存储介质 |
CN116932779A (zh) * | 2023-08-14 | 2023-10-24 | 企查查科技股份有限公司 | 知识图谱的数据处理方法和装置 |
CN116932779B (zh) * | 2023-08-14 | 2024-03-12 | 企查查科技股份有限公司 | 知识图谱的数据处理方法和装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN114968967A (zh) | 文件管理方法、装置、设备和存储介质 | |
EP4394662A1 (en) | Training method, apparatus and system for deep learning model, and device and medium | |
US20230120580A1 (en) | Access control method and apparatus for shared memory, electronic device and autonomous vehicle | |
KR20210156243A (ko) | 딥러닝 프레임워크의 훈련 방법, 장치 및 저장 매체 | |
CN107211003A (zh) | 分布式存储系统及管理元数据的方法 | |
CN112905314A (zh) | 异步处理方法、装置、电子设备、存储介质、及路侧设备 | |
CN112559908A (zh) | 数据标识生成方法、装置、设备、介质和程序产品 | |
CN115599821A (zh) | 缓存控制方法、装置、设备及介质 | |
CN112527506B (zh) | 设备资源的处理方法、装置、电子设备及存储介质 | |
CN113132479A (zh) | 流量切换、模型生成方法、装置、设备、存储介质及程序 | |
CN113590329A (zh) | 资源处理方法及装置 | |
CN111124256B (zh) | 管理存储的方法、设备和计算机程序产品 | |
CN114518848B (zh) | 存储数据的处理方法、装置、设备和介质 | |
CN113360689B (zh) | 图像检索系统、方法、相关装置及计算机程序产品 | |
CN113641688B (zh) | 节点更新方法、相关装置及计算机程序产品 | |
CN113553074B (zh) | 小程序分发控制方法、装置、电子设备以及存储介质 | |
CN109521966A (zh) | 存储设备虚拟化方法、装置、终端及计算机可读存储介质 | |
CN115061947A (zh) | 资源管理方法、装置、设备和存储介质 | |
CN115269530A (zh) | 数据同步方法、电子设备及计算机可读存储介质 | |
CN113313195B (zh) | 标注任务处理方法、装置、设备、存储介质及程序产品 | |
CN114979141B (zh) | 一种任务处理方法、装置、设备以及存储介质 | |
CN113282571A (zh) | 数据转移方法、装置、电子设备和存储介质 | |
CN115309568A (zh) | 一种实现多进程文件共享的方法、装置、设备及介质 | |
CN115174447A (zh) | 一种网络通信方法、装置、系统、设备及存储介质 | |
CN115328913A (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 |