Skip to main content

HistoryCacheStats

Struct HistoryCacheStats 

Source
pub struct HistoryCacheStats {
    pub len: AtomicUsize,
    pub evicted: AtomicU64,
    pub max_sn: AtomicI64,
    pub min_sn: AtomicI64,
}
Expand description

Atomar-aktualisierte Snapshot-Statistik eines HistoryCache.

**** das eigentliche BTreeMap-Storage des Caches braucht weiter &mut self zum Mutieren (lese-/schreib-konkurrente BTreeMap-Mutation gibt’s in std nicht), aber Statistik-Werte (Laenge, max/min SN, Eviction-Counter) werden parallel in einem Arc<HistoryCacheStats> mitgefuehrt. Monitoring-Threads, SEDP-Tick- Loops und Telemetrie koennen so zustimmungsfrei pollen, ohne den Writer/Reader-Lock zu nehmen.

Konsistenz-Garantie: jede mutierende Methode des Caches updated die Atomics nach der BTreeMap-Mutation, mit Release-Ordering. Reader nutzen Acquire-Ordering — sie sehen einen konsistenten Stand der letzten abgeschlossenen Cache-Operation, nie einen halb-aktualisierten Zustand der einzelnen Atomics.

Was nicht garantiert ist: cross-field-Konsistenz. Wenn ein Reader len und dann max_sn liest, koennen zwischen den Loads weitere Inserts passiert sein. Das ist akzeptabel fuer Monitoring; fuer harte Wire-Pfade (Heartbeat-Build) wird weiter der Writer-Lock genommen.

Fields§

§len: AtomicUsize

Anzahl Changes im Cache (entspricht BTreeMap::len).

§evicted: AtomicU64

Anzahl per KeepLast-Eviction verworfener Samples seit Start.

§max_sn: AtomicI64

Hoechste SN im Cache, oder [STATS_SENTINEL_NO_SN] wenn leer.

§min_sn: AtomicI64

Niedrigste SN im Cache, oder [STATS_SENTINEL_NO_SN] wenn leer.

Implementations§

Source§

impl HistoryCacheStats

Source

pub fn snapshot(&self) -> HistoryCacheSnapshot

Snapshot der vier Atomics als Plain-Old-Data-Struct. Wird mit Acquire-Ordering geladen — synchronisiert mit der Release-Speicheroperation in HistoryCache::insert / HistoryCache::remove_up_to.

Trait Implementations§

Source§

impl Clone for HistoryCacheStats

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for HistoryCacheStats

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for HistoryCacheStats

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.