Async-logger-state
Read a complete async logger runtime snapshot for diagnostics. This API is the preferred way to inspect queue backlog, dropped counts, lifecycle status, and runtime mode before exporting them through JSON helpers when needed.
Interface
pub fn[S] AsyncLogger::state(self : AsyncLogger[S]) -> AsyncLoggerState {}input
self : AsyncLogger[S]- The async logger whose runtime snapshot should be read.
output
AsyncLoggerState- A snapshot containing runtime mode, worker support, queue counts, lifecycle flags, last error, and flush policy.
Explanation
Detailed rules explaining key parameters and behaviors
AsyncLoggerStateincludesruntime,pending_count,dropped_count,is_closed,is_running,has_failed,last_error, andflush_policy.state()returns a value snapshot rather than a live handle.- This helper is equivalent to
AsyncLoggerState::new(async_runtime_state(), self.pending_count(), self.dropped_count(), self.is_closed(), self.is_running(), self.has_failed(), self.last_error(), self.flush_policy()). async_logger_state_to_json(...)andstringify_async_logger_state(...)convert the snapshot to stable diagnostic output.runtimeembeds the result ofasync_runtime_state()from the momentstate()is called, so callers do not need to join separate helpers manually.- The runtime portion is therefore recomputed from the active backend helper on each call, while the remaining fields come from the logger's current counters, flags, and flush policy at that same general moment.
- Because the snapshot is assembled field by field when
state()is called, later logger changes require callingstate()again rather than reusing an olderAsyncLoggerStatevalue as if it refreshed itself. - That field-by-field assembly also means this helper is not an atomic freeze across all refs; under concurrent logger activity, neighboring fields can reflect slightly different instants.
- After a worker failure,
has_failed=true, a non-emptylast_error, andpending_count>0can legitimately appear together in one snapshot until later cleanup or a later startedrun()changes them. - After shutdown cleanup on an already failed logger, snapshots can also legitimately show
is_closed=truetogether with retainedhas_failed=trueand the samelast_error(), whilepending_countversusdropped_countstill reflects the active runtime's cleanup path. state()only reports the current field values; it does not clear failure state, drain backlog, or synchronize pending work by itself.
How to Use
Here are some specific examples provided.
When Need Startup Diagnostics
When you want to expose current async logger mode and queue state at startup:
let logger = build_async_logger(config)
println(stringify_async_logger_state(logger.state(), pretty=true))In this example, the snapshot can be printed directly without extra manual formatting.
And downstream operators can see both runtime mode and queue-related status together.
When Need Failure Investigation Data
When diagnosing async delivery issues:
let state = logger.state()
if state.has_failed {
println(stringify_async_logger_state(state, pretty=true))
}In this example, the same snapshot object works for conditional diagnostics and serialization.
And the reported failure fields can still appear together with non-zero backlog when a worker stopped early.
Error Case
e.g.:
If no error has occurred,
last_erroris just an empty string.If the queue is empty,
pending_countis0; this is normal and not a special error condition.flush_policyreports the logger's configured async flush mode, not whether a flush has already happened.The embedded
runtimeobject is also just a snapshot of the current backend helper result at read time;state()does not cache it onto the logger for later reuse.If concurrent logger activity is still changing counters or flags while
state()runs, the returned value is still useful for diagnostics but should not be treated as a transactional snapshot.A snapshot showing
has_failed=truedoes not implypending_countis already0; remaining queued records may still be visible until later cleanup or restart.A snapshot showing
is_closed=truealso does not imply failure state was cleared; after failure-driven shutdown,has_failed=trueand the recordedlast_errorcan still remain visible until a laterrun()actually restarts the logger.
Notes
Prefer this API over manually combining
pending_count(),dropped_count(), and runtime-mode helpers.Use
pretty=truewhen emitting logs for humans and the compact form for machine-oriented payloads.Use
AsyncLoggerState::new(...)only when tests or adapters need to construct a manual snapshot instead of reading one directly from a logger instance.If consumers need stronger cross-field consistency than a diagnostic snapshot, they should not assume
state()provides an atomic read barrier.