Skip to content

Latest commit

 

History

History
112 lines (81 loc) · 4.97 KB

api.md

File metadata and controls

112 lines (81 loc) · 4.97 KB

SLO Generator API

Description

The SLO Generator API is based on the Functions Framework allowing deployments to hosted services easier, such as Kubernetes, CloudRun or Cloud Functions.

Standard mode API

In the standard mode, the slo-generator API takes SLO configs as inputs and export SLO reports using the default_exporters in the shared config, and the exporters section in the SLO config:

slo-generator api --config <CONFIG_PATH>

where:

The standard-mode API can receive HTTP POST requests containing an SLO config, an SLO config path, or a SLO config GCS URL in the request body:

curl -X POST --data-binary /path/to/slo_config.yaml <SERVICE_URL> # SLO config (YAML)
curl -X POST -d @/path/to/slo_config.json <SERVICE_URL>  # SLO config (JSON)
curl -X POST -d "/path/to/slo_config.yaml" <SERVICE_URL> # SLO config path on disk (service needs to be able to load the path on the target machine).
curl -X POST -d "gs://<GCS_BUCKET_NAME>/slo.yaml" <SERVICE_URL> # SLO config GCS URL.

The API also has a batch mode that can be used by calling the endpoint with ?batch=true:

curl -X POST -d "gs://<GCS_BUCKET_NAME>/slo.yaml;gs://GCS_BUCKET_NAME/slo2.yaml" <SERVICE_URL>/?batch=true # SLO configs GCS URLs (batch mode).

Batch mode allows to send multiple file URLs that will be split and:

  • Send each URL as individual HTTP requests (one per URL) to the service (default).

or

  • Send each URL to PubSub if the section pubsub_batch_handler exists in the slo-generator config. This section is populated the same as a pubsub exporter. This setup is useful to smooth big loads (many SLOs), setting up a Pubsub push subscription back to the service.

Export-only mode API

Some use cases require to have a distinct service for the export part. For instance, some SRE teams might want to let application teams compute their SLOs, but require them to export the SLO reports to a shared destination like BigQuery:

arch

It is possible to run the slo-generator API in export mode only, by setting the --target run_export:

slo-generator api --config /path/to/config.yaml --target run_export

In this mode, the API accepts an SLO report in the POST request or in a base64-encoded string under the message.data enveloppe., and exports that data to the required exporters.

If --signature-type cloudevent is passed, the POST request data needs to be wrapped into a CloudEvent message under the data key. See the next section to see in which setups this is used.

The exporters which are used for the export are configured using the default_exporters property in the slo-generator configuration.

Sending data from a standard API to an export-only API

There are two ways you can forward SLO reports from the standard slo-generator API to an export-only API:

  • If the export-only API is configured with --signature-type http (default), then you can:

    • Set up a Pubsub exporter in the standard API shared config to send the SLO reports to a Pubsub topic, and set up a Pubsub push subscription configured with the export-only API service URL. See official documentation.
    • [not implemented yet] Set up an HTTP exporter in the standard API shared config to send the reports.
  • If the export-only API is configured with --signature-type cloudevent, then you can:

    • Set up a Cloudevent exporter in the standard API shared config to send the events directly to the export-only API. See cloudevent exporter documentation.

    • Set up a Pubsub exporter in the standard API shared config to send the events to a Pubsub topic, and set up an EventArc to convert the Pubsub messages to CloudEvent format. See official documentation.

Notes:

  • Using a queue like Pubsub as an intermediary between the standard service and the export-only service is a good way to spread the load over time if you are dealing with lots of SLO computations.

  • You can develop your own Cloudevent receivers to use with the Cloudevent exporter if you want to do additional processing / analysis of SLO reports. An example code for a Cloudevent receiver is given here, but you can also check out the Functions Framework that does the marshalling / unmarshalling of Cloudevents out-of-the-box.