Thanos
Thanos is a group of components that seamlessly integrate with Prometheus to monitor your applications. You can enable and configure Thanos components with Verrazzano and use long-term storage to store metrics. By using the Thanos console, you can query for metrics across all Prometheus instances and long-term storage. Thanos also makes it easier to scale Prometheus horizontally and obtain a global view of data from multiple Prometheus servers.
Advantages of using Thanos:
- Long-term metrics retention
- High availability
- Easy backup for metrics
- Efficient data access
For more information on Thanos, see the Thanos website.
Thanos components
Verrazzano currently supports the following Thanos components:
Components | Description |
---|---|
Sidecar | Container that resides in the Prometheus pod. It connects to Prometheus, reads its data for queries, and uploads it to long-term storage. |
Store Gateway | Serves metrics from long-term storage. |
Query | Implements the Prometheus API to aggregate data from the underlying components and provides a user interface for querying across all Prometheus stores. |
Query Frontend | Implements the Prometheus API and proxies it to Query while caching the response and optionally, splitting queries. |
Verrazzano installs these Thanos components using a Helm chart. You can customize the installation configuration using Helm overrides specified in the Verrazzano custom resource.
Enable Thanos
To enable Thanos in Verrazzano, add the following:
apiVersion: install.verrazzano.io/v1beta1
kind: Verrazzano
metadata:
name: example-verrazzano
spec:
components:
prometheusOperator:
enabled: true
overrides:
- values:
prometheus:
thanos:
integration: sidecar
thanos:
enabled: true
Enable long-term storage using OCI Object Storage
Optionally, you can configure Thanos to use OCI Object Storage for long-term storage of metrics.
To enable this behavior complete the following steps:
Step 1: Create a YAML configuration file
Create a local file named storage.yaml
that identifies your OCI Object Storage bucket name, the region and compartment
where it is located within your OCI tenancy, and a valid set of credentials for Thanos to use when accessing it.
type: OCI
config:
provider: "raw"
bucket: "thanos"
compartment_ocid: "ocid1.compartment.oc1....."
region: "us-ashburn-1"
tenancy_ocid: "ocid1.tenancy.oc1....."
user_ocid: "ocid1.user.oc1....."
fingerprint: "12:d3:4c:..."
privatekey: |
-----BEGIN RSA PRIVATE KEY-----
...
-----END RSA PRIVATE KEY-----
The OCI provider for Thanos object storage supports API signing keys, instance principal, and OKE workload identity authentication. For more information on configuring OCI Object Storage in Thanos, see Oracle Cloud Infrastructure Object Storage.
Step 2: Create a secret
Create the secret for object storage configuration using the storage.yaml
file you created in Step 1.
The Thanos Store Gateway requires the key in the secret to be objstore.yml
.
$ kubectl create namespace verrazzano-monitoring
$ kubectl create secret generic objstore-config -n verrazzano-monitoring --from-file=objstore.yml=storage.yaml
Step 3: Enable storage and Thanos Store Gateway
The following example enables storage, creates the required secret, and enables Thanos Store Gateway in the Verrazzano custom resource. It also configures the Thanos Sidecar to write to object storage and the Store Gateway to read from object storage.
Note: objstore-config
is the secret that you created in Step 2.
apiVersion: install.verrazzano.io/v1beta1
kind: Verrazzano
metadata:
name: example-verrazzano
spec:
components:
prometheusOperator:
enabled: true
overrides:
- values:
prometheus:
thanos:
integration: sidecar
prometheusSpec:
thanos:
objectStorageConfig:
name: objstore-config
key: objstore.yml
thanos:
enabled: true
overrides:
- values:
existingObjstoreSecret: objstore-config
storegateway:
enabled: true
Access the Thanos Query console
You can access the Thanos Query console using the instructions at Get the consoles URLs.
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.