Tail Workers
BetaA Tail Worker receives information about the execution of other Workers (known as producer Workers), such as HTTP statuses, data passed to console.log()
or uncaught exceptions. Tail Workers can process logs for alerts, debugging, or analytics.
Tail Workers are available to all customers on the Workers Paid and Enterprise tiers. Tail Workers are billed by CPU time, not by the number of requests.
A Tail Worker is automatically invoked after the invocation of a producer Worker (the Worker the Tail Worker will track) that contains the application logic. It captures events after the producer has finished executing. Events throughout the request lifecycle, including potential sub-requests via Service Bindings and Dynamic Dispatch, will be included. You can filter, change the format of the data, and send events to any HTTP endpoint. For quick debugging, Tail Workers can be used to send logs to KV or any database.
To configure a Tail Worker:
- Create a Worker to serve as the Tail Worker.
- Add a
tail()
handler to your Worker. Thetail()
handler is invoked every time the producer Worker a Tail Worker is connected to is invoked. The following Worker code is a Tail Worker that sends its data to an HTTP endpoint:
The following Worker code is an example of what the events
object may look like:
- Add the following to the
wrangler.toml
file of the producer Worker:
tail()
Handler API docs - Learn how to set up atail()
handler in your Worker.
- Errors and exceptions - Review common Workers errors.
- Local development and testing - Develop and test you Workers locally.
- Source maps and stack traces - Learn how to enable source maps and generate stack traces for Workers.