Exporting metrics, logs, and traces.
Kalix supports exporting metrics, logs, and traces to a variety of different destinations for reporting, long term storage and alerting. Metrics, logs, and traces can either by exported to the same location, by configuring a default exporter, or to different locations by configuring separate logging, metrics, and tracing exporters. Only one exporter for each may be configured.
Observability configuration is configured per Kalix project. All services in that project will use the same observability config. Configuration can either be done by specifying an observability descriptor, or by running CLI commands.
When updating observability configuration, the changes will not take effect until a service is restarted.
Working with observability descriptors
The Kalix observability descriptor allows observability export configuration to be specified in a YAML file, for versioning and reuse across projects and environments.
Exporting the observability configuration
To export the current configuration, run:
akka project observability exportThis will write the observability YAML descriptor out to standard out. If preferred, the -f argument can be used to specify a file to write the descriptor out to.
Updating the observability configuration
To update the current configuration, run:
akka project observability apply -f observability.yamlWhere observability.yaml is the path to the YAML descriptor.
Editing the observability configuration in place
If you just want to edit the observability configuration for your project, without exporting and then applying it again, run:
akka project observability editThis will open the observability descriptor in a text editor. After saving and exiting the editor, the saved descriptor will be used to update the configuration.
| After updating your observability configuration, you will need to restart a service to apply the new configuration. Kalix automatically makes that a rolling restart. | 
Activating tracing
The generation of traces is disabled by default. To enable it you need to set telemetry/tracing/enabled to true. Like the following:
name: <<service-name>>
service:
  telemetry:
    tracing:
      enabled: true
  image: <<docker-image>>Once this is set, Kalix will start generating spans for the following components: Event Sourced Entities, Value Entities, Actions, and Views. In addition, a View or an Action that subscribes to an Entity will receive the traces from that Entity and create a span related to the previous trace.
Another possible use is to add a traceparent header when calling your Kalix endpoint. In this case Kalix will propagate this trace parent as the root of the subsequent interaction with a Kalix component. Linking each Kalix call to that external trace parent.
Setting sampling
By default, Kalix filters your traces. You’ll get 1% of the traces produced by your services. You can adjust this percentage according to your needs. Based on the TraceID, 99% of the traces will be filtered and won’t be exported to the endpoint you have configured. By default traces are sent to the Control Tower found in your Kalix Console.
This filtering is known as head sampling. To configure it, you need to set your observability descriptor as follows:
traces:
  probabilistic:
    percentage: "2"With this configuration, 2% of the traces are sent while the 98% are filtered. For more considerations on how much sampling is appropriate, see the OpenTelemetry documentation.
Activating the heap dump extension (Beta)
Kalix supports an OpenTelemetry extension that aggregates heap dumps in out of memory scenarios and uploads these to an AWS S3 bucket. Configuring this extension requires providing an AWS S3 bucket in the region where the Kalix service runs, and configure credentials to access it. The credentials must be stored in a Kalix secret and referenced in the observability descriptor (see Manage secrets).
The heap dump extension is disabled by default. To enable it, update the observability descriptor as follows:
# other configurations removed for brevity
heapDump:
  aws:
    bucket: heapdump-bucket
    region: us-east-2
    credentialsSecretRef:
      awsAccessKeyId:
        name: aws-credentials
        key: awsAccessKeyId
      awsSecretAccessKey:
        name: aws-credentials
        key: awsSecretAccessKeyOnce Kalix sees that the heap dump extension is enabled, it will start generating heap dumps on out of memory errors and sending them to the S3 bucket you have configured.
Updating the configuration using commands
The Kalix observability configuration can also be updated using commands. To view a human readable summary of the observability configuration, run:
akka project observability getTo change configuration, the set command can be used. To change the default exporter for both logs and metrics, use set default, to change the exporter just for metrics, use set metrics, and to change the exporter just for logs, use set logs.
When using the set command, the default, logs or metrics exporter configuration will be completely replaced. So, it’s important to include the full configuration for that exporter when you run the command. For example, if you run akka project observability set default otlp --endpoint otlp.example.com:4317, and then you want to add a header, you must include the --endpoint flag when setting the header.
Supported exporters
Kalix supports a number of different destinations to export metrics, logs, and traces to. The example commands and configuration below will show configuring the default exporter, if the exporter supports metrics, logs, and traces, or the metrics, logs, or traces as applicable if not.
Kalix Console
The Kalix Console is the default destination for metrics and traces. It provides a built in, short term time series database for limited dashboards displayed in the Kalix Console. To configure it:
- Descriptor
- 
default: kalixConsole: {}
- CLI
- 
akka project observability set default kalix-console
OTLP
OTLP is the gRPC based protocol used by OpenTelemetry. It is supported for logs, metrics, and traces. The primary piece of configuration it needs is an endpoint. For example:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4317
- CLI
- 
akka project observability set default otlp --endpoint otlp.example.com:4317
In addition, the OTLP exporter supports TLS configuration and custom headers. A full reference of configuration options is available in the reference documentation.
Prometheus Remote Write
The Prometheus remote write protocol is supported for exporting metrics. It is generally used to write metrics into Cortex and similar long term metrics databases for Prometheus. The primary piece of configuration it needs is an endpoint. For example:
- Descriptor
- 
metrics: prometheuswrite: endpoint: https://prometheus.example.com/api/v1/push
- CLI
- 
akka project observability set metrics prometheus --endpoint https://prometheus.example.com/api/v1/push
In addition, the Prometheus exporter supports TLS configuration and custom headers. A full reference of configuration options is available in the reference documentation.
Splunk HEC
The Splunk HTTP Event Collector protocol is supported for exporting both metrics and logs. It is used to export to the Splunk platform. It needs an endpoint and a splunk token. The Splunk token must be configured as a Kalix secret, which then gets referenced from the observability configuration.
- Descriptor
- 
default: splunkHec: endpoint: https://<my-trial-instance>.splunkcloud.com:8088/services/collector tokenSecret: name: my-splunk-token key: token
- CLI
- 
akka project observability set default splunk-hec \ --endpoint https://<my-trial-instance>.splunkcloud.com:8088/services/collector \ --token-secret-name my-splunk-token --token-secret-key token
In addition, the Splunk HEC exporter supports TLS configuration. A full reference of configuration options is available in the reference documentation.
Google Cloud
Google Cloud is supported for exporting logs, metrics, and traces. The primary piece of configuration it needs is a service account JSON key. The service account that the key is for must have the following IAM roles:
- 
If exporting metrics to Google Cloud, it must have the roles/monitoring.metricWriterrole.
- 
If exporting logs to Google Cloud, it must have the roles/logging.logWriterrole.
To create such a service account and key using the gcloud command, assuming you are logged in and have a Google project configured:
- 
Create a service account. In this example, we’ll call it kalix-exporter.gcloud iam service-accounts create kalix-exporter
- 
Grant the metrics and logging roles, as required, to your service account. Substitute your project ID for <gcp-project-id>.gcloud projects add-iam-policy-binding <gcp-project-id> \ --member "serviceAccount:kalix-exporter@<gcp-project-id>.iam.gserviceaccount.com" \ --role "roles/monitoring.metricWriter" gcloud projects add-iam-policy-binding <gcp-project-id> \ --member "serviceAccount:kalix-exporter@<gcp-project-id>.iam.gserviceaccount.com" \ --role "roles/logging.logWriter"
- 
Generate a key file for your service account, we’ll place it into a file called key.json.gcloud iam service-accounts keys create key.json \ --iam-account kalix-exporter@<gcp-project-id>.iam.gserviceaccount.com
- 
Place the key file in a Kalix secret, we’ll call the secret gcp-credentials. The key for key file must bekey.json.akka secret create generic gcp-credentials \ --from-file key.json=key.json
Now that you have configured service account, granted it the necessary roles, created a service account key and placed it into a Kalix secret, you can now configure your observability configuration to export to Google Cloud:
- Descriptor
- 
default: googleCloud: serviceAccountSecret: name: gcp-credentials
- CLI
- 
akka project observability set default google-cloud --service-account-key-secret gcp-credentials
Common exporter configuration
TLS configuration
TLS configuration for multiple different exporters can be configured. To turn off TLS altogether, the insecure property can be set to true:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 tls: insecure: true
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 --insecure
To skip verifying server certificates, use insecure skip verify:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 tls: insecureSkipVerify: true
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 --insecure-skip-verify
To specify a custom CA to verify server certificates, use the server CA property, pointing to a Kalix CA secret:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 tls: caSecret: name: my-ca
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 --server-ca-secret my-ca
To specify a client certificate to use to authenticate with a remote server, you can use the client certificate property, pointing to a Kalix TLS secret:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 tls: clientCertSecret: name: my-client-certificate
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 \ --client-cert-secret my-client-certificate
Custom headers
Custom headers may be configured for a number of exporters. Headers can either have static values, configured directly in the observability configuration, or they can reference secrets.
To specify a static header:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 headers: - name: X-My-Header value: some-value
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 \ --header X-My-Header=some-value
To set a header value from a secret:
- Descriptor
- 
default: otlp: endpoint: otlp.example.com:4137 headers: - name: X-Token valueFrom: secretKeyRef: name: my-token key: token
- CLI
- 
akka project observability set default otlp \ --endpoint otlp.example.com:4137 \ --header-secret X-Token=my-token/token
Debugging observability configuration
After updating your observability configuration, you will need to restart a service to use it. This can be done by running the akka service restart command. Once the service has been restarted, if there are any issues, you can check the observability agent logs, by running the following command:
akka logs <service-name> --instance=false --observabilityThis will show the observability agent logs for all instances of the service. Any errors that the agent encountered will be displayed here.