ABV’s client SDKs and integrations are all designed to queue and batch requests in the background to optimize API calls and network time. Batches are determined by a combination of time and size (number of events and size of batch).Documentation Index
Fetch the complete documentation index at: https://docs.abv.dev/llms.txt
Use this file to discover all available pages before exploring further.
Configuration
All integrations have a sensible default configuration, but you can customize the batching behaviour to suit your needs.| Option (Python) [SDK constructor, Environment] | Option (JS) | Description |
|---|---|---|
flush_at, ABV_FLUSH_AT | flushAt | The maximum number of events to batch up before sending. |
flush_interval, ABV_FLUSH_INTERVAL (s) | flushInterval (ms) | The maximum time to wait before sending a batch. |
flushAt=1 to send every event immediately, or flushInterval=1000 to send every second.
Manual flushing
This is especially relevant for short-lived applications like serverless functions. If you do not flush the client, you may lose events.
flush method on the client. In case of network issues, flush will log an error and retry the batch, it will never throw an exception.
Python SDK
Install packageshutdown method to make sure all requests are flushed and pending requests are awaited before the process exits. On success of this function, no more events will be sent to ABV API.
JS/TS SDK
Install packages.env file in your project root and a package like dotenv to load the variables.
.env
instrumentation.ts file and use dotenv package to load the variables.
Additional parameters are provided to get trace visible in the UI immediately.
instrumentation.ts
instrumentation.ts file at the top of your application.
The ABVSpanProcessor buffers events and sends them in batches, so a final flush ensures no data is lost.
You can export the processor from your OTEL SDK setup file.
instrumentation.ts
handler.ts