forked from Deuxfleurs/garage
Merge pull request 'block/manager.rs: Prioritize raw blocks when no compression configured' (#566) from jpds/garage:skip-compressed-blocks-scrub-no-compression into main
Reviewed-on: Deuxfleurs/garage#566
This commit is contained in:
commit
2f495575d8
1 changed files with 25 additions and 5 deletions
|
@ -600,12 +600,32 @@ impl BlockManager {
|
||||||
/// Utility: check if block is stored compressed. Error if block is not stored
|
/// Utility: check if block is stored compressed. Error if block is not stored
|
||||||
async fn is_block_compressed(&self, hash: &Hash) -> Result<bool, Error> {
|
async fn is_block_compressed(&self, hash: &Hash) -> Result<bool, Error> {
|
||||||
let mut path = self.block_path(hash);
|
let mut path = self.block_path(hash);
|
||||||
path.set_extension("zst");
|
|
||||||
if fs::metadata(&path).await.is_ok() {
|
// If compression is disabled on node - check for the raw block
|
||||||
return Ok(true);
|
// first and then a compressed one (as compression may have been
|
||||||
|
// previously enabled).
|
||||||
|
match self.compression_level {
|
||||||
|
None => {
|
||||||
|
if fs::metadata(&path).await.is_ok() {
|
||||||
|
return Ok(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
path.set_extension("zst");
|
||||||
|
|
||||||
|
fs::metadata(&path).await.map(|_| true).map_err(Into::into)
|
||||||
|
}
|
||||||
|
_ => {
|
||||||
|
path.set_extension("zst");
|
||||||
|
|
||||||
|
if fs::metadata(&path).await.is_ok() {
|
||||||
|
return Ok(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
path.set_extension("");
|
||||||
|
|
||||||
|
fs::metadata(&path).await.map(|_| false).map_err(Into::into)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
path.set_extension("");
|
|
||||||
fs::metadata(&path).await.map(|_| false).map_err(Into::into)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn lock_mutate(&self, hash: &Hash) -> MutexGuard<'_, BlockManagerLocked> {
|
async fn lock_mutate(&self, hash: &Hash) -> MutexGuard<'_, BlockManagerLocked> {
|
||||||
|
|
Loading…
Reference in a new issue