Async-logger-config-type
AsyncLoggerConfig is the public config object used to describe async queue capacity, overflow behavior, batching, linger timing, and flush policy. It is a direct alias to the async config model used by async_logger(...), config parsers, and async config serializers.
Interface
pub type AsyncLoggerConfig = @utils.AsyncLoggerConfigoutput
AsyncLoggerConfig- Public async config object containingmax_pending,overflow,max_batch,linger_ms, andflush.
Explanation
Detailed rules explaining key parameters and behaviors
- This is a type alias, not a runtime logger handle.
- The current fields are
max_pending : Int,overflow : AsyncOverflowPolicy,max_batch : Int,linger_ms : Int, andflush : AsyncFlushPolicy. - The public
src-asyncsurface forwards this alias directly from@utils.AsyncLoggerConfig, so constructor, parser, export, and stringify helpers all operate on one shared underlying config model. AsyncLoggerConfig::new(...)normalizesmax_batchandlinger_ms, but it preserves the providedmax_pendingvalue.- Runtime queue creation later interprets negative
max_pendingas0when choosing the internal queue kind. parse_async_logger_config_text(...),async_logger_config_to_json(...), andstringify_async_logger_config(...)all operate on this same public config shape.- The parser accepts the stable serialized labels such as
DropNewestandNever, plus compatibility aliases such asDropLatestandNone.
How to Use
Here are some specific examples provided.
When Need A Typed Async Runtime Policy Value
When async queue and flush behavior should be passed around as structured config:
let config : AsyncLoggerConfig = AsyncLoggerConfig::new(
max_pending=64,
overflow=AsyncOverflowPolicy::DropOldest,
)In this example, async policy remains a typed object instead of immediately becoming JSON text or a logger instance.
When Need To Inspect The Config Before Building
When one layer should read or adjust async policy before logger construction:
let config = AsyncLoggerConfig::new(max_batch=4, linger_ms=20)
println(stringify_async_logger_config(config, pretty=true))In this example, the same public config object supports both inspection and later build steps.
Error Case
e.g.:
AsyncLoggerConfigitself does not have a runtime failure mode.Constructor normalization still applies when the value is created through
AsyncLoggerConfig::new(...), so very small batch sizes and negative linger values may be adjusted before later serialization or use.Negative
max_pendingis not rewritten inside the config object itself; it is only clamped later when the async queue kind is derived at runtime.
Notes
Use
AsyncLoggerConfig::new(...)when you need a value of this type in code.Use
AsyncLoggerBuildConfigwhen the async config should travel together with the base synchronousLoggerConfig.Use
parse_async_logger_config_text(...)when the same shape should come from JSON text, including accepted aliases likeDropLatestandNone.