mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
with xlv2 format we never had to fill in checksumInfo() (#17963)
- this PR avoids sending a large ChecksumInfo slice when its not needed - also for a file with XLV2 format there is no reason to allocate Checksum slice while reading
This commit is contained in:
parent
6a8d8f34a5
commit
18b3655c99
@ -620,7 +620,7 @@ func TestDisksWithAllParts(t *testing.T) {
|
|||||||
diskFailures[15] = "part.1"
|
diskFailures[15] = "part.1"
|
||||||
|
|
||||||
for diskIndex, partName := range diskFailures {
|
for diskIndex, partName := range diskFailures {
|
||||||
for i := range partsMetadata[diskIndex].Erasure.Checksums {
|
for i := range partsMetadata[diskIndex].Parts {
|
||||||
if fmt.Sprintf("part.%d", i+1) == partName {
|
if fmt.Sprintf("part.%d", i+1) == partName {
|
||||||
filePath := pathJoin(erasureDisks[diskIndex].String(), bucket, object, partsMetadata[diskIndex].DataDir, partName)
|
filePath := pathJoin(erasureDisks[diskIndex].String(), bucket, object, partsMetadata[diskIndex].DataDir, partName)
|
||||||
f, err := os.OpenFile(filePath, os.O_WRONLY|os.O_SYNC, 0)
|
f, err := os.OpenFile(filePath, os.O_WRONLY|os.O_SYNC, 0)
|
||||||
|
@ -714,11 +714,6 @@ func (er *erasureObjects) healObject(ctx context.Context, bucket string, object
|
|||||||
|
|
||||||
partsMetadata[i].DataDir = dstDataDir
|
partsMetadata[i].DataDir = dstDataDir
|
||||||
partsMetadata[i].AddObjectPart(partNumber, "", partSize, partActualSize, partModTime, partIdx, partChecksums)
|
partsMetadata[i].AddObjectPart(partNumber, "", partSize, partActualSize, partModTime, partIdx, partChecksums)
|
||||||
partsMetadata[i].Erasure.AddChecksumInfo(ChecksumInfo{
|
|
||||||
PartNumber: partNumber,
|
|
||||||
Algorithm: checksumAlgo,
|
|
||||||
Hash: bitrotWriterSum(writers[i]),
|
|
||||||
})
|
|
||||||
if len(inlineBuffers) > 0 && inlineBuffers[i] != nil {
|
if len(inlineBuffers) > 0 && inlineBuffers[i] != nil {
|
||||||
partsMetadata[i].Data = inlineBuffers[i].Bytes()
|
partsMetadata[i].Data = inlineBuffers[i].Bytes()
|
||||||
partsMetadata[i].SetInlineData()
|
partsMetadata[i].SetInlineData()
|
||||||
|
@ -41,17 +41,6 @@ const minIOErasureUpgraded = "x-minio-internal-erasure-upgraded"
|
|||||||
|
|
||||||
const erasureAlgorithm = "rs-vandermonde"
|
const erasureAlgorithm = "rs-vandermonde"
|
||||||
|
|
||||||
// AddChecksumInfo adds a checksum of a part.
|
|
||||||
func (e *ErasureInfo) AddChecksumInfo(ckSumInfo ChecksumInfo) {
|
|
||||||
for i, sum := range e.Checksums {
|
|
||||||
if sum.PartNumber == ckSumInfo.PartNumber {
|
|
||||||
e.Checksums[i] = ckSumInfo
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
e.Checksums = append(e.Checksums, ckSumInfo)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetChecksumInfo - get checksum of a part.
|
// GetChecksumInfo - get checksum of a part.
|
||||||
func (e ErasureInfo) GetChecksumInfo(partNumber int) (ckSum ChecksumInfo) {
|
func (e ErasureInfo) GetChecksumInfo(partNumber int) (ckSum ChecksumInfo) {
|
||||||
for _, sum := range e.Checksums {
|
for _, sum := range e.Checksums {
|
||||||
@ -60,7 +49,7 @@ func (e ErasureInfo) GetChecksumInfo(partNumber int) (ckSum ChecksumInfo) {
|
|||||||
return sum
|
return sum
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return ChecksumInfo{}
|
return ChecksumInfo{Algorithm: DefaultBitrotAlgorithm}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ShardFileSize - returns final erasure size from original size.
|
// ShardFileSize - returns final erasure size from original size.
|
||||||
|
@ -960,11 +960,6 @@ func (er erasureObjects) putMetacacheObject(ctx context.Context, key string, r *
|
|||||||
}
|
}
|
||||||
partsMetadata[i].Data = inlineBuffers[i].Bytes()
|
partsMetadata[i].Data = inlineBuffers[i].Bytes()
|
||||||
partsMetadata[i].AddObjectPart(1, "", n, data.ActualSize(), modTime, index, nil)
|
partsMetadata[i].AddObjectPart(1, "", n, data.ActualSize(), modTime, index, nil)
|
||||||
partsMetadata[i].Erasure.AddChecksumInfo(ChecksumInfo{
|
|
||||||
PartNumber: 1,
|
|
||||||
Algorithm: DefaultBitrotAlgorithm,
|
|
||||||
Hash: bitrotWriterSum(w),
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fill all the necessary metadata.
|
// Fill all the necessary metadata.
|
||||||
@ -1296,11 +1291,6 @@ func (er erasureObjects) putObject(ctx context.Context, bucket string, object st
|
|||||||
}
|
}
|
||||||
// No need to add checksum to part. We already have it on the object.
|
// No need to add checksum to part. We already have it on the object.
|
||||||
partsMetadata[i].AddObjectPart(1, "", n, data.ActualSize(), modTime, compIndex, nil)
|
partsMetadata[i].AddObjectPart(1, "", n, data.ActualSize(), modTime, compIndex, nil)
|
||||||
partsMetadata[i].Erasure.AddChecksumInfo(ChecksumInfo{
|
|
||||||
PartNumber: 1,
|
|
||||||
Algorithm: DefaultBitrotAlgorithm,
|
|
||||||
Hash: bitrotWriterSum(w),
|
|
||||||
})
|
|
||||||
partsMetadata[i].Versioned = opts.Versioned || opts.VersionSuspended
|
partsMetadata[i].Versioned = opts.Versioned || opts.VersionSuspended
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -612,17 +612,9 @@ func (j xlMetaV2Object) ToFileInfo(volume, path string) (FileInfo, error) {
|
|||||||
fi.Parts[i].Index = j.PartIndices[i]
|
fi.Parts[i].Index = j.PartIndices[i]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fi.Erasure.Checksums = make([]ChecksumInfo, len(j.PartSizes))
|
// fi.Erasure.Checksums - is left empty since we do not have any
|
||||||
for i := range fi.Parts {
|
// whole checksums for many years now, no need to allocate.
|
||||||
fi.Erasure.Checksums[i].PartNumber = fi.Parts[i].Number
|
|
||||||
switch j.BitrotChecksumAlgo {
|
|
||||||
case HighwayHash:
|
|
||||||
fi.Erasure.Checksums[i].Algorithm = HighwayHash256S
|
|
||||||
fi.Erasure.Checksums[i].Hash = []byte{}
|
|
||||||
default:
|
|
||||||
return FileInfo{}, fmt.Errorf("unknown BitrotChecksumAlgo: %v", j.BitrotChecksumAlgo)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fi.Metadata = make(map[string]string, len(j.MetaUser)+len(j.MetaSys))
|
fi.Metadata = make(map[string]string, len(j.MetaUser)+len(j.MetaSys))
|
||||||
for k, v := range j.MetaUser {
|
for k, v := range j.MetaUser {
|
||||||
// https://github.com/google/security-research/security/advisories/GHSA-76wf-9vgp-pj7w
|
// https://github.com/google/security-research/security/advisories/GHSA-76wf-9vgp-pj7w
|
||||||
|
Loading…
Reference in New Issue
Block a user