Skip to content

API usage examples

Common operations for the Aerospike Backup Service (ABS) REST API, with example requests and responses. See the REST API specification for request and response schemas.

Backup

Use backup endpoints to trigger scheduled or on-demand backup operations for your routines, monitor backups that are currently running, and cancel jobs if needed. Routines themselves are defined in your configuration file.

These endpoints use the same ABS authentication and authorization settings as other ABS API endpoints.

Trigger an on-demand full backup

Starts a full backup for the specified routine, ignoring any configured schedule.

Request:

  • ROUTINE_NAME: Backup routine name.
  • delay (optional): Delay in milliseconds before the backup starts.
POST BASE_URL/v1/backups/full/ROUTINE_NAME?delay=DELAY_MS

Response:

  • 202 Accepted

Trigger an on-demand incremental backup

Starts an incremental backup for the specified routine, ignoring any configured schedule. The routine determines which namespace and optional set filters are backed up.

Request:

  • ROUTINE_NAME: Backup routine name.
  • delay (optional): Delay in milliseconds before the backup starts.
POST BASE_URL/v1/backups/incremental/ROUTINE_NAME

Example with 1000 ms delay:

POST BASE_URL/v1/backups/incremental/ROUTINE_NAME?delay=1000

Response:

  • 202 Accepted

Trigger a backup routine (deprecated)

POST /v1/backups/schedule/ROUTINE_NAME is deprecated, but still supported for backward compatibility. It triggers a full backup and accepts the same optional delay query parameter.

Cancel all jobs for a backup routine

Cancels any running full and incremental backups for the specified routine and deletes any partially created backups.

Request:

  • ROUTINE_NAME: Backup routine name.
POST BASE_URL/v1/backups/cancel/ROUTINE_NAME

Response:

  • 202 Accepted

Get information about a running backup

Shows information about currently running backups for a specific backup routine, including number of records completed, start time, progress toward completion, and estimated end time.

Request:

  • ROUTINE_NAME: Backup routine name.
GET BASE_URL/v1/backups/currentBackup/ROUTINE_NAME

Response:

Example

The following example response shows two backups in progress, one full and one incremental.

{
"full": {
"total-records": 100000,
"done-records": 50000,
"start-time": "2024-01-01T12:00:00Z",
"percentage-done": 50,
"estimated-end-time": "2024-01-01T13:00:00Z",
"metrics": {
"records-per-second": 1000,
"kilobytes-per-second": 30000,
"pipeline": 0
}
},
"incremental": {
"total-records": 20000,
"done-records": 15000,
"start-time": "2024-01-01T12:30:00Z",
"percentage-done": 75,
"estimated-end-time": "2024-01-01T12:40:00Z",
"metrics": {
"records-per-second": 1000,
"kilobytes-per-second": 30000,
"pipeline": 0
}
}
}

Retrieve full backup list

Lists backups for each configured routine, including details such as creation time, namespace, and storage location.

Request:

  • from (optional): Lower bound timestamp filter in milliseconds since epoch.
  • to (optional): Upper bound timestamp filter in milliseconds since epoch.
GET BASE_URL/v1/backups/full

Response:

Example
{
"routine1": [
{
"created": "2024-01-01T12:00:00Z",
"timestamp": 1704110400000,
"finished": "2024-01-01T12:05:00Z",
"duration": 300,
"from": "0001-01-01T00:00:00Z",
"namespace": "source-ns1",
"record-count": 42,
"byte-count": 480000,
"file-count": 1,
"secondary-index-count": 5,
"udf-count": 1,
"key": "routine1/backup/1704110400000/source-ns1",
"storage": {
"s3-storage": {
"bucket": "as-backup-bucket",
"path": "backups",
"s3-region": "eu-central-1"
}
},
"compression": "ZSTD",
"encryption": "NONE"
}
]
}

Restore

Use restore endpoints to recover data from a backup. You can restore from a specific backup path or from a point in time, which automatically combines the most recent full backup with any subsequent incremental backups. Restores run asynchronously and return a job ID that you can use to track progress.

Direct restore using a specific backup

The destination field specifies where to restore data. It can be one of the clusters from Get cluster configuration or any other Aerospike Database cluster.

This request restores a backup from a specified path to a designated destination. The no-generation parameter allows overwriting of existing keys if set to true.

The source section matches the storage field of a backup returned from Retrieve full backup list. Copy the key field from the backup into the backup-data-path field.

Request:

POST BASE_URL/v1/restore/full

Request body:

{
"destination": {
"seed-nodes": [
{
"host-name": "localhost",
"port": 3000
}
],
"credentials": {
"user": "user",
"password": "password"
}
},
"policy": {
"no-generation": true
},
"source": {
"s3-storage": {
"bucket": "as-backup-bucket",
"path": "backups",
"s3-region": "eu-central-1"
}
},
"backup-data-path": "routine1/backup/1704110400000/source-ns1"
}

The response is a job ID. You can get the status of this job with the endpoint GET BASE_URL/v1/restore/status/:JOB_ID.

123456789

Restore using routine name and timestamp

Restores the most recent full backup before the given timestamp and then applies all subsequent incremental backups up to that timestamp.

Request body fields:

  • Required:
    • routine: Routine name.
    • time: Timestamp in milliseconds since epoch.
  • Optional:
    • destination-name: Destination cluster name. If omitted, restores to the routine’s source cluster.
    • destination: Inline destination cluster configuration (alternative to destination-name).
    • policy: Restore policy overrides (if omitted, defaults are used).

Request:

POST BASE_URL/v1/restore/timestamp

Minimal request body:

{
"routine": "routine1",
"time": 1710671632452
}

The response is a job ID. You can get job status with the endpoint GET BASE_URL/v1/restore/status/:JOB_ID.

123456789

Show all restore jobs

Lists all restore jobs, with optional filtering by time range and status.

Request:

GET BASE_URL/v1/restore/jobs?from=FROM&to=TO&status=STATUS
  • from: Lower bound timestamp filter in milliseconds since epoch.
  • to: Upper bound timestamp filter in milliseconds since epoch.
  • status: Comma-separated status filter.
    • Possible statuses: Running, Done, Failed, and Canceled.
    • Use the ! prefix to exclude one or more statuses, such as !Failed,Canceled.

Response:

Example
{
"12345678": {
"read-records": 100000,
"total-bytes": 30000000,
"expired-records": 0,
"skipped-records": 0,
"ignored-records": 0,
"inserted-records": 50000,
"existed-records": 0,
"fresher-records": 0,
"index-count": 4,
"udf-count": 1,
"errors-in-doubt": 0,
"current-job": {
"total-records": 100000,
"done-records": 50000,
"start-time": "2024-01-01T12:00:00Z",
"percentage-done": 50,
"estimated-end-time": "2024-01-01T13:00:00Z",
"metrics": {
"records-per-second": 1000,
"kilobytes-per-second": 30000,
"pipeline": 0
}
},
"status": "Running"
}
}

Read configurations

Verify settings or debug configuration issues with the following endpoints. They retrieve the service’s current configuration, including cluster definitions, backup routines, and storage destinations.

Get cluster configuration

Returns the configuration files of existing clusters, including the default cluster setup with seed nodes and credentials.

Request:

GET BASE_URL/v1/config/clusters

Response:

Example
{
"absDefaultCluster": {
"seed-nodes": [
{
"host-name": "host.docker.internal",
"port": 3000
}
],
"credentials": {
"user": "tester",
"password": "psw"
}
}
}

Get routine configuration

Retrieves all configured backup routines.

Request:

GET BASE_URL/v1/config/routines

Response:

Example
{
"routine1": {
"backup-policy": "defaultPolicy",
"source-cluster": "absDefaultCluster",
"storage": "local",
"interval-cron": "@yearly",
"namespaces": ["source-ns7"]
},
"routine2": {
"backup-policy": "defaultPolicy",
"source-cluster": "absDefaultCluster",
"storage": "local",
"interval-cron": "@yearly",
"namespaces": ["source-ns8"],
"set-list": ["backupSet"],
"bin-list": ["backupBin"]
}
}

Get storage configuration

Returns all the configured storage endpoints, including cloud storage endpoint information such as region and path, if applicable.

Request:

GET BASE_URL/v1/config/storage

Response:

Example
{
"local": {
"local-storage": {
"path": "./localStorage"
}
},
"minio": {
"s3-storage": {
"path": "storage1",
"bucket": "as-backup-bucket",
"s3-region": "eu-central-1",
"s3-profile": "minio",
"s3-endpoint-override": "http://host.docker.internal:9000"
}
}
}

System

Retrieve operational information about the service with the following system endpoints. Use these to perform health probes, check versions, and integrate with monitoring tools like Prometheus. See Monitoring for details on available metrics.

Get service version

Returns version information about the running Aerospike Backup Service instance.

Request:

GET {{BASE_URL}}/version

Response:

Example
{
"version": "3.5.0",
"build-time": "2026-01-15T10:30:00Z",
"commit": "abc123def456"
}
Feedback

Was this page helpful?

What type of feedback are you giving?

What would you like us to know?

+Capture screenshot

Can we reach out to you?