P
US10185625B2ExpiredUtilityPatentIndex 51

Data storage system and method by shredding and deshredding

Assignee: CLEVERSAFE INCPriority: Aug 31, 2001Filed: Dec 1, 2014Granted: Jan 22, 2019
Est. expiryAug 31, 2021(expired)· nominal 20-yr term from priority
Inventors:DE LA TORRE DOUGLAS RYOUNG DAVID W
G06F 11/1076G06F 2201/80G06F 17/30371H04L 9/3247H04L 2209/30G06F 11/141G06F 11/1402Y10S707/99943Y10S707/99942H03M 7/30H03M 13/29G06F 21/602G06F 16/2365
51
PatentIndex Score
0
Cited by
5
References
22
Claims

Abstract

A system and method for data storage by shredding and deshredding of the data allows for various combinations of processing of the data to provide various resultant storage of the data. Data storage and retrieval functions include various combinations of data redundancy generation, data compression and decompression, data encryption and decryption, and data integrity by signature generation and verification. Data shredding is performed by shredders and data deshredding is performed by deshredders that have some implementations that allocate processing internally in the shredder and deshredder either in parallel to multiple processors or sequentially to a single processor. Other implementations use multiple processing through multi-level shredders and deshredders. Redundancy generation includes implementations using non-systematic encoding, systematic encoding, or a hybrid combination. Shredder based tag generators and deshredder based tag readers are used in some implementations to allow the deshredders to adapt to various versions of the shredders.

Claims

exact text as granted — not AI-modified
What is claimed is: 
     
       1. A method for decoding encoded data elements retrieved from storage units by use of at least one processor comprising:
 transmitting a retrieval request for a plurality of encoded data elements to a plurality of storage units; wherein each encoded data element of the plurality of encoded data elements is associated with a data object; 
 retrieving metadata from a set of storage units of the plurality of storage units, wherein the metadata includes information regarding the plurality of encoded data elements, and further wherein the information is sufficient to determine one or more transforms of a set of transforms used to create each encoded data element of the plurality of encoded data elements, wherein each transform of the set of transforms is different from other transforms in the set of transforms; and 
 based on the information regarding the plurality of encoded data elements, performing one or more of:
 retrieving a threshold number of encoded data elements of the plurality of encoded data elements from the set of storage units of the plurality of storage units, wherein the threshold number of encoded data elements is a number of encoded data elements of the plurality of encoded data elements sufficient to recover a first piece of data and further wherein the number of encoded data elements of the plurality of encoded data elements sufficient to recover the first piece of data is less than a total number of encoded data slices associated with the data object; and 
 decoding the threshold number of encoded data elements retrieved to recover the data object, wherein the data object is divided into a set of separate pieces of data and wherein the set of separate pieces of data includes the piece of data. 
 
 
     
     
       2. The method of  claim 1 , further including:
 retrieving and decoding another threshold number of encoded data elements to produce a second piece of data; and 
 combining the second piece of data with the first piece of data to recover the data. 
 
     
     
       3. The method of  claim 1 , further including selecting the set of storage units of the plurality of storage units for retrieving the threshold number of encoded data elements, wherein the set of storage units includes the storage unit for retrieving the metadata. 
     
     
       4. The method of  claim 1 , wherein systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       5. The method of  claim 1 , wherein non-systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       6. The method of  claim 1 , wherein a hybrid combination of systematic decoding and non-systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       7. The method of  claim 1 , wherein the metadata includes information pertaining to relationships among different encoded data elements of the plurality of encoded data elements. 
     
     
       8. The method of  claim 1 , wherein the one or more transforms collectively form a matrix. 
     
     
       9. The method of  claim 1 , wherein the one or more transforms includes information sufficient to identify at least one of an encryption function, a sequencing function, and parameters that have changed, in the generation of the plurality of encoded data elements. 
     
     
       10. The method of  claim 1 , wherein the metadata includes one or more information pertaining to:
 data geometries; 
 data relationships; 
 data nesting; 
 structure; 
 coding structure; 
 data alignment; 
 size and length of data; and 
 data hash. 
 
     
     
       11. An apparatus for decoding encoded data elements retrieved from storage units comprising:
 an interface; and 
 at least one processor configured with the interface to: 
 transmit a retrieval request for a plurality of encoded data elements to a plurality of storage units; wherein each encoded data element of the plurality of encoded data elements is associated with a data object; 
 retrieve metadata from a storage unit of the plurality of storage units, wherein the metadata includes information sufficient to determine one or more transforms of a set of transforms used to create each encoded data element of the plurality of encoded data elements, wherein each transform of the set of transforms is different from other transforms in the set of transforms; and 
 based on the information regarding the plurality of encoded data elements, perform one or more of:
 retrieve a threshold number of encoded data elements of the plurality of encoded data elements from a set of storage units of the plurality of storage units, wherein the threshold number of encoded data elements is a number of encoded data elements of the plurality of encoded data elements sufficient to recover a first piece of data and further wherein the number of encoded data elements of the plurality of encoded data elements sufficient to recover the first piece of data is less than a total number of encoded data slices associated with the data object; and 
 decode the threshold number of encoded data elements retrieved to recover the data object, wherein the data object is divided into a set of separate pieces of data and wherein the set of separate pieces of data includes the piece of data. 
 
 
     
     
       12. The apparatus of  claim 11 , wherein the at least one processor also retrieves and decodes another threshold number of encoded data elements to produce a second piece of data and combines the second piece of data with the first piece of data to recover the data. 
     
     
       13. The apparatus of  claim 11 , wherein the at least one processor selects the set of storage units from the plurality of storage units to retrieve the threshold number of encoded data elements, wherein the set of storage units includes the storage unit with the metadata. 
     
     
       14. The apparatus of  claim 11 , wherein systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       15. The apparatus of  claim 11 , wherein non-systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       16. The apparatus of  claim 11 , wherein a hybrid combination of systematic decoding and non-systematic decoding is utilized to decode the threshold number of encoded data elements. 
     
     
       17. The apparatus of  claim 11 , wherein the metadata includes information pertaining to relationship among different encoded data elements of the plurality of encoded data elements. 
     
     
       18. The apparatus of  claim 11 , wherein the one or more transforms collectively form a matrix. 
     
     
       19. The apparatus of  claim 18 , wherein the one or more transforms includes information sufficient to identify at least one of an encryption function, a sequencing function, and parameters that have changed, in the generation of the plurality of encoded data elements. 
     
     
       20. The apparatus of  claim 11 , wherein the metadata includes one or more information pertaining to:
 data geometries; 
 data relationships; 
 data nesting; 
 structure; 
 coding structure; 
 data alignment; 
 size and length of data; and 
 data hash. 
 
     
     
       21. A computer-readable medium comprising instructions executable by a processor and when executed, instructing the processor to:
 transmit a retrieval request for a plurality of encoded data elements to a plurality of storage units; 
 wherein each encoded data element of the plurality of encoded data elements is associated with a data object; 
 retrieve metadata from a storage unit of the plurality of storage units, wherein the metadata includes information sufficient to determine one or more transforms of a set of transforms used to create each encoded data element of the plurality of encoded data elements, wherein each transform of the set of transforms is different from other transforms in the set of transforms; and 
 based on the information regarding the plurality of encoded data elements, perform one or more of:
 retrieve a threshold number of encoded data elements of the plurality of encoded data elements from a set of storage units of the plurality of storage units, wherein the threshold number of encoded data elements is a number of encoded data elements of the plurality of encoded data elements sufficient to recover a first piece of data and further wherein the number of encoded data elements of the plurality of encoded data elements sufficient to recover the first piece of data is less than a total number of encoded data slices associated with the data object; and 
 decode the threshold number of encoded data elements retrieved to recover the data object, wherein the data object is divided into a set of separate pieces of data and wherein the set of separate pieces of data includes the piece of data. 
 
 
     
     
       22. The computer-readable medium of  claim 21 , wherein the instructions instruct the processor to use at least one of systematic decoding, non-systematic decoding and a hybrid combination of systematic decoding and non-systematic decoding, to decode the threshold number of encoded data elements.

Cited by (0)

No later patents cite this yet.

References (0)

No backward citations on record.