Logs Engine
Logs Engine gives you the ability to store your logs in R2 and query them directly.
- Set up a Logpush to R2 job.
- Create an R2 access key with at least R2 read permissions.
- Ensure that you have Logshare read permissions.
- Alternatively, create a Cloudflare API token with the following permissions:
- Account scope
- Logs read permissions
 
You can use the API to query and download your logs by time range or RayID.
The following headers are required for all API calls:
- X-Auth-Email- the Cloudflare account email address associated with the domain
- X-Auth-Key- the Cloudflare API key
Alternatively, API tokens with Logs edit permissions can also be used for authentication:
- Authorization: Bearer <API_TOKEN>
In addition to the required authentication headers mentioned, the following headers are required for the API to access logs stored in your R2 bucket.
- R2-access-key-id(required) - R2 Access Key Id
- R2-secret-access-key(required) - R2 Secret Access Key
List relevant R2 objects containing logs matching the provided query parameters, using the endpoint GET /accounts/{accountId}/logs/list.
- 
start(required) string (TimestampRFC3339) - Start time in RFC 3339 format, for examplestart=2022-06-06T16:00:00Z.
- 
end(required) string (TimestampRFC3339) - End time in RFC 3339 format, for exampleend=2022-06-06T16:00:00Z.
- 
bucket(required) string (Bucket) - R2 bucket name, for examplebucket=cloudflare-logs.
- 
prefixstring (Prefix) - R2 bucket prefix logs are stored under, for exampleprefix=http_requests/example.com/{DATE}.
- 
limitnumber (Limit) - Maximum number of results to return, for examplelimit=100.
Stream logs stored in R2 that match the provided query parameters, using the endpoint GET /accounts/{accountId}/logs/retrieve.
- 
start(required) string (TimestampRFC3339) - Start time in RFC 3339 format, for examplestart=2022-06-06T16:00:00Z
- 
end(required) string (TimestampRFC3339) - End time in RFC 3339 format, for exampleend=2022-06-06T16:00:00Z
- 
bucket(required) string (Bucket) - R2 bucket name, for examplebucket=cloudflare-logs
- 
prefixstring (Prefix) - R2 bucket prefix logs are stored under, for exampleprefix=http_requests/example.com/{DATE}
curl --globoff "https://api.cloudflare.com/client/v4/accounts/{account_id}/logs/retrieve?start=2022-06-01T16:00:00Z&end=2022-06-01T16:05:00Z&bucket=cloudflare-logs&prefix=http_requests/example.com/{DATE}" \--header "X-Auth-Email: <EMAIL>" \--header "X-Auth-Key: <API_KEY>" \--header "R2-Access-Key-Id: R2_ACCESS_KEY_ID" \--header "R2-Secret-Access-Key: R2_SECRET_ACCESS_KEY"Results can be piped to a file using > logs.json.
Additionally, if you want to receive the raw GZIP bytes without them being transparently decompressed by your client, include the header --header "Accept-Encoding: gzip".
Using your logs stored in R2 - the Logpull RayID Lookup feature allows you to query an indexed time range for the presence of an RayID and return the matching result. This feature is available to users with the Logpull RayID Lookup beta subscription.
The ability to look up a RayID is a two-step process. First, a time range needs to be indexed before being able to request a record by the RayID.
Indexes will automatically expire after seven days of no usage.
Before executing your query, you can specify the time range you would like to index in order to narrow down the scope of the query. In the following example, we index one minute of logs stored in the R2 bucket "cloudflare-logs" under the prefix "http_requests/{DATE}".
curl https://api.cloudflare.com/client/v4/accounts/{account_id}/logs/rayids/index \--header "Authorization: Bearer <API_TOKEN>" \--header "R2-Access-Key-Id: <R2_ACCESS_KEY_ID>" \--header "R2-Secret-Access-Key: <R2_SECRET_ACCESS_KEY>" \--header "Content-Type: application/json" \--data-raw '{  "start": "2022-08-16T20:30:00Z",  "end": "2022-08-16T20:31:00",  "bucket": "cloudflare-logs",  "prefix": "http_requests/example.com/{DATE}"}'After indexing a time range, perform a GET request with the RayID. If a matching result is found in the indexed time range, the record will be returned. Note that the parameters have moved from the request body and into the URL. The -g flag is required to avoid the {DATE} parameter from being misinterpreted by cURL.
curl --globoff "https://api.cloudflare.com/client/v4/accounts/{account_id}/logs/rayids/<RAY_ID>?bucket=cloudflare-logs&prefix=http_requests/example.com/{DATE}" \--header "Authorization: Bearer <API_TOKEN>" \--header "R2-Access-Key-Id: <R2_ACCESS_KEY_ID>" \--header "R2-Secret-Access-Key: <R2_SECRET_ACCESS_KEY>"I am getting an error when accessing the API
 - Error: Time range returned too many results. Try reducing the time range and try again.
HTTP status code 422 will be returned if the time range between the start and end parameters is too wide. Try querying a shorter time range if you are running into this limit.
- Error: Provided token does not have the required features enabled.
Contact your account representative to have the beta Logpull RayID Lookup subscription added to your account.
- Error: Time range returned too many results. Try reducing the time range and try again.
High volume zones can produce many log files in R2. Try reducing your start and end time range until you find a duration that works best for your log volume.
How do I know what time range to index?
 Currently, there is no process to index logs as they arrive. If you have the RayID and know the time the request was made, try indexing the next 5-10 minutes of logs after the request was completed.
What is the time delay between when an event happens and when I can query for it?
 Logpush delivers logs in batches as soon as possible, generally in less than one minute. After this, logs can be accessed using Logs Engine.
Does R2 have retention controls?
 R2 does not currently have retention controls in place. You can query back as far as when you created the Logpush job.
Which datasets is Logs Engine compatible with?
 The retrieval API is compatible with all the datasets we support. The full list is available on the Datasets section.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark
-