From 7f2e9297bc356672621308c9c5177008da91f5a6 Mon Sep 17 00:00:00 2001 From: Ben Kirwin Date: Fri, 10 Jan 2025 13:52:26 -0500 Subject: [PATCH 1/2] Remove stale test assertion The comment is no longer true: we _do_ share state under the hood, which is fine. --- src/persist-client/src/internal/machine.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/persist-client/src/internal/machine.rs b/src/persist-client/src/internal/machine.rs index 8af5174254471..749a83e2a0304 100644 --- a/src/persist-client/src/internal/machine.rs +++ b/src/persist-client/src/internal/machine.rs @@ -2633,8 +2633,7 @@ pub mod tests { ]; write1.expect_compare_and_append(&data[..1], 0, 2).await; - // quick check: each handle should have its own copy of state - assert!(write1.machine.seqno() > write2.machine.seqno()); + // this handle's upper now lags behind. if compare_and_append fails to update // state after an upper mismatch then this call would (incorrectly) fail write2.expect_compare_and_append(&data[1..2], 2, 3).await; From 82d85afca7ddda47484c814444c34dd2ccc5374a Mon Sep 17 00:00:00 2001 From: Ben Kirwin Date: Fri, 10 Jan 2025 14:05:45 -0500 Subject: [PATCH 2/2] Improve logging of GC invariant checks --- src/persist-client/src/internal/gc.rs | 30 +++++++++++---------------- 1 file changed, 12 insertions(+), 18 deletions(-) diff --git a/src/persist-client/src/internal/gc.rs b/src/persist-client/src/internal/gc.rs index 961b80bd18fa7..6e736fc34bfb9 100644 --- a/src/persist-client/src/internal/gc.rs +++ b/src/persist-client/src/internal/gc.rs @@ -23,7 +23,7 @@ use prometheus::Counter; use timely::progress::Timestamp; use tokio::sync::mpsc::UnboundedSender; use tokio::sync::{mpsc, oneshot, Semaphore}; -use tracing::{debug, debug_span, error, warn, Instrument, Span}; +use tracing::{debug, debug_span, warn, Instrument, Span}; use crate::async_runtime::IsolatedRuntime; use crate::batch::PartDeletes; @@ -31,6 +31,7 @@ use crate::cfg::GC_BLOB_DELETE_CONCURRENCY_LIMIT; use mz_ore::cast::CastFrom; use mz_ore::collections::HashSet; +use mz_ore::soft_assert_or_log; use mz_persist::location::{Blob, SeqNo}; use mz_persist_types::{Codec, Codec64}; @@ -360,26 +361,19 @@ where .rollups .contains_key(&initial_seqno); - debug_assert!( + // this should never be true in the steady-state, but may be true the + // first time GC runs after fixing any correctness bugs related to our + // state version invariants. we'll make it an error so we can track + // any violations in Sentry, but opt not to panic because the root + // cause of the violation cannot be from this GC run (in fact, this + // GC run, assuming it's correct, should have fixed the violation!) + soft_assert_or_log!( valid_pre_gc_state, - "rollups = {:?}, state seqno = {}", + "earliest state fetched during GC did not have corresponding rollup: rollups = {:?}, state seqno = {}", states.state().collections.rollups, initial_seqno ); - if !valid_pre_gc_state { - // this should never be true in the steady-state, but may be true the - // first time GC runs after fixing any correctness bugs related to our - // state version invariants. we'll make it an error so we can track - // any violations in Sentry, but opt not to panic because the root - // cause of the violation cannot be from this GC run (in fact, this - // GC run, assuming it's correct, should have fixed the violation!) - error!("earliest state fetched during GC did not have corresponding rollup: rollups = {:?}, state seqno = {}", - states.state().collections.rollups, - initial_seqno - ); - } - report_step_timing( &machine .applier @@ -426,7 +420,7 @@ where // By our invariant, `states` should always begin on a rollup. assert!( gc_rollups.contains_seqno(&states.state().seqno), - "rollups = {:?}, state seqno = {}", + "must start with a present rollup before searching for blobs: rollups = {:#?}, state seqno = {}", gc_rollups, states.state().seqno ); @@ -458,7 +452,7 @@ where // to maintain our invariant. assert!( gc_rollups.contains_seqno(&states.state().seqno), - "rollups = {:?}, state seqno = {}", + "must start with a present rollup after searching for blobs: rollups = {:#?}, state seqno = {}", gc_rollups, states.state().seqno );