R2 Object Storage
In the following sections, we will give you some details about how to configure R2 with Regional Services and Customer Metadata Boundary.
To configure Regional Services for hostnames proxied through Cloudflare and ensure that processing of requesting objects from a R2 Bucket occurs only in-region, follow these steps:
- Log in to the Cloudflare dashboard ↗, and select an account.
- Go to the R2 tab.
- Follow the steps to create a Bucket.
- Connect a bucket to a custom domain.
- Run the API POST command on the configured bucket custom domain to create a regional_hostnameswith a specific region.
Regional Services only applies to the custom domain configured for an R2 Bucket.
The following instructions will show you how to set up a Logpush job using an S3-compatible endpoint to store logs in an R2 bucket in the jurisdiction of your choice.
- 
Create an R2 bucket in your Cloudflare account and select the jurisdiction you would like to use. 
- 
Generate an API token for your R2 bucket. You have the following two options: 
Generate a token for a specific bucket (recommended)
 Go to the R2 section of your Cloudflare dashboard and select Manage R2 API Tokens to generate a token directly tied to your specific bucket. You can follow the instructions in the Authentication section.
Generate a token for all buckets
 You can generate a API token in Manage Account > Account API Tokens or you can create a user-specific token:
- Go to My Profile > API Tokens
- Select Create Token > Create Custom Token
- Choose Account > Workers R2 Storage > Edit to set permissions.
- To test your token, copy the curlcommand and paste it into a terminal.
curl "https://api.cloudflare.com/client/v4/user/tokens/verify" \--header "Authorization: Bearer <API_TOKEN>"The result:
{  "result": {    "id": "325xxxxcd",    "status": "active"  },  "success": true,  "errors": [],  "messages": [    {      "code": 10000,      "message": "This API Token is valid and active",      "type": null    }  ]}- Generate a SHA-256 hash of the token:
echo -n "<token>" | shasum -a 256This command will output a hash similar to dxxxx391b.
- Set up a Logpush destination using S3-compatible endpoint and fill in the following fields:
- Bucket: Enter the name of the R2 bucket you created with the jurisdiction you would like to use.
- Path (optional): If you want, you can specify a folder path to organize your logs.
- Endpoint URL: Provide the S3 API endpoint for your bucket in the format <account-id>.eu.r2.cloudflarestorage.com. Do not include the bucket name, as it was set in the first field.
- Bucket Region: For instance, use WEURto specify the EU region.
- Access Key ID: Enter the Token ID created previously (325xxxxcd).
- Secret Access Key: Use the SHA-256 hash of the token (dxxxx391b).
Complete the configuration by selecting the fields you want to push to your R2 bucket.
With Customer Metadata Boundary set to EU, R2 > Bucket > Metrics tab in the account dashboard will be populated.
Refer to the R2 documentation for more information.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- 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