Storage Providers
To maintain control over your data and ensure high performance, utilize different storage providers to store router artifacts on Amazon S3, while still using our Cosmo Managed offering.
The router is a stateless component, allowing it to be scaled horizontally without requiring persistence. However, it needs to fetch the execution configuration from a storage source at startup and when new schema updates are published. This execution config provides the instructions for executing and planning GraphQL operations.
The same approach applies to persisted operations (PO), which manage an allowlist of permitted GraphQL operations that can execute against the router. The router must download these operations once before they can be executed.
For both mechanisms, different storage providers can be used:
CDN: The default provider that used by Cosmo Cloud.
Amazon S3: An object storage protocol. We support any S3 compatible object-storage e.g. Minio and AWS.
By removing the dependency on Cosmo Cloud, your router no longer rely on us for operations while still benefiting from all its features.
When using a custom storage provider, you are responsible for manually pushing those artifacts as part of your CI process. In the next section, we will explain how to do this:
Define a provider
Before you can use a storage provider, you have to define it in the storage_providers
section of your config.yaml
file.
secure has to be set to true
when you point to an S3 that uses https://
Execution config
After configuring the storage provider, you can use it by referencing it in the provider_id
field.
The object_path
field points to the file in your bucket that is updated after each schema deployment in your CI/CD pipeline. The following snippet illustrates how it could look like:
First, we publish our schema changes to Cosmo. After that, we will download the latest execution config and upload it your own S3 provider. The router will check for updates every 10 seconds (default) and hot-reload the router accordingly without impacting current user traffic.
Best Practices
Create different S3 credentials for READ and WRITE to reduce the attack surface.
Persisted Operations
After configuring the storage provider, you can use it by referencing it in the provider_id
field.
The object_prefix
field points to the location in the bucket where the persisted operations are uploaded. Each persisted operation needs to follow the naming convention: SHA256 of the file + .json
as filename extension. A persisted operation is a JSON document and must follow the following structure:
version
: The version of the persisted operation format.body
: The actual content of the persistent operation.
Example
Given the following persisted operation:
Upload the file to the bucket location as follow:
Now, you can make a persisted operation (PO) request against the router, and it will fetch the operation from your S3 and execute it. Subsequent requests are cached and won't add additional latency.
Best Practices
We can cache persisted operations effectively only by using an immutable filename, such as the SHA-256 hash of the file.
Last updated