Send events¶
You send events to a data source using the Events API or the tb datasource append CLI command with the --events
flag.
Send JSON events¶
The following examples show how to append data via the Events API to a data source in Tinybird Cloud:
Sending batches of JSON events
curl \ -H "Authorization: Bearer <import_token>" \ -d $'{"date": "2020-04-05", "city": "Chicago"}\n{"date": "2020-04-05", "city": "Madrid"}\n' \ 'https://api.tinybird.co/v0/events?name=<data_source_name>'
Sending batches of events helps you achieve much higher total throughput than sending single events. You can send batches of JSON events to the Events API by formatting the events as NDJSON (newline delimited JSON). Each single JSON event must be separated by a newline \n
character.
Token¶
The token you use to send events must have the DATASOURCE:APPEND
scope.
Limits¶
The Events API delivers a default capacity of:
- Up to 100 requests per second per data source
- Up to 20 MB per second per data source
- Up to 10 MB per request per data source.
Rate limit headers¶
The Events API returns the following headers with the response:
Header Name | Description |
---|---|
X-RateLimit-Limit | The maximum number of requests you're permitted to make in the current limit window. |
X-RateLimit-Remaining | The number of requests remaining in the current rate limit window. |
X-RateLimit-Reset | The time in seconds after the current rate limit window resets. |
Retry-After | The time to wait before making a another request. Only present on 429 responses. |
Check the payload size¶
To avoid hitting the request limit size, you can check your payload size before sending. For example:
echo '{"date": "2020-04-05", "city": "Chicago"}' | wc -c | awk '{print $1/1024/1024 " MB"}'
Compress the data you send¶
You can compress the data you send to the Events API using Gzip. Compressing events adds overhead to the ingestion process, which can introduce latency, although it's typically minimal.
Here is an example of sending a JSON event compressed with Gzip from the command line:
echo '{"timestamp":"2022-10-27T11:43:02.099Z","transaction_id":"8d1e1533-6071-4b10-9cda-b8429c1c7a67","name":"Bobby Drake","email":"bobby.drake@pressure.io","age":42,"passport_number":3847665,"flight_from":"Barcelona","flight_to":"London","extra_bags":1,"flight_class":"economy","priority_boarding":false,"meal_choice":"vegetarian","seat_number":"15D","airline":"Red Balloon"}' | gzip > body.gz curl \ -X POST 'https://api.tinybird.co/v0/events?name=gzip_events_example' \ -H "Authorization: Bearer <AUTH_TOKEN>" \ -H "Content-Encoding: gzip" \ --data-binary @body.gz
Write operation acknowledgements¶
When you send data to the Events API, you usually receive an HTTP202
response, which indicates that the request was successful, although it doesn't confirm that the data has been committed into the underlying database. This is useful when guarantees on writes aren't strictly necessary.
Typically, it takes under two seconds to receive a response from the Events API. For example:
curl \ -X POST 'https://api.tinybird.co/v0/events?name=events_example' \ -H "Authorization: Bearer <AUTH_TOKEN>" \ -d $'{"timestamp":"2022-10-27T11:43:02.099Z"}' < HTTP/2 202 < content-type: application/json < content-length: 42 < {"successful_rows":2,"quarantined_rows":0}
If your use case requires absolute guarantees that data is committed, use the wait
parameter. The wait
parameter is a boolean that accepts a value of true
or false
. A value of false
is the default behavior, equivalent to omitting the parameter entirely.
Using wait=true
with your request asks the Events API to wait for acknowledgement that the data you sent has been committed into the underlying database. You then receive an HTTP200
response that confirms data has been committed.
Adding wait=true
to your request can result in a slower response time. Use a timeout of at least 10 seconds when waiting for the response. For example:
curl \ -X POST 'https://api.tinybird.co/v0/events?name=events_example&wait=true' \ -H "Authorization: Bearer <AUTH_TOKEN>" \ -d $'{"timestamp":"2022-10-27T11:43:02.099Z"}' < HTTP/2 200 < content-type: application/json < content-length: 42 < {"successful_rows":2,"quarantined_rows":0}
Log your requests and responses from and to the Events API. This helps you get visibility into any failures.