verify: speedup - only verify chunks once
We need to do the check before we load the chunk.
This commit is contained in:
parent
4264c5023b
commit
7ae571e7cb
@ -50,7 +50,17 @@ fn verify_index_chunks(
|
|||||||
worker.fail_on_abort()?;
|
worker.fail_on_abort()?;
|
||||||
|
|
||||||
let info = index.chunk_info(pos).unwrap();
|
let info = index.chunk_info(pos).unwrap();
|
||||||
let size = info.range.end - info.range.start;
|
|
||||||
|
if verified_chunks.contains(&info.digest) {
|
||||||
|
continue; // already verified
|
||||||
|
}
|
||||||
|
|
||||||
|
if corrupt_chunks.contains(&info.digest) {
|
||||||
|
let digest_str = proxmox::tools::digest_to_hex(&info.digest);
|
||||||
|
worker.log(format!("chunk {} was marked as corrupt", digest_str));
|
||||||
|
errors += 1;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
let chunk = match datastore.load_chunk(&info.digest) {
|
let chunk = match datastore.load_chunk(&info.digest) {
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
@ -81,8 +91,8 @@ fn verify_index_chunks(
|
|||||||
errors += 1;
|
errors += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if !verified_chunks.contains(&info.digest) {
|
let size = info.range.end - info.range.start;
|
||||||
if !corrupt_chunks.contains(&info.digest) {
|
|
||||||
if let Err(err) = chunk.verify_unencrypted(size as usize, &info.digest) {
|
if let Err(err) = chunk.verify_unencrypted(size as usize, &info.digest) {
|
||||||
corrupt_chunks.insert(info.digest);
|
corrupt_chunks.insert(info.digest);
|
||||||
worker.log(format!("{}", err));
|
worker.log(format!("{}", err));
|
||||||
@ -90,12 +100,6 @@ fn verify_index_chunks(
|
|||||||
} else {
|
} else {
|
||||||
verified_chunks.insert(info.digest);
|
verified_chunks.insert(info.digest);
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
let digest_str = proxmox::tools::digest_to_hex(&info.digest);
|
|
||||||
worker.log(format!("chunk {} was marked as corrupt", digest_str));
|
|
||||||
errors += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if errors > 0 {
|
if errors > 0 {
|
||||||
|
Loading…
Reference in New Issue
Block a user