Skip to content
Cloudflare Docs

Manage catalogs

Learn how to:

  • Enable and disable R2 Data Catalog on your buckets.
  • Authenticate Iceberg engines using API tokens.

Enable R2 Data Catalog on a bucket

Enabling the catalog on a bucket turns on the REST catalog interface and provides a Catalog URI and Warehouse name required by Iceberg clients. Once enabled, you can create and manage Iceberg tables in that bucket.

  1. In the Cloudflare dashboard, go to the R2 object storage page.

    Go to Overview
  2. Select the bucket you want to enable as a data catalog.

  3. Switch to the Settings tab, scroll down to R2 Data Catalog, and select Enable.

  4. Once enabled, note the Catalog URI and Warehouse name.

Disable R2 Data Catalog on a bucket

When you disable the catalog on a bucket, it immediately stops serving requests from the catalog interface. Any Iceberg table references stored in that catalog become inaccessible until you re-enable it.

  1. In the Cloudflare dashboard, go to the R2 object storage page.

    Go to Overview
  2. Select the bucket where you want to disable the data catalog.

  3. Switch to the Settings tab, scroll down to R2 Data Catalog, and select Disable.

Enable compaction

Compaction improves query performance by combining the many small files created during data ingestion into fewer, larger files according to the set target file size. For more information about compaction and why it's valuable, refer to About compaction.

  1. In the Cloudflare dashboard, go to the R2 object storage page.

    Go to Overview
  2. Select the bucket you want to enable compaction on.

  3. Switch to the Settings tab, scroll down to R2 Data Catalog, and click on the Edit icon next to the compaction card.

  4. Enable compaction and optionally set a target file size. The default is 128 MB.

  5. (Optional) Provide a Cloudflare API token for compaction to access and rewrite files in your bucket.

  6. Select Save.

Once enabled, compaction applies retroactively to all existing tables (for catalog-level compaction) or the specified table (for table-level compaction). During open beta, we currently compact up to 2 GB worth of files once per hour for each table.

Disable compaction

Disabling compaction will prevent the process from running for all tables (catalog level) or a specific table (table level). You can re-enable it at any time.

  1. In the Cloudflare dashboard, go to the R2 object storage page.

    Go to Overview
  2. Select the bucket you want to enable compaction on.

  3. Switch to the Settings tab, scroll down to R2 Data Catalog, and click on the edit icon next to the compaction card.

  4. Disable compaction.

  5. Select Save.

Authenticate your Iceberg engine

To connect your Iceberg engine to R2 Data Catalog, you must provide a Cloudflare API token with both R2 Data Catalog permissions and R2 storage permissions. Iceberg engines interact with R2 Data Catalog to perform table operations. The catalog also provides engines with SigV4 credentials, which are required to access the underlying data files stored in R2.

Create API token in the dashboard

Create an R2 API token with Admin Read & Write or Admin Read only permissions. These permissions include both:

  • Access to R2 Data Catalog (read-only or read/write, depending on chosen permission)
  • Access to R2 storage (read-only or read/write, depending on chosen permission)

Providing the resulting token value to your Iceberg engine gives it the ability to manage catalog metadata and handle data operations (reads or writes to R2).

Create API token via API

To create an API token programmatically for use with R2 Data Catalog, you'll need to specify both R2 Data Catalog and R2 storage permission groups in your Access Policy.

Example Access Policy

[
{
"id": "f267e341f3dd4697bd3b9f71dd96247f",
"effect": "allow",
"resources": {
"com.cloudflare.edge.r2.bucket.4793d734c0b8e484dfc37ec392b5fa8a_default_my-bucket": "*",
"com.cloudflare.edge.r2.bucket.4793d734c0b8e484dfc37ec392b5fa8a_eu_my-eu-bucket": "*"
},
"permission_groups": [
{
"id": "d229766a2f7f4d299f20eaa8c9b1fde9",
"name": "Workers R2 Data Catalog Write"
},
{
"id": "2efd5506f9c8494dacb1fa10a3e7d5b6",
"name": "Workers R2 Storage Bucket Item Write"
}
]
}
]

To learn more about how to create API tokens for R2 Data Catalog using the API, including required permission groups and usage examples, refer to the Create API tokens via API documentation.

Learn more