Files
BitLogger/docs/api/async-logger-with-context-fields.md
T
2026-05-12 13:51:08 +08:00

2.6 KiB

name, group, category, update-time, description, key-word
name group category update-time description key-word
async-logger-with-context-fields api async 20260512 Attach reusable structured fields to an async logger so every queued record inherits them.
async
logger
fields
public

Async-logger-with-context-fields

Bind shared structured fields to an async logger. This is the standard way to attach stable metadata such as service name, component, region, or subsystem identity without repeating them for every async log call.

Interface

pub fn[S] AsyncLogger::with_context_fields(
  self : AsyncLogger[S],
  fields : Array[@bitlogger.Field],
) -> AsyncLogger[S] {}

input

  • self : AsyncLogger[S] - Base async logger that should gain shared fields.
  • fields : Array[Field] - Structured fields that will be prepended to each emitted record.

output

  • AsyncLogger[S] - A new async logger carrying the shared field set.

Explanation

Detailed rules explaining key parameters and behaviors

  • Context fields are merged during log(...) before enqueue.
  • When a log call also passes per-record fields, the context fields are placed before those per-call fields.
  • This API returns a new logger value; it does not mutate the original async logger.
  • Unlike synchronous Logger::with_context_fields(...), this async variant stores fields directly on AsyncLogger instead of changing the visible sink type.

How to Use

Here are some specific examples provided.

When Need Stable Async Service Metadata

When every queued record should carry service-level metadata:

let logger = async_logger(console_sink(), target="billing")
  .with_context_fields([
    @bitlogger.field("service", "billing"),
    @bitlogger.field("region", "cn"),
  ])

In this example, both fields are attached before each record enters the queue.

When Build Child Async Loggers For Subsystems

When a subsystem has both a target and fixed fields:

let worker = async_logger(console_sink(), target="app")
  .child("worker")
  .with_context_fields([@bitlogger.field("component", "worker")])

In this example, target composition and field binding stay separate but work together cleanly.

Error Case

e.g.:

  • If fields is empty, the logger remains valid and just adds no extra metadata.

  • If duplicate field keys are provided, all fields are still emitted; conflict handling is left to the consumer side.

Notes

  1. Use this for stable metadata, not highly dynamic event-specific values.

  2. This async variant preserves the visible AsyncLogger[S] type while still injecting shared fields.