From df1c9efc4eeff737abc5625d4c6c5e942f95abca Mon Sep 17 00:00:00 2001 From: Vinnie Magro Date: Fri, 6 Oct 2023 12:57:54 -0700 Subject: [PATCH] [antlir2][btrfs package] increase loop retries Summary: metalos ci builds tons of loopbacks and fails constantly on diffs, try to bump up retries Test Plan: testhard Reviewed By: wujj123456 Differential Revision: D49980561 fbshipit-source-id: 350f8eeafe0f00845dcd367cfcacaf445d4d3bf4 --- .../antlir2_packager/btrfs_packager/src/main.rs | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/antlir/antlir2/antlir2_packager/btrfs_packager/src/main.rs b/antlir/antlir2/antlir2_packager/btrfs_packager/src/main.rs index 8bbf45d3bc..abbaea4093 100644 --- a/antlir/antlir2/antlir2_packager/btrfs_packager/src/main.rs +++ b/antlir/antlir2/antlir2_packager/btrfs_packager/src/main.rs @@ -75,12 +75,17 @@ impl LdHandle { // supposed to be atomic, but we're clearly getting what looks like race // conditions on CI, so just retry a few times and hopefully we'll get a // good device before giving up - retry::retry(retry::delay::Fixed::from_millis(50).take(3), || { - let ld = lc - .next_free() - .context("Failed to find a free loopback device")?; - Self::attach(ld, target.clone()) - }) + retry::retry( + retry::delay::Fixed::from_millis(100) + .map(retry::delay::jitter) + .take(10), + || { + let ld = lc + .next_free() + .context("Failed to find a free loopback device")?; + Self::attach(ld, target.clone()) + }, + ) .map_err(|e| match e { retry::Error::Operation { error, .. } => error, retry::Error::Internal(s) => anyhow::Error::msg(s),