Synchronizing checkpoints to object store
Synchronizing checkpoints to object store is a highly experimental feature.
Feldera allows synchronizing pipeline checkpoints to an object store and restoring them at startup.
Storage configuration
Checkpoint sync is supported only with the file
backend and uses
rclone
under the hood to interact with S3-compatible
object stores.
Here is a sample configuration:
"storage": {
"backend": {
"name": "file",
"config": {
"sync": {
"bucket": "BUCKET_NAME/DIRECTORY_NAME",
"provider": "AWS",
"access_key": "ACCESS_KEY",
"secret_key": "SECRET_KEY",
"start_from_checkpoint": "latest",
"fail_if_no_checkpoint": false,
"standby": false,
"flags": ["--s3-server-side-encryption", "aws:kms"]
}
}
}
}
sync
configuration fields
Field | Type | Default | Description |
---|---|---|---|
endpoint | string | The S3-compatible object store endpoint (e.g., http://localhost:9000 for MinIO). | |
bucket * | string | The bucket name and optional prefix to store checkpoints (e.g., mybucket/checkpoints ). | |
region | string | us-east-1 | The region of the bucket. Leave empty for MinIO. If provider is AWS, and no region is specified, us-east-1 is used. |
provider * | string | The S3 provider identifier. Must match rclone’s list. Case-sensitive. Use "Other" if unsure. | |
access_key | string | S3 access key. Not required if using environment-based auth (e.g., IRSA). | |
secret_key | string | S3 secret key. Not required if using environment-based auth. | |
start_from_checkpoint | string | Checkpoint UUID to resume from, or latest to restore from the latest checkpoint. | |
fail_if_no_checkpoint | boolean | false | When true the pipeline will fail to initialize if fetching the specified checkpoint fails. When |
standby | boolean | false | When true , the pipeline starts in standby mode. To start processing the data the pipeline must be activated ( If a previously activated pipeline is restarted without clearing storage, it auto-activates. start_from_checkpoint must be set to use standby mode. |
pull_interval | integer(u64) | 10 | Interval (in seconds) between fetch attempts for the latest checkpoint while standby. |
transfers | integer (u8) | 20 | Number of concurrent file transfers. |
checkers | integer (u8) | 20 | Number of parallel checkers for verification. |
ignore_checksum | boolean | false | Skip checksum verification after transfer and only check the file size. Might improve throughput. |
multi_thread_streams | integer (u8) | 10 | Number of streams for multi-threaded downloads. |
multi_thread_cutoff | string | 100M | File size threshold to enable multi-threaded downloads (e.g., 100M , 1G ). Supported suffixes: k , M , G , T . |
upload_concurrency | integer (u8) | 10 | Number of concurrent chunks to upload during multipart uploads. |
flags | array[string] | Extra flags to pass to rclone .⚠️ Incorrect or conflicting flags may break behavior. See rclone flags and S3 flags. |
*Fields marked with an asterisk are required.
S3 permissions
The following minimum permissions are required to be available on the bucket being written to:
ListBucket
DeleteBucket
GetObject
PutObject
PutObjectACL
Example policy:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::USER_SID:user/USER_NAME"
},
"Action": [
"s3:ListBucket",
"s3:DeleteObject",
"s3:GetObject",
"s3:PutObject",
"s3:PutObjectAcl"
],
"Resource": [
"arn:aws:s3:::BUCKET_NAME/*",
"arn:aws:s3:::BUCKET_NAME"
]
},
{
"Effect": "Allow",
"Action": "s3:ListAllMyBuckets",
"Resource": "arn:aws:s3:::*"
}
]
}
For more details, refer to rclone S3 permissions.
IRSA
To use IRSA (IAM Roles for Service Accounts) omit fields access_key
and secret_key
. This loads credentials from the environment.
Standby mode
Pipelines can be configured to start in standby mode by setting standby
to
true. When in standby mode, the pipeline does not process any data but continuously
pulls the latest (or the checkpoint with the specified UUID based on start_from_checkpoint
)
checkpoint at the interval specified by pull_interval
.
Pipelines in standby mode must be explicitly activated via:
curl -X POST https://{FELDERA_HOST}/v0/pipelines/{PIPELINE_NAME}/activate
Pipelines that were previously activated, and have the storage intact will auto-activate from the latest local checkpoint. This is to avoid unintential behavior in case of the pipeline getting rescheduled or restarted.
Standby mode is incredibly useful to have a backup pipeline (B) ready to process data in case the primary pipeline (A) fails. Consider the following example. These are two pipelines running side by side: Pipeline A (Primary) actively processes data and creates checkpoints, while Pipeline B (Standby) stays in standby mode, pulling checkpoints and ready to activate if needed.
When Pipeline A fails, you can trigger Pipeline B to activate and start processing from the latest checkpoint (Checkpoint 2 in this case).
Time | Pipeline A (Primary) | Pipeline B (Standby) |
---|---|---|
Step 1 | Start | Standby Start |
Step 2 | Processing | Standby |
Step 3 | Checkpoint 1 | Standby |
Step 4 | Sync 1 to S3 | Standby |
Step 5 | Processing | Pulls Checkpoint 1 |
Step 6 | Checkpoint 2 | Standby |
Step 7 | Sync 2 to S3 | Standby |
Step 8 | Processing | Pulls Checkpoint 2 |
Step 9 | Failed | Standby |
Step 10 | Activate | |
Step 11 | Running From Checkpoint 2 |
Buckets with server side encryption
If the bucket has server side encryption enabled, set the flag
--s3-server-side-encryption
in the flags
field.
Example:
"sync": {
"bucket": "BUCKET_NAME/DIRECTORY_NAME",
"provider": "AWS",
"start_from_checkpoint": "latest",
"flags": ["--s3-server-side-encryption", "aws:kms"]
}
Performance
Sync performance may vary based on configuration and environment. In our testing, we observed the following average speeds:
Storage Type | Avg Upload Speed | Avg Download Speed | Avg Download Speed (Ignore Checksum) |
---|---|---|---|
GP3 | 650 MiB/s | 650 MiB/s | 850 MiB/s |
GP2 | 125 MiB/s | 125 MiB/s | 250 MiB/s |
NVMe | 1.5 GiB/s | 2.2 GiB/s | 2.3 GiB/s |
- GP3 was configured with throughput of 1000 MB/s, and IOPS of 10,000.
- GP2 has the max throughput of 250 MB/s.
- Both GP2 and GP3 can briefly hit maximum download speeds of around 1 GiB/s, but performance quickly drops off.
- NVMe speeds were tested on i4i.4xlarge instance type.
- Performance may improve by tuning sync parameters such as
transfers
,checkers
,upload_concurrency
etc.
Triggering a checkpoint sync
A sync operation can be trigged by making a POST
request to:
curl -X POST http://localhost/v0/pipelines/{PIPELINE_NAME}/checkpoint/sync
This initiates the sync and returns the UUID of the checkpoint being synced:
{"checkpoint_uuid":"019779b4-8760-75f2-bdf0-71b825e63610"}
Checking sync status
The status of the sync operation can be checked by making a GET
request to:
curl http://localhost/v0/pipelines/{PIPELINE_NAME}/checkpoint/sync_status
Response examples
In Progress:
{"success":null,"failure":null}
Success:
{"success":"019779b4-8760-75f2-bdf0-71b825e63610","failure":null}
Failure:
{
"success": null,
"failure": {
"uuid": "019779c1-8317-7a71-bd78-7b971f4a3c43",
"error": "Error pushing checkpoint to object store: ... SignatureDoesNotMatch ..."
}
}