Tigris Global Object Storage
Tigris is a globally caching, S3-compatible object storage service built on Fly.io infrastructure.
Objects in Tigris are stored close to the region where they’re written. Then, when requested, objects are cached close to the requesting user. This cache is intelligently managed by Tigris based on global traffic patterns. This behavior offers CDN-like behavior with zero configuration required.
Learn more from their service overview and architecture docs.
Use Tigris with your framework
Language- and framework-specific guides for setting up Tigris:
Create and manage a Tigris storage bucket
Creating and managing storage buckets happens exclusively via the Fly CLI. Install it, then sign up for a Fly account.
Running the following command in a Fly.io app context – inside an app directory or specifying -a yourapp
– will automatically set secrets on your app.
fly storage create
? Select Organization: fly-ephemeral (fly-ephemeral)
? Choose a name, use the default, or leave blank to generate one:
Your project (summer-grass-2004) is ready.
Set one or more of the following secrets on your target app.
BUCKET_NAME: summer-grass-2004
AWS_ENDPOINT_URL_S3: https://fly.storage.tigris.dev
AWS_ACCESS_KEY_ID: tid_xxxxxx
AWS_SECRET_ACCESS_KEY: tsec_xxxxxx
Public buckets
By default, buckets are private. If you need to serve public assets like images or JavaScript files, create a public bucket:
fly storage create --public
You can also make a public bucket private.
fly storage update mybucket --private
Currently, buckets must be public or private. ACL settings will be ignored by the Tigris API.
Migrating to Tigris with shadow buckets
A shadow bucket is an existing S3 (or compatible) bucket, assigned to your Tigris bucket via flyctl
.
Shadow buckets enable transparent copying and writing of objects as they are requested or uploaded. This is helpful for a few scenarios, like:
- Avoiding egress fees from large data migrations
- Avoiding downtime by serving requests from Tigris while running a data migration
- Testing Tigris global cache performance
- Testing Tigris features with the option to switch back to your current provider
How shadow buckets work
Tigris follows this logic when a shadow bucket is set:
- If a requested object is present in Tigris, it’s served immediately
- If not present, Tigris fetches it from the shadow bucket and stores it in a region close to the requesting user
- Subsequent requests are served from Tigris and cached in the requesting user’s region
- Written objects are stored in Tigris close to the uploading user’s region
- Optionally, written objects are replicated to the shadow bucket
- Deleted objects are removed from both the Tigris and shadow bucket
Create a new bucket with a shadow bucket
You must specify all shadow bucket attributes, including the endpoint and region. Check your provider docs to find these values. Here’s the AWS S3 list of regions and endpoints.
flyctl storage create -n mybucket -o myorg --shadow-access-key 123 --shadow-secret-key abc --shadow-endpoint https://s3.us-east-1.amazonaws.com --shadow-region us-east-1 --shadow-write-through
Add or remove a shadow bucket on an existing Tigris bucket
You can also add and remove shadow buckets from existing Tigris buckets.
flyctl storage update mybucket --shadow-access-key 123 --shadow-secret-key abc --shadow-endpoint https://s3.us-east-1.amazonaws.com --shadow-region us-east-1
flyctl storage update mybucket --clear-shadow
shadow-write-through
ensures that writes to Tigris buckets are replicated to the shadow bucket.
The Tigris web console
To view more details about your buckets, sign in to the Tigris web console.
flyctl storage dashboard <bucket_name>
Or, visit your organization-level overview for billing and organization settings:
flyctl storage dashboard --org <org_name>
List your buckets
Get a list of all of your Tigris buckets.
flyctl storage list
NAME ORG
js-storage-1 fly-ephemeral
late-surf-5384 fly-ephemeral
Delete a Tigris bucket
Deleting can’t be undone. Empty buckets can’t be deleted without the --force
option.
fly storage destroy late-surf-5384
Destroying a Tigris bucket is not reversible.
? Destroy Tigris bucket late-surf-5384? Yes
Your Tigris bucket late-surf-5384 was destroyed
Pricing and Billing
Tigris buckets are billed by usage with no up-front costs. Check the official Tigris Pricing page for details. This pricing can change as data transfer costs are worked out between Fly.io and Tigris.
AWS API compatibility
Check out the Tigris docs on compatibility: https://www.tigrisdata.com/docs/api/s3
Tigris also supports the following:
- Pre-signed URLs for secure download and upload
- Setting HTTP headers on objects such as
Cache-Control