[go: up one dir, main page]

CN108415986B - Data processing method, device, system, medium and computing equipment - Google Patents

Data processing method, device, system, medium and computing equipment Download PDF

Info

Publication number
CN108415986B
CN108415986B CN201810142664.XA CN201810142664A CN108415986B CN 108415986 B CN108415986 B CN 108415986B CN 201810142664 A CN201810142664 A CN 201810142664A CN 108415986 B CN108415986 B CN 108415986B
Authority
CN
China
Prior art keywords
data
storage node
file
data block
data file
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.)
Active
Application number
CN201810142664.XA
Other languages
Chinese (zh)
Other versions
CN108415986A (en
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.)
Hangzhou Netease Shuzhifan Technology Co ltd
Original Assignee
Hangzhou Langhe 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 Hangzhou Langhe Technology Co Ltd filed Critical Hangzhou Langhe Technology Co Ltd
Priority to CN201810142664.XA priority Critical patent/CN108415986B/en
Publication of CN108415986A publication Critical patent/CN108415986A/en
Application granted granted Critical
Publication of CN108415986B publication Critical patent/CN108415986B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/16File or folder operations, e.g. details of user interfaces specifically adapted to file systems
    • G06F16/162Delete operations
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/13File access structures, e.g. distributed indices
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/18File system types
    • G06F16/182Distributed file systems

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

The embodiment of the invention provides a data processing method. The method comprises the following steps: if the current data block of the main storage node meets the first data processing condition, extracting the determined effective data file of the current data block; rewriting the extracted effective data file into the last data block of the main storage node and the at least one slave storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; and deleting the current data block from the main storage node and at least one auxiliary storage node by using a preset data consistency protocol. In addition, the embodiment of the invention provides a data processing device, a medium, a system and a computing device. According to the embodiment of the invention, independent garbage collection of each storage node can be avoided, and the consistency of the data stored in the data block of each storage node is ensured on the basis of collecting the garbage in the storage node.

Description

Data processing method, device, system, medium and computing equipment
Technical Field
The embodiment of the invention relates to the technical field of data processing, in particular to a data processing method, a data processing device, a data processing system, a data processing medium and a computing device.
Background
This section is intended to provide a background or context to the embodiments of the invention that are recited in the claims. The description herein is not admitted to be prior art by inclusion in this section.
When a conventional stand-alone file system (Linux ext4xfs) stores a file, metadata information of the file, such as an inode and a file name, needs to be stored. If a large number of small files are stored, the metadata information cannot be completely cached in the memory due to too many files, the metadata information can be read/written by randomly accessing the disk for many times when the files are read and written, and the read-write performance of the disk is greatly lower than the sequential read-write performance, so the read-write performance is rapidly reduced.
In order to optimize the writing performance of the small file, an additional writing storage mode is generally adopted, the small file is added behind a large file, and then index information of the small file is recorded in an index database, wherein the index information can include the offset and the length of the small file in the large file. The writing performance of the small file is optimized by the additional writing mode; and because the index information recorded in the index database is far smaller than the meta information recorded in the file system, the index information can be completely cached in the memory, so that the corresponding data can be read only by one disk IO (input output).
In the storage mode, a logic deletion command file is added at the tail end of the large file to mark that the small file is deleted, so that the aim of deleting the small file is fulfilled. However, in practice, only the small file is logically deleted, that is, the data in the small file is still in the memory, and no actual physical deletion is performed, so that the storage method needs to perform garbage collection, that is, the valid data file (valid small file) in the large file is read out and rewritten, and then the large file is physically deleted, so as to achieve the purpose of saving the memory.
In a distributed system, data (which may be understood as the above small files) needs to be stored on a plurality of storage nodes, and for the same copy of data, the plurality of storage nodes storing the copy of data form a copy group, that is, the data stored in each storage node in the same copy group is the same. Each storage node in the replica group is a copy (storage node), wherein one copy is called a master copy or a master storage node, and the other copies are called slave copies or slave storage nodes. When garbage collection is performed in the distributed storage system, the garbage collection is required to be performed independently on each storage node, so that the memory space of the storage nodes is saved.
However, when the respective storage nodes independently perform garbage collection, there is a possibility that the time for performing garbage collection by the respective storage nodes may be inconsistent, and thus there is a problem that data stored in the respective storage nodes are inconsistent after garbage collection.
Disclosure of Invention
In the prior art, garbage collection needs to be independently performed on each storage node, and the time for performing garbage collection on each storage node may be inconsistent, so that the problem of inconsistency of data stored on each storage node is caused after garbage collection. For this reason, an improved data processing scheme is highly desirable.
In this context, embodiments of the present invention are intended to provide a data processing method, apparatus, medium, and computing device.
In a first aspect of embodiments of the present invention, there is provided a data processing method, including:
if the current data block of the main storage node meets a first data processing condition, extracting the determined effective data file of the current data block; rewriting the extracted effective data file into the last data block of the main storage node and at least one auxiliary storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; and deleting the current data block from the main storage node and the at least one auxiliary storage node by utilizing the preset data consistency protocol.
In a second aspect of embodiments of the present invention, there is provided a data processing apparatus comprising:
the extraction module is used for extracting the determined effective data file of the current data block if the current data block of the main storage node meets a first data processing condition;
the rewriting module is used for rewriting the extracted effective data file into the last data block of the main storage node and the at least one auxiliary storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time;
and the deleting module is used for deleting the current data block from the main storage node and the at least one auxiliary storage node by utilizing the preset data consistency protocol.
In a third aspect of embodiments of the present invention, there is provided a data processing system comprising a master storage node and at least one slave storage node, wherein:
the main storage node is used for extracting the determined effective data file of the current data block if the current data block of the main storage node meets a first data processing condition; rewriting the extracted valid data file into the last data block of the main storage node and instructing the at least one slave storage node to rewrite the extracted valid data file into the last data block of the corresponding slave storage node by using a preset data consistency protocol; deleting the current data block from the master storage node and instructing the at least one slave storage node to delete the current data block from the corresponding slave storage node using the preset data consistency protocol; the last data block is a data block with the generation time closest to the current time;
and the slave storage node is used for rewriting the extracted valid data file into the last data block of the slave storage node according to the indication of the master storage node and deleting the current data block from the slave storage node.
In a fourth aspect of embodiments of the present invention, there is provided a computer readable medium having stored thereon a computer program, the program being executed by a processor to perform the steps of implementing the data processing method described above.
In a fifth aspect of embodiments of the present invention, there is provided a computing device comprising a memory, a processor and a computer program stored on the memory and executable on the processor, the processor implementing the steps of the data processing method when executing the program.
By utilizing the data processing method, the device, the medium and the computing equipment provided by the embodiment of the invention, when the current data block of the main storage node meets the first data processing condition, the effective data file of the current data block is extracted, and the extracted valid data file is rewritten into the master storage node and each slave storage node by using a data consistency protocol, and then, the current data block is deleted from the master storage node and each of the slave storage nodes using a data coherency protocol, by scanning whether the data block in the master storage node meets a first data processing condition, under the condition of meeting the first data processing condition, the effective data file is written into each storage node by using the data consistency protocol and the corresponding data block is deleted, so that each storage node can be prevented from independently performing garbage collection, and the consistency of the data stored in the data blocks of each storage node is ensured on the basis of recovering the garbage in the storage nodes.
Drawings
The above and other objects, features and advantages of exemplary embodiments of the present invention will become readily apparent from the following detailed description read in conjunction with the accompanying drawings. Several embodiments of the invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which:
FIG. 1 schematically illustrates an application scenario according to an embodiment of the present invention;
FIG. 2 schematically shows a flow diagram of a data processing method according to an embodiment of the invention;
FIG. 3 schematically illustrates an example schematic diagram of a data coherency protocol according to an embodiment of the present invention;
FIG. 4 is a schematic flow chart illustrating a method for determining that a current data block satisfies a first data processing condition according to an embodiment of the present invention;
FIG. 5 is a schematic flow chart illustrating a method of rewriting a valid data file according to an embodiment of the present invention;
FIG. 6 is a schematic flow chart illustrating a method for determining a valid data file of a current data block according to an embodiment of the present invention;
FIG. 7 is a flow chart diagram schematically illustrating a specific implementation process of a data processing method according to an embodiment of the present invention;
FIG. 8 is a schematic diagram illustrating a data block structure according to an embodiment of the present invention;
FIG. 9 schematically shows a block diagram of a data processing apparatus according to an embodiment of the present invention;
fig. 10 schematically shows a hardware configuration diagram of a computer apparatus for implementing a data processing method according to an embodiment of the present invention;
fig. 11 schematically shows a program product for implementing the data processing method according to an embodiment of the present invention.
In the drawings, the same or corresponding reference numerals indicate the same or corresponding parts.
Detailed Description
The principles and spirit of the present invention will be described with reference to a number of exemplary embodiments. It is understood that these embodiments are given solely for the purpose of enabling those skilled in the art to better understand and to practice the invention, and are not intended to limit the scope of the invention in any way. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the disclosure to those skilled in the art.
As will be appreciated by one skilled in the art, embodiments of the present invention may be embodied as a system, apparatus, device, method, or computer program product. Accordingly, the present disclosure may be embodied in the form of: entirely hardware, entirely software (including firmware, resident software, micro-code, etc.), or a combination of hardware and software.
According to the embodiment of the invention, a data processing method, a data processing device, a data processing system, a data processing medium and a computing device are provided.
In this document, it is to be understood that any number of elements in the figures are provided by way of illustration and not limitation, and any nomenclature is used for differentiation only and not in any limiting sense.
The principles and spirit of the present invention are explained in detail below with reference to several representative embodiments of the invention.
Summary of The Invention
The inventor finds that in the prior art, when each storage node independently performs garbage collection, the time for performing garbage collection by each storage node may be inconsistent, so that the problem of inconsistency of data stored in each storage node is caused after garbage collection.
To this end, the present invention provides a data processing method, apparatus, system, medium and computing device, wherein the data processing method may include: if the current data block of the main storage node meets a first data processing condition, extracting the determined effective data file of the current data block; rewriting the extracted effective data file into the last data block of the main storage node and at least one auxiliary storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; and deleting the current data block from the main storage node and the at least one auxiliary storage node by utilizing the preset data consistency protocol.
In the data processing method provided by the invention, when the current data block of the main storage node meets the first data processing condition, the effective data file of the current data block is extracted, and the extracted valid data file is rewritten into the master storage node and each slave storage node by using a data consistency protocol, and then, the current data block is deleted from the master storage node and each of the slave storage nodes using a data coherency protocol, by scanning whether the data block in the master storage node meets a first data processing condition, under the condition of meeting the first data processing condition, the effective data file is written into each storage node by using the data consistency protocol and the corresponding data block is deleted, so that each storage node can be prevented from independently performing garbage collection, and the consistency of the data stored in the data blocks of each storage node is ensured on the basis of recovering the garbage in the storage nodes.
Having described the general principles of the invention, various non-limiting embodiments of the invention are described in detail below.
Application scene overview
Referring to fig. 1, as shown in fig. 1, an application scenario schematic diagram of a data processing scheme provided by an embodiment of the present invention includes a master storage node 101 and at least one slave storage node 102, where if it is determined that a current data block of the master storage node 101 meets a first data processing condition, an effective data file of the determined current data block is extracted; rewriting the extracted effective data file into the last data block of the main storage node 101 and the at least one slave storage node 102 by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; the current data block is deleted from the master storage node 101 and at least one of the slave storage nodes 102 using a preset data consistency protocol. The master storage node 101 and the slave storage node 102 can communicate through a communication network such as a local area network and a wide area network; the master storage node 101 and the slave storage node 102 may be portable devices (e.g., mobile phones, tablets, laptops, etc.) or Personal Computers (PCs).
Exemplary method
A data processing method according to an exemplary embodiment of the present invention is described below with reference to fig. 2 to 8 in conjunction with the application scenario of fig. 1. It should be noted that the above application scenarios are merely illustrated for the convenience of understanding the spirit and principles of the present invention, and the embodiments of the present invention are not limited in this respect. Rather, embodiments of the present invention may be applied to any scenario where applicable.
Fig. 2 is a flowchart illustrating a data processing method according to an embodiment of the present invention, where an execution subject may be a main storage node 101 in an application scenario overview or may be other computing devices, as shown in fig. 2, the data processing method according to the embodiment of the present invention includes the following steps:
step 201, if the current data block of the main storage node meets the first data processing condition, extracting the determined valid data file in the current data block.
In specific implementation, a data block in a current scanning order is determined to serve as a current data block, whether the current data block meets a first data processing condition is judged, and if the current data block meets the first data processing condition, an effective data file in the determined current data block is extracted. The scanning sequence is specifically the sequence of the data block generation time, and the data blocks in the main storage node can be scanned one by one from the data block with the earliest generation time.
And if the data volume of the effective data file in the current data block is less than the specific value, determining that the current data block meets the first processing condition. Other ways to determine that the current data block satisfies the first data processing condition may also be used, and are not limited herein. The embodiment of the invention takes the logically deleted data file as an invalid data file.
Optionally, the valid data file includes a data file that is not logically deleted, and/or a logical deletion command file, excluding a data file that is logically deleted and a data file that is physically deleted. Under the condition that the logically deleted data file is determined to be physically deleted, the logical deletion command file corresponding to the logically deleted data file is an invalid data file; and under the condition that the logically deleted data file is not physically deleted, determining that the logical deletion command file corresponding to the logically deleted data file is a valid data file. The data file which is logically deleted is the data file which is indicated by the logical deletion command file to be logically deleted.
It should be noted that the physical deletion refers to that a storage area used for storing a file is actually erased or cleared, and a physically deleted data file is generally unrecoverable. Logical deletion refers to marking a data file as a data file which cannot be identified by an operating system by some means, wherein the logically deleted data file actually exists in a corresponding storage medium, and the logically deleted data file can be recovered by using a proper tool or software.
It is emphasized that the data blocks in the master storage node and the data files stored in the data blocks are backed up at each of the slave storage nodes. In the main storage node and each of the slave storage nodes, only the last data block can be written with data, and other data blocks are in a read-only state and can not be written with data, wherein the last data block is one of the data blocks in the main storage node or the slave storage nodes, and the data block with the time closest to the current time is generated.
Step 202, rewriting the extracted valid data file into the last data block of the master storage node and the at least one slave storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time.
During specific implementation, according to the sequence of the valid data files stored in the current data block, the extracted valid data files are rewritten into the last data block of the main storage node, and the extracted valid data files are rewritten into the last data block of at least one slave storage node. The last data block is specifically the data block whose generation time is closest to the current time.
The data consistency of the valid data files rewritten into the last data block of the master storage node and each slave storage node can be ensured by using a preset data consistency protocol, for example, the byte consistency of the data of the valid data files rewritten into the master storage node and the slave storage node can be ensured.
The preset data consistency protocol can be a pacificA protocol, and the pacificA protocol is a variant of a data replication protocol which is a Paxos algorithm, and can realize strong consistency of data between a master storage node and a slave storage node. The data block provided by the embodiment of the invention can be used for storing the log file and the data file of the pacificA protocol.
In the case that the predetermined data consistency protocol is pacificA protocol, the data block is composed of a Header (Header) and a Record (Record), where Record can be understood as a data file, and the format of the data block is as shown in fig. 3, and includes a Header and a plurality of records, where a Record includes a sn field, a commit _ pt field, a cmd _ type field, a fid field, a data _ len field, and a data field, and of course, the Record includes not all the fields included in the Record, and only the fields are illustrated here. Wherein, the sn field is the log number of the pacificA protocol, and is increased from 1, and the sn field can be 64-bit integer data; the commit _ pt field is a commit point of the pacificA protocol, records with log numbers smaller than the commit point are submitted, and the commit _ pt field can be 64-bit integer data; the cmd _ type field is a pacificA protocol command type field, and different types of commands need to execute corresponding callback functions; a fid field is used for recording the identification of the record, and a data _ len field is the data length in the record, and can be 32-bit integer data; the data field is a data carrying field of record.
The pacificA protocol command types may include a write data file command type, a delete data block command type, an overwrite data file command type, and a delete logical delete command file command type.
The principle of realizing data consistency by using the pacificA protocol is as follows: after receiving a request for rewriting valid data, the main storage node encapsulates the request into a record; the master storage node adds 1 to the local prefix _ point, appends the record to the last data block and sends the record to each slave storage node; after receiving the record from the storage node, adding 1 to the local prefix _ point, and adding the received record to the last data block; the slave storage node returns the current prefix _ point to the master storage node; after receiving all the prefix _ points returned by the slave storage nodes, the master storage node increases commit _ point (commit _ point is the smallest prefix _ point of the three copies, namely, all three copies are written successfully), and calls a corresponding callback function according to cmd _ type of Record to return success to the client. And then the master storage node transmits the commit _ point to the slave storage node in the heartbeat or subsequent data writing of the slave storage node, and the slave storage node submits the local data to update the commit _ point after receiving the submission message and calls a corresponding callback function.
In the process of realizing data consistency by the pacificA protocol, the master storage node and the slave storage node meet the following conditions: the commit _ point of each slave storage node is smaller than or equal to the commit _ point of the master storage node, the commit _ point of the master storage node is smaller than or equal to the minimum prefix _ point in the prefix _ points of the slave storage nodes, and when the master storage node and the slave storage node meet the condition, the consistency of data stored in other storage nodes can be ensured under the condition that any storage node is down to lose data.
As shown in fig. 3, it is assumed that two slave storage nodes are included, the commit _ point of the master storage node is 7, the prepare _ point is 9, the commit _ point of the slave storage node 1 is 4, the prepare _ point is 8, the commit _ point of the slave storage node 2 is 5, and the prepare _ point is 7, on the basis of this assumption, if the slave storage node 1 crashes and data is lost, since the commit _ point of the master storage node is equal to the prepare _ point of the slave storage node 2; therefore, the slave storage node 2 includes all submitted data files of the master storage node; if the master storage node goes down and data is lost, and the commit _ point on the master storage node is 7 at this time, the commit _ point of the slave storage node 1 and the slave storage node 2 are 8 and 7, respectively, and since the commit _ point of the master storage node is less than or equal to the commit _ point of the slave storage node, all the submitted data files of the master storage node are included in the slave storage nodes 1 and 2.
In practical application, when the execution main body is a computer device except the master storage node and the slave storage node, the computer device can send an indication of rewriting the extracted valid data file to the master storage node and all the slave storage nodes; when the execution subject is the master storage node, the master storage node sends an indication to all slave storage nodes to rewrite the extracted valid data file.
Step 203, deleting the current data block from the master storage node and the at least one slave storage node by using the preset data consistency protocol.
In specific implementation, because the data blocks stored in the master storage node have backup in each slave storage node block, the slave storage nodes also have current data blocks in the master storage node, and at this time, after the valid data file is rewritten into the master storage node and the slave storage node, the current data blocks in the master storage node and the slave storage node are physically deleted, that is, the current data blocks are completely deleted from the master storage node and the slave storage node. Therefore, the problem that repeated data are stored in the storage node after the extracted effective data are rewritten can be solved, the storage space of the storage node is saved, and the purpose of garbage collection in the storage node is achieved.
In the data processing method provided by the invention, when the current data block of the main storage node meets the first data processing condition, the effective data file of the current data block is extracted, and the extracted valid data file is rewritten into the master storage node and each slave storage node by using a data consistency protocol, and then, the current data block is deleted from the master storage node and each of the slave storage nodes using a data coherency protocol, by scanning whether the data block in the master storage node meets a first data processing condition, under the condition of meeting the first data processing condition, the effective data file is written into each storage node by using the data consistency protocol and the corresponding data block is deleted, so that each storage node can be prevented from independently performing garbage collection, and the consistency of the data stored in the data blocks of each storage node is ensured on the basis of recovering the garbage in the storage nodes.
Alternatively, according to the content provided in fig. 4, it is determined that the current data block satisfies the first data processing condition:
step 401, determining a valid data file of the current data block.
Step 402, determining whether the effective data file percentage of the current data block is less than a set threshold.
In concrete implementation, step 403 is executed when the valid data file occupancy of the current data block is less than the set threshold, and step 404 is executed when the valid data file occupancy of the current data block is not less than the set threshold.
In step 403, it is determined that the current data block satisfies the first data processing condition.
Step 404, determining that the current data block does not satisfy the first data processing condition.
In specific implementation, when it is determined that the current data block does not satisfy the first data processing condition, a next data block adjacent to the scanning order of the current data block is taken as the current data block, and the process goes to step 401.
The effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block, that is, the ratio of the data volume of the effective data files in the data block to the maximum storage capacity which can be carried by the data block. The size of the set threshold can be set according to practical application scenarios, and is not limited herein, for example, the set threshold is 0.6 or 0.8.
In this optional embodiment, when the ratio of valid data files in the current data block is smaller than a certain threshold, the valid data files in the current data block are extracted for rewriting, and the current data block is deleted from the master storage node and the slave storage node after the rewriting is completed, so that the storage space of the master storage node and the slave storage node can be saved.
Optionally, according to the content provided in fig. 5, the method for rewriting the extracted valid data file into the last data block of the master storage node and the at least one slave storage node by using a preset data consistency protocol is implemented:
step 501, adding the extracted valid data file to the last data block of the main storage node.
In a specific implementation, when the data is already stored in the last data block of the main storage node, the extracted valid data file is additionally written into the last data block of the main storage node from a position adjacent to the already stored data. And in the case that the last data block of the main storage node does not store data, additionally writing the extracted valid data file into the last data block of the main storage node from the starting position of the data block.
Step 502, sending a first instruction for rewriting the valid data file to the at least one slave storage node, where the first instruction carries index information of the valid data file, and the index information is used by the at least one slave storage node to extract the valid data file according to the index information and append the valid data file to a last data block of the at least one slave storage node.
In specific implementation, after the extracted valid data file is additionally written into the last data block of the main storage node, an instruction for rewriting the extracted valid data file is sent to each slave storage node. For each slave storage node, the slave storage node may locally find, according to the index information carried in the first instruction, the valid data file pointed by the index information at the slave storage node, and append the found valid data file to the last data block of the slave storage node.
Accordingly, when data is already stored in the last data block of the slave storage node, the valid data file is additionally written in the last data block of the slave storage node from a position adjacent to the already stored data. When the last data block of the slave storage node does not store data, the valid data file is additionally written into the last data block of the slave storage node from the start position of the data block.
Step 503, if all the first responses sent by the secondary storage nodes are received, modifying the index information of the valid data file in the primary storage node into the index information corresponding to the additional position.
In the step, whether the first response sent by all the slave storage nodes is received or not is judged, if yes, the index information of the extracted effective data in the master storage node is modified into the index information corresponding to the additional position, namely, the index information corresponding to the effective data file is modified into the index information corresponding to the effective data after the effective data is added to the last data block of the master storage node. For example, if the index information of the extracted valid data file in the current data block is a, the step modifies the index information of the extracted valid data file into the index information B corresponding to the last data block of the main storage node. And after the index information is modified, rewriting the extracted effective data file into the main storage node.
The index information includes an identifier fid of the valid data file, an identifier blockid of a data block where the valid data file is located, a position off of the valid data file in the data block, and a length len occupied by the data block of the valid data file, where for example, if fid is 1, blockid is 2, off is 140 bytes, and len is 1440 bytes, then starting from the 140 th byte in the data block2, the valid data file corresponding to 1440 bytes in length is valid data file 1.
In specific implementation, the index information may be stored in an index database, a main key (key) of the index database is fid, and a corresponding value (value) may be found according to the main key, where the value is equal to (blockid, off, len).
Step 504, sending a second response to the at least one slave storage node, where the second response is used to identify that the operation of rewriting the valid data file into the master storage node is completed, so that the at least one slave storage node modifies the index information of the valid data file in the at least one slave storage node into the index information corresponding to the appended position according to the second response.
In particular implementations, a second response is sent to each of the slave storage nodes to notify each of the slave storage nodes that the master storage node has overwritten the fetched valid data file. And the slave storage node modifies the index information of the effective data file in the slave storage node into the index information corresponding to the last data block added to the slave storage node according to the received second response. The manner of modifying the index information by the slave storage node is similar to the manner of modifying the index information by the master storage node, and is not described herein again, and for the explanation of the index information, reference may be made to the above, and no further description is given here.
And after determining that the index information is modified from the storage node, determining that the operation of rewriting the valid data file from the storage node is completed.
In this optional embodiment, when the extracted valid data file is rewritten into the last data block of the slave storage node, only the index information of the valid data file to be rewritten needs to be sent to the slave storage node, and the data content of the rewritten valid data file does not need to be sent, so that the network traffic can be saved.
In some cases, it is necessary to perform logical deletion on data files in the data block, and at this time, the data block further includes a logical deletion command file, where the logical deletion command file is used to instruct to perform logical deletion on a certain data file. For example, the logical deletion command file 2X is used to instruct to logically delete the data file 2, where the logical deletion command file 2X is stored in a data block of the storage node, that is, the data file 2 and the logical deletion command file 2X of the data file 2 are both stored in a data block of the storage node.
In a possible implementation, the valid data file of the current data block may be determined in advance, specifically, the valid data file of the current data block may be determined before step 101, and optionally, the valid data file of the current data block is determined according to the content provided in fig. 6:
step 601, for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with an overwrite mark.
In specific implementation, file identifiers of the data files may be stored in the index database, where the data files correspond to the file identifiers one to one, and the index database includes file identifiers of data files that are indicated by the logical deletion command file to be logically deleted and/or file identifiers of data files that are not logically deleted. The index information of the first type data file can be searched from an index database according to the file identification of the first type data file, if the searched index information is not empty, the first type data file is determined to be an effective data file of the current data block, otherwise, the first type data file is determined to be an invalid data file. It should be noted that, if the block identifier, the position off, and the length len of the data block in the index information are all non-empty, it is determined that the index information is non-empty.
Wherein the first type of data file comprises a data file with a write-in mark (PutCmd) and a data file with a rewrite-in mark (GcPutCmd); the data file with the write mark is specifically a data file for executing a command corresponding to the command type of the write data file, and the data file with the rewrite mark is a data file for executing a command corresponding to the command type of the rewrite data file.
It should be noted that the data file which is not logically deleted in the embodiment of the present invention is defaulted to a data file which is not logically deleted and is not physically deleted.
Step 602, storing the file identifier of the first type data file in each data block of the main storage node to an identifier set.
In specific implementation, under the condition that the second data processing condition is met, scanning each data block of the main storage node, and storing the file identifier of the first type of data file in the scanned data block to an identifier set.
Optionally, the second data processing condition is determined to be satisfied in the following manner: and judging whether the preset scanning period is reached, if so, determining that a second data processing condition is met, and otherwise, continuously judging whether the preset scanning period is reached. The size of the preset scanning period is set according to an actual application scenario, and is not limited herein. Other ways to determine that the second data processing condition is satisfied may also be used, and are not limited herein, such as: and when a data writing instruction from the client is monitored, determining that a second data processing condition is met.
It should be noted that the execution sequence of step 601 and step 602 is not limited, and step 601 may be executed after step 602 is executed first, or step 601 and step 602 are executed simultaneously.
Step 603, for each logical deletion command file in the current data block, querying a file identifier of the data file indicated by the logical deletion command file for logical deletion from the identifier set.
Step 604, if yes, determining that the logical deletion command file is a valid data file of the current data block.
In specific implementation, when the file identifier of the data file subjected to logical deletion is indicated by the logical deletion command file of the current data block, which is queried from the identifier set, the logical deletion command file is determined to be the valid data file of the current data block. And if the logic deletion command file of the current data block is not inquired from the identification set and indicates the file identification of the data file for logic deletion, determining that the logic deletion command file is an invalid data file.
In specific implementation, the determined valid data file of the current data block may be extracted as follows: recording the file identification of the valid data file determined based on the embodiment provided in fig. 6; searching index information corresponding to each recorded file identifier from an index database; and extracting the corresponding effective data file according to the searched index information.
The following describes the data processing method provided in the embodiment of the present invention in detail with reference to a specific implementation process, as shown in fig. 7, including:
step 701, a main storage node stores file identifications of first type data files of each data block of the main storage node into an identification set, wherein the data files of the data blocks comprise a logic deletion command file.
Wherein the first type of data file comprises a data file with a write mark and a data file with an overwrite mark. The primary storage node may determine a file identification of the first type of data file therein by scanning the respective data blocks. The data blocks of the main storage node are not included in the data blocks which are physically deleted from the main storage node. The logical delete command file is a data file with a GcDelCmd flag.
In step 702, the master storage node determines that the data block in the current scanning order is the current data block, where the current data block is a data block that is adjacent to and later than the most recently scanned data block in the scanning order.
In specific implementation, the main storage node scans each data block of the main storage node one by one, and determines that the data block in the current scanning order is the current data block, and the current data block is a data block which is located after the latest scanned data block and is adjacent to the latest scanned data block in the scanning order, and serves as the current data block, wherein the latest scanned data block is a data block whose scanning time is closest to the current time. Optionally, the main storage node scans the data blocks of the main storage node one by one according to the sequence of the data block generation time.
Step 703, for each first-type data file of the current data block, if the index information of the first-type data file is non-empty, determining that the first-type data file is an effective data file of the current data block.
Step 704, for each logical deletion command file in the current data block, querying a file identifier of the data file indicated by the logical deletion command file for logical deletion from the identifier set.
The data file subjected to logic deletion is a data file with a DelCmd mark.
The execution sequence of step 703 and step 704 is not limited, step 703 may be executed first and then step 704 is executed, or both may be executed simultaneously.
Step 705, if yes, determining that the logical deletion command file is a valid data file of the current data block.
Specifically, if the data block is not queried, it is determined that the logical deletion command file is an invalid data file of the current data block.
In step 706, the primary storage node determines whether the determined effective data file percentage of the current data block is smaller than a set threshold, if so, step 707 is executed, otherwise, step 714 is executed.
And the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the previous data block to the storage capacity corresponding to the current data block.
In step 707, the primary storage node fetches the valid data file in the current data block.
In specific implementation, step 707 is executed as follows:
the first method is as follows: the main storage node records step 703 and step 705 to determine the file identifier of each valid data file of the current data block; searching index information corresponding to each recorded file identifier from an index database; and extracting the corresponding effective data file according to the searched index information.
The second method comprises the following steps: the main storage node scans the current data block, and if the data file is the valid data file determined according to the step 703, the valid data file is extracted; if the data file is a valid data file as determined in step 705, the logical delete command file is extracted. In the specific implementation process of the second mode: scanning a current data block; for each first type data file of the current data block, if the index information of the first type data file is not null, extracting the first type data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark; storing file identifications of first-class data files in each data block of a main storage node into an identification set; for each logic deletion command file in the current data block, inquiring the file identifier of the data file indicated by the logic deletion command file for logic deletion from the identifier set; if yes, extracting the logic deletion command file.
Step 708, the master storage node appends the extracted valid data file to the last data block of the master storage node, and sends a first instruction for rewriting the valid data file to at least one slave storage node, where the first instruction carries index information of the valid data file.
Step 709, receiving the first instruction from the storage node, extracting the corresponding valid data file according to the index information in the first instruction, and adding the extracted valid data file to the last data block of the storage node.
Wherein the valid data file extracted from the storage node is the same as the valid data file extracted from the current data block by the main storage node.
Step 710, a first response is sent from the storage node.
In step 711, if the primary storage node receives all the first responses sent by the secondary storage nodes, the index information of the extracted valid data file in the primary storage node is modified into the index information corresponding to the additional position, and the current data block is physically deleted.
The data block can be physically deleted using a DelBlkCmd command, where a data field in the command is a data block identification (blockid) to be deleted.
In step 712, the master storage node sends a second response to the at least one slave storage node, the second response identifying that the operation of rewriting the extracted valid data file into the master storage node is complete.
Step 713, receiving a second response from the storage node, modifying the index information of the extracted valid data file in the slave storage node into the index information corresponding to the additional position according to the second response, and physically deleting the data block of the current data block corresponding to the storage node.
In step 714, the next data block is used as the current data block, and step 701 is executed.
The following illustrates a data processing method according to an embodiment of the present invention.
Suppose that the data blocks of the main storage node include block1, block2, and block3, the set of identifiers of the data files stored in block1 is [ 123456782X ], the set of identifiers of the data files stored in block2 is [ 9101112136X 14151X 3X ], the set of identifiers of the data files stored in block3 is [ 1617 ], where 1X is an identifier of a logical deletion command file corresponding to the data file 1, 2X is an identifier of a logical deletion command file corresponding to the data file 2, 3X is an identifier of a logical deletion command file corresponding to the data file 3, and 6X is an identifier of a logical deletion command file corresponding to the data file 6.
The main storage node scans block1, block2 and block3, and saves file identifications [ 1234567891011121314151617 ] of first type data files in block1, block2 and block3 to an identification set.
The master storage node scans block1, determining each data file in block1 as [ 123456782X ].
The main storage node determines that the corresponding index information in the first type data file [ 12345678 ] in block1 is a non-empty file identifier [ 4578 ], and determines that the data file corresponding to [ 4578 ] is a valid data file of block 1.
And if the main storage node can inquire the data file 2 which is indicated by 2X to be logically deleted from the obtained identification set, determining that 2X is a valid data file of block 1.
If the determined effective data file occupation ratio of the Block1 is smaller than a set threshold value, [ 45782X ] in the Block1 is extracted, the extracted [ 45782X ] is rewritten into the Block3 by using a preset data consistency protocol, the Block1 is deleted from the main storage node by using the preset data consistency protocol, and a data Block2 and a Block3 of the main storage node are obtained, at this time, the identification set of the data files stored by the Block2 is [ 9101112136X 14151X 3X ], and the identification set of the data files stored by the Block3 is [ 161745782X ].
Taking block2 as a current data block, scanning block2 and block3, and storing file identifications [ 910111213141516174578 ] of first-class data files in block2 and block3 into an identification set, wherein at the moment, 1X, 3X and 6X in block2 indicate that the data files subjected to logical deletion are physically deleted, so that the determined identification set is [ 910111213141516174578 ], and the data files [ 136 ] subjected to physical deletion are not included.
The master storage node scans block2, determining that each data file in block2 is [ 9101112136X 14151X 3X ].
And the main storage node determines that the index information of the first type data file [ 9101112131415 ] in the block2 corresponding to the index database is non-empty, and determines that the data file [ 9101112131415 ] corresponding to the block2 is a valid data file.
And for the logical deletion command files 1X, 3X and 6X of the block2, the main storage node does not inquire data files 1, 3 and 6 which are indicated by 1X, 3X and 6X to be logically deleted from the obtained identification set, and then determines that 1X, 3X and 6X are invalid data files of the block 2.
If the determined effective data file occupation ratio of the block2 is smaller than the set threshold value, [ 9101112131415 ] in the block2 is extracted, the extracted [ 9101112131415 ] is rewritten into the block3 by using a preset data consistency protocol, and the block2 is deleted from the main storage node by using the preset data consistency protocol to obtain a data block3 of the main storage node.
If the remaining storage capacity of block3 is not sufficient to hold [ 9101112131415 ], a new data block4 is generated and the data files in [ 9101112131415 ] that fail to be written to block3 are written to block 4.
The same data processing procedure is performed on block3 and block4 in the same manner, and details are not described here.
Optionally, the data processing method provided in the embodiment of the present invention further includes:
if the remaining storage capacity of the last data block of the main storage node is smaller than the data amount corresponding to the effective data file, generating a new data block; rewriting the remaining valid data files into the new data block; and the remaining valid data files are valid data files which are not rewritten into the last data block of the main storage node.
In a specific implementation, the remaining space of the last data block of the main storage node may not be enough to accommodate all the extracted valid data files, and at this time, a new data block is generated in the main storage node, and the remaining valid data files that the last data block is not enough to accommodate are written into the new data block. This avoids loss of valid data files.
In the above embodiments, the sizes of the data blocks in the master storage node are the same, the sizes of the data blocks in the slave storage nodes are the same, and the sizes of the data blocks in the master storage node and the slave storage nodes are the same, for example, the size of each data block is 1 GB. As shown in fig. 8, the data block is composed of a header (board) and a data file (record), and the primary key (key) of each record is the fid mentioned above.
Accordingly, the remaining space of the last data block of the slave storage node may not be sufficient to accommodate all of the extracted valid data files, and at this time, a new data block is generated in the slave storage node, and the remaining valid data files that the last data block is not sufficient to accommodate are written into the new data block.
Based on the same inventive concept as the data processing method provided in the above embodiment, an embodiment of the present invention further provides a data processing system, including a master storage node and at least one slave storage node, wherein:
the main storage node is used for extracting the determined effective data file of the current data block if the current data block of the main storage node meets a first data processing condition; rewriting the extracted valid data file into the last data block of the main storage node and instructing the at least one slave storage node to rewrite the extracted valid data file into the last data block of the corresponding slave storage node by using a preset data consistency protocol; deleting the current data block from the master storage node and instructing the at least one slave storage node to delete the current data block from the corresponding slave storage node using the preset data consistency protocol; the last data block is a data block with the generation time closest to the current time;
and the slave storage node is used for rewriting the extracted valid data file into the last data block of the slave storage node according to the indication of the master storage node and deleting the current data block from the slave storage node.
Optionally, the master storage node is specifically configured to:
adding the extracted effective data file to the last data block of the main storage node, and sending a first instruction for rewriting the effective data file to the at least one auxiliary storage node, wherein the first instruction carries index information of the effective data file; if first responses sent by all the slave storage nodes are received, modifying the index information of the effective data file in the master storage node into the index information corresponding to the additional position; sending a second response to the at least one slave storage node, the second response identifying completion of the operation of rewriting the valid data file into the master storage node;
the slave storage node is specifically configured to: receiving a first instruction sent by the main storage node; extracting the effective data file according to the index information of the effective data file carried in the first instruction, and adding the extracted effective data file to the last data block of the slave storage node; receiving a second response sent by the main storage node; and according to the second response, modifying the index information of the effective data file in the slave storage node into the index information corresponding to the additional position.
Optionally, the main storage node is specifically configured to determine that the current data block meets the first data processing condition in the following manner:
determining a valid data file of the current data block;
judging whether the effective data file proportion of the current data block is smaller than a set threshold value or not;
if so, determining that the current data block meets a first data processing condition;
the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block.
Optionally, the main storage node is specifically configured to determine the valid data file of the current data block by:
for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, determining that the logic deletion command file is a valid data file of the current data block.
Optionally, the master storage node is further configured to:
if the remaining storage capacity of the last data block of the main storage node is smaller than the data amount corresponding to the effective data file, generating a new data block;
rewriting the remaining valid data files into the new data block;
and the remaining valid data files are valid data files of the last data block which is not rewritten into the main storage node.
Optionally, the primary storage node is specifically configured to extract the determined valid data file of the current data block in the following manner:
scanning the current data block;
for each first-class data file of the current data block, if the index information of the first-class data file is not null, extracting the first-class data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, extracting the logic deletion command file.
Exemplary device
Having described the data processing method and system according to the exemplary embodiment of the present invention, a data processing apparatus according to an exemplary embodiment of the present invention will be described next with reference to fig. 9.
Fig. 9 is a schematic structural diagram of a data processing apparatus according to an embodiment of the present invention, as shown in fig. 9, the data processing apparatus may include the following modules:
an extracting module 901, configured to extract a determined valid data file of a current data block of a main storage node if the current data block meets a first data processing condition;
a rewriting module 902, configured to rewrite, by using a preset data consistency protocol, the extracted valid data file into a last data block of the master storage node and the at least one slave storage node, where the last data block is a data block whose generation time is closest to a current time;
a deleting module 903, configured to delete the current data block from the master storage node and the at least one slave storage node by using the preset data consistency protocol.
Optionally, the data processing apparatus provided in the embodiment of the present invention further includes:
the first determining module 904 is specifically configured to determine that the current data block meets the first data processing condition in the following manner:
determining a valid data file of the current data block;
judging whether the effective data file proportion of the current data block is smaller than a set threshold value or not;
if so, determining that the current data block meets a first data processing condition;
the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block.
Optionally, the rewrite module 902 is specifically configured to:
adding the extracted effective data file to the last data block of the main storage node, and sending a first instruction for rewriting the effective data file to the at least one slave storage node, wherein the first instruction carries index information of the effective data file, and the index information is used for the at least one slave storage node to extract the effective data file according to the index information and add the effective data file to the last data block of the at least one slave storage node;
if first responses sent by all the slave storage nodes are received, modifying the index information of the effective data file in the master storage node into the index information corresponding to the additional position;
and sending a second response to the at least one slave storage node, wherein the second response is used for identifying that the operation of rewriting the valid data file into the master storage node is completed, so that the at least one slave storage node modifies the index information of the valid data file in the at least one slave storage node into the index information corresponding to the additional position according to the second response.
Optionally, the data processing apparatus provided in the embodiment of the present invention further includes:
a second determining module 905, configured to determine a valid data file of the current data block as follows:
for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, determining that the logic deletion command file is a valid data file of the current data block.
Optionally, the data processing apparatus provided in the embodiment of the present invention further includes:
a generating module 906, configured to generate a new data block if the remaining storage capacity of the last data block of the main storage node is smaller than the data size corresponding to the valid data file;
the rewrite module 902 is further configured to rewrite the remaining valid data files into the new data block; and the remaining valid data files are valid data files of the last data block which is not rewritten into the main storage node.
Optionally, the extracting module 901 is specifically configured to:
scanning the current data block;
for each first-class data file of the current data block, if the index information of the first-class data file is not null, extracting the first-class data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, extracting the logic deletion command file.
Exemplary device
Having described the data processing method, apparatus and system according to exemplary embodiments of the present invention, a computing device for data processing according to exemplary embodiments of the present invention is described next.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or program product. Thus, various aspects of the invention may be embodied in the form of: an entirely hardware embodiment, an entirely software embodiment (including firmware, microcode, etc.) or an embodiment combining hardware and software aspects that may all generally be referred to herein as a "circuit," module "or" system.
In some possible embodiments, a computing device for data processing according to the present invention may comprise at least a memory, a processor and a computer program stored on the memory and executable on the processor, the processor implementing the steps in the data processing method according to various exemplary embodiments of the present invention described in the above section "exemplary method" of the present specification when executing the program. For example, when the processor executes the program, as shown in fig. 2, step 201 is implemented, if a current data block of a primary storage node satisfies a first data processing condition, extracting a determined valid data file of the current data block; step 202, rewriting the extracted valid data file into the last data block of the main storage node and at least one slave storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; step 203, deleting the current data block from the master storage node and the at least one slave storage node by using the preset data consistency protocol.
A computing device 100 according to this embodiment of the invention is described below with reference to fig. 10. The computing device 100 shown in FIG. 10 is only one example and should not be taken to limit the scope of use and functionality of embodiments of the present invention.
As shown in fig. 10, computing device 100 is embodied in the form of a general purpose computing device. Components of computing device 100 may include, but are not limited to: the processor 1001, the memory 1002, and the bus 1003 connecting the different system components (including the processor 1001 and the memory 1002).
The bus 1003 includes an address bus, a control bus, and a data bus.
The memory 1002 can include volatile memory, such as Random Access Memory (RAM)10021 and/or cache memory 10022, and can further include Read Only Memory (ROM) 10023.
Memory 1002 may also include a program/utility 10025 having a set (at least one) of program modules 10024, such program modules 10024 including, but not limited to: an operating system, one or more application programs, other program modules, and program data, each of which, or some combination thereof, may comprise an implementation of a network environment.
Computing device 100 may also communicate with one or more external devices 1004 (e.g., keyboard, pointing device, etc.), which may through input/output (I/O) interfaces 1005. Moreover, computing device 100 may also communicate with one or more networks (e.g., a Local Area Network (LAN), a Wide Area Network (WAN), and/or a public network, such as the internet) through network adapter 1006. As shown in FIG. 10, network adapter 1006 communicates with the other modules of computing device 100 via bus 1003. It should be understood that although not shown in the figures, other hardware and/or software modules may be used in conjunction with computing device 100, including but not limited to: microcode, device drivers, redundant processing units, external disk drive arrays, RAID systems, tape drives, and data backup storage systems, among others.
Exemplary Medium
Having described the data method, apparatus, system, and computing device of exemplary embodiments of the present invention, a computer-readable medium for data processing of exemplary embodiments of the present invention is described next. An embodiment of the present invention provides a computer-readable medium, on which a computer program is stored, which when executed by a processor implements steps in a data processing method according to various exemplary embodiments of the present invention described in the above section "exemplary method", such as implementing step 201 shown in fig. 2, and if a current data block of a main storage node satisfies a first data processing condition, extracting a determined valid data file of the current data block; step 202, rewriting the extracted valid data file into the last data block of the main storage node and at least one slave storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time; step 203, deleting the current data block from the master storage node and the at least one slave storage node by using the preset data consistency protocol.
The readable medium may be a readable signal medium or a readable storage medium. A readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any combination of the foregoing. More specific examples (a non-exhaustive list) of the readable storage medium include: an electrical connection having one or more wires, a portable disk, a hard disk, a Random Access Memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing.
As shown in fig. 11, a program product 110 for data processing according to an embodiment of the present invention is described, which may employ a portable compact disc read only memory (CD-ROM) and include program code, and may be run on a terminal device. However, the program product of the present invention is not limited in this regard and, in the present document, a readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A readable signal medium may include a propagated data signal with readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated data signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A readable signal medium may also be any readable medium that is not a readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, C + + or the like and conventional procedural programming languages, such as the "C" programming language or similar programming languages. The program code may execute entirely on the user device, partly on a remote computing device, or entirely on the remote computing device or server. In the case of a remote computing device, the remote computing device may be connected to the user device through any kind of network, including a Local Area Network (LAN) or a Wide Area Network (WAN), or may be connected to an external computing device.
It should be noted that although in the above detailed description several modules of the data processing apparatus are mentioned, such a division is merely exemplary and not mandatory. Indeed, the features and functionality of two or more of the modules described above may be embodied in one module according to embodiments of the invention. Conversely, the features and functions of one module described above may be further divided into embodiments by a plurality of modules.
Moreover, while the operations of the method of the invention are depicted in the drawings in a particular order, this does not require or imply that the operations must be performed in this particular order, or that all of the illustrated operations must be performed, to achieve desirable results. Additionally or alternatively, certain steps may be omitted, multiple steps combined into one step execution, and/or one step broken down into multiple step executions.
While the spirit and principles of the invention have been described with reference to several particular embodiments, it is to be understood that the invention is not limited to the disclosed embodiments, nor is the division of aspects, which is for convenience only as the features in such aspects may not be combined to benefit. The invention is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.

Claims (17)

1. A method of data processing, comprising:
if the current data block of the main storage node meets a first data processing condition, extracting the determined effective data file of the current data block;
rewriting the extracted effective data file into the last data block of the main storage node and at least one auxiliary storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time;
deleting the current data block from the master storage node and the at least one slave storage node using the preset data consistency protocol;
if the remaining storage capacity of the last data block of the main storage node is smaller than the data amount corresponding to the effective data file, generating a new data block;
rewriting the remaining valid data files into the new data block;
and the remaining valid data files are valid data files of the last data block which is not rewritten into the main storage node.
2. The method of claim 1, wherein the current data block is determined to satisfy a first data processing condition by:
determining a valid data file of the current data block;
judging whether the effective data file proportion of the current data block is smaller than a set threshold value or not;
if so, determining that the current data block meets a first data processing condition;
the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block.
3. The method of claim 1, wherein rewriting the extracted valid data file into a last data block of the master storage node and the at least one slave storage node using a preset data consistency protocol comprises:
adding the extracted effective data file to the last data block of the main storage node, and sending a first instruction for rewriting the effective data file to the at least one slave storage node, wherein the first instruction carries index information of the effective data file, and the index information is used for the at least one slave storage node to extract the effective data file according to the index information and add the effective data file to the last data block of the at least one slave storage node;
if first responses sent by all the slave storage nodes are received, modifying the index information of the effective data file in the master storage node into the index information corresponding to the additional position;
and sending a second response to the at least one slave storage node, wherein the second response is used for identifying that the operation of rewriting the valid data file into the master storage node is completed, so that the at least one slave storage node modifies the index information of the valid data file in the at least one slave storage node into the index information corresponding to the additional position according to the second response.
4. The method of claim 2, wherein the valid data file for the current data block is determined as follows:
for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, determining that the logic deletion command file is a valid data file of the current data block.
5. The method of claim 1, wherein extracting the determined valid data file for the current data block comprises:
scanning the current data block;
for each first-class data file of the current data block, if the index information of the first-class data file is not null, extracting the first-class data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, extracting the logic deletion command file.
6. A data processing apparatus comprising:
the extraction module is used for extracting the determined effective data file of the current data block if the current data block of the main storage node meets a first data processing condition;
the rewriting module is used for rewriting the extracted effective data file into the last data block of the main storage node and the at least one auxiliary storage node by using a preset data consistency protocol, wherein the last data block is a data block with the generation time closest to the current time;
a deletion module configured to delete the current data block from the master storage node and the at least one slave storage node using the preset data consistency protocol;
a generating module, configured to generate a new data block if a remaining storage capacity of a last data block of the main storage node is smaller than a data amount corresponding to the valid data file;
the rewriting module is further configured to rewrite the remaining valid data files into the new data block; and the remaining valid data files are valid data files of the last data block which is not rewritten into the main storage node.
7. The apparatus of claim 6, further comprising:
the first determining module is specifically configured to determine that the current data block meets a first data processing condition in the following manner:
determining a valid data file of the current data block;
judging whether the effective data file proportion of the current data block is smaller than a set threshold value or not;
if so, determining that the current data block meets a first data processing condition;
the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block.
8. The apparatus of claim 6, wherein the rewrite module is specifically configured to:
adding the extracted effective data file to the last data block of the main storage node, and sending a first instruction for rewriting the effective data file to the at least one slave storage node, wherein the first instruction carries index information of the effective data file, and the index information is used for the at least one slave storage node to extract the effective data file according to the index information and add the effective data file to the last data block of the at least one slave storage node;
if first responses sent by all the slave storage nodes are received, modifying the index information of the effective data file in the master storage node into the index information corresponding to the additional position;
and sending a second response to the at least one slave storage node, wherein the second response is used for identifying that the operation of rewriting the valid data file into the master storage node is completed, so that the at least one slave storage node modifies the index information of the valid data file in the at least one slave storage node into the index information corresponding to the additional position according to the second response.
9. The apparatus of claim 7, further comprising:
a second determining module, configured to determine a valid data file of the current data block in the following manner:
for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, determining that the logic deletion command file is a valid data file of the current data block.
10. The apparatus of claim 6, wherein the extraction module is specifically configured to:
scanning the current data block;
for each first-class data file of the current data block, if the index information of the first-class data file is not null, extracting the first-class data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, extracting the logic deletion command file.
11. A data processing system comprising a master storage node and at least one slave storage node, wherein:
the main storage node is used for extracting the determined effective data file of the current data block if the current data block of the main storage node meets a first data processing condition; rewriting the extracted valid data file into the last data block of the main storage node and instructing the at least one slave storage node to rewrite the extracted valid data file into the last data block of the corresponding slave storage node by using a preset data consistency protocol; deleting the current data block from the master storage node and instructing the at least one slave storage node to delete the current data block from the corresponding slave storage node using the preset data consistency protocol; the last data block is a data block with the generation time closest to the current time;
the master storage node is further configured to: if the remaining storage capacity of the last data block of the main storage node is smaller than the data amount corresponding to the effective data file, generating a new data block; rewriting the remaining valid data files into the new data block; wherein, the remaining valid data files are valid data files of the last data block which is not rewritten into the main storage node;
and the slave storage node is used for rewriting the extracted valid data file into the last data block of the slave storage node according to the indication of the master storage node and deleting the current data block from the slave storage node.
12. The system of claim 11, wherein the master storage node is specifically configured to:
adding the extracted effective data file to the last data block of the main storage node, and sending a first instruction for rewriting the effective data file to the at least one auxiliary storage node, wherein the first instruction carries index information of the effective data file; if first responses sent by all the slave storage nodes are received, modifying the index information of the effective data file in the master storage node into the index information corresponding to the additional position; sending a second response to the at least one slave storage node, the second response identifying completion of the operation of rewriting the valid data file into the master storage node;
the slave storage node is specifically configured to: receiving a first instruction sent by the main storage node; extracting the effective data file according to the index information of the effective data file carried in the first instruction, and adding the extracted effective data file to the last data block of the slave storage node; receiving a second response sent by the main storage node; and according to the second response, modifying the index information of the effective data file in the slave storage node into the index information corresponding to the additional position.
13. The system of claim 11,
the primary storage node is specifically configured to determine that the current data block satisfies a first data processing condition in the following manner:
determining a valid data file of the current data block;
judging whether the effective data file proportion of the current data block is smaller than a set threshold value or not;
if so, determining that the current data block meets a first data processing condition;
the effective data file occupation ratio of the current data block is equal to the ratio of the data volume of the effective data files in the current data block to the storage capacity corresponding to the current data block.
14. The system of claim 13,
the main storage node is specifically configured to determine the valid data file of the current data block by:
for each first type data file of the current data block, if the index information of the first type data file is not null, determining that the first type data file is an effective data file of the current data block; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, determining that the logic deletion command file is a valid data file of the current data block.
15. The system of claim 11,
the main storage node is specifically configured to extract the determined valid data file of the current data block in the following manner:
scanning the current data block;
for each first-class data file of the current data block, if the index information of the first-class data file is not null, extracting the first-class data file; wherein the first type of data file comprises a data file with a write mark and a data file with a rewrite mark;
storing file identifications of first-class data files in each data block of a main storage node into an identification set;
for each logic deletion command file in the current data block, inquiring the file identifier of the data file which is indicated by the logic deletion command file and is subjected to logic deletion from the identifier set;
if yes, extracting the logic deletion command file.
16. A computer-readable medium, on which a computer program is stored which is executed by a processor for carrying out the steps of the method of any one of claims 1 to 5.
17. A computing device comprising a memory, a processor and a computer program stored on the memory and executable on the processor, a bus connecting the memory and the processor, and/or an interface for connecting external devices, the processor implementing the steps of the method according to any one of claims 1 to 5 when executing the program.
CN201810142664.XA 2018-02-11 2018-02-11 Data processing method, device, system, medium and computing equipment Active CN108415986B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810142664.XA CN108415986B (en) 2018-02-11 2018-02-11 Data processing method, device, system, medium and computing equipment

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810142664.XA CN108415986B (en) 2018-02-11 2018-02-11 Data processing method, device, system, medium and computing equipment

Publications (2)

Publication Number Publication Date
CN108415986A CN108415986A (en) 2018-08-17
CN108415986B true CN108415986B (en) 2020-10-30

Family

ID=63128646

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810142664.XA Active CN108415986B (en) 2018-02-11 2018-02-11 Data processing method, device, system, medium and computing equipment

Country Status (1)

Country Link
CN (1) CN108415986B (en)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109325034B (en) * 2018-10-12 2023-10-20 平安科技(深圳)有限公司 Data processing method, device, computer equipment and storage medium
CN109933566B (en) * 2019-03-06 2023-05-12 深信服科技股份有限公司 File reading and writing method, device, equipment and computer readable storage medium
CN109977074B (en) * 2019-03-11 2021-04-27 北京东方国信科技股份有限公司 HDFS-based LOB data processing method and device
CN110096237B (en) * 2019-04-30 2022-02-08 北京百度网讯科技有限公司 Copy processing method, node, storage system, server and readable medium
CN112764662B (en) * 2019-10-21 2024-04-19 伊姆西Ip控股有限责任公司 Method, apparatus and computer program product for storage management
CN111177075B (en) * 2019-12-26 2022-04-22 浪潮电子信息产业股份有限公司 Junk data identification method and system, electronic equipment and storage medium

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1670726A (en) * 2004-03-17 2005-09-21 联想(北京)有限公司 A method for inspecting garbage files in cluster file system
CN102317939A (en) * 2008-12-22 2012-01-11 谷歌公司 Asynchronous distributed garbage collection for replicated storage clusters
CN103064843A (en) * 2011-10-20 2013-04-24 北京中搜网络技术股份有限公司 Data processing device and data processing method
CN103077166A (en) * 2011-10-25 2013-05-01 深圳市快播科技有限公司 Spatial multiplexing method and device for small file storage
CN105095489A (en) * 2015-08-18 2015-11-25 浪潮(北京)电子信息产业有限公司 Distributed file deletion method, device and system

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101251843B (en) * 2007-11-23 2010-06-30 华中科技大学 A Fully Distributed Replica Location Method for Data Grid
DE102008012979A1 (en) * 2008-03-06 2009-09-10 Gip Ag Method and program for providing data coherency in networks
US9292373B2 (en) * 2013-03-15 2016-03-22 International Business Machines Corporation Query rewrites for data-intensive applications in presence of run-time errors

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1670726A (en) * 2004-03-17 2005-09-21 联想(北京)有限公司 A method for inspecting garbage files in cluster file system
CN102317939A (en) * 2008-12-22 2012-01-11 谷歌公司 Asynchronous distributed garbage collection for replicated storage clusters
CN103064843A (en) * 2011-10-20 2013-04-24 北京中搜网络技术股份有限公司 Data processing device and data processing method
CN103077166A (en) * 2011-10-25 2013-05-01 深圳市快播科技有限公司 Spatial multiplexing method and device for small file storage
CN105095489A (en) * 2015-08-18 2015-11-25 浪潮(北京)电子信息产业有限公司 Distributed file deletion method, device and system

Also Published As

Publication number Publication date
CN108415986A (en) 2018-08-17

Similar Documents

Publication Publication Date Title
CN108415986B (en) Data processing method, device, system, medium and computing equipment
US12117911B2 (en) Remote data replication method and system
US10599337B2 (en) Method and device for writing data and acquiring data in a distributed storage system
CN110018998B (en) File management method and system, electronic equipment and storage medium
US10303363B2 (en) System and method for data storage using log-structured merge trees
EP3206128B1 (en) Data storage method, data storage apparatus, and storage device
CN103460197A (en) Computer system, file management method and metadata server
US20190188090A1 (en) Snapshot Deletion In A Distributed Storage System
WO2017113211A1 (en) Method and device for processing access request, and computer system
JP2021522577A (en) Host-aware update write method, system, and computer program
CN112817962B (en) Data storage method and device based on object storage and computer equipment
US10430110B2 (en) Implementing a hybrid storage node in a distributed storage system
JP6376626B2 (en) Data storage method, data storage device, and storage device
US10452308B2 (en) Encoding tags for metadata entries in a storage system
CN112162950B (en) Data processing method and device based on file system and computer equipment
CN115793982A (en) Data processing method, medium, device and computing equipment
CN114063935B (en) Method and device for processing data
CN113806316B (en) File synchronization method, equipment and storage medium
CN118796134B (en) Disaster recovery method, system, device, equipment and storage medium for IO data
US20240403169A1 (en) Data Processing System and Method, and Device
CN112597074B (en) Data processing method and device
HK40067494A (en) Data processing method and device
WO2024132126A1 (en) Memory controller and method for backup system
CN114880277A (en) Block device snapshot method, system and storage medium
CN117951094A (en) Storage space recycling method, file system, medium and computing device

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
CP01 Change in the name or title of a patent holder
CP01 Change in the name or title of a patent holder

Address after: 310052 Room 301, Building No. 599, Changhe Street Network Business Road, Binjiang District, Hangzhou City, Zhejiang Province

Patentee after: Hangzhou NetEase Shuzhifan Technology Co.,Ltd.

Address before: 310052 Room 301, Building No. 599, Changhe Street Network Business Road, Binjiang District, Hangzhou City, Zhejiang Province

Patentee before: HANGZHOU LANGHE TECHNOLOGY Ltd.