Google GKE uses Google Cloud Operations to view metric data. In order for Google Cloud Operations to view metric data collected in Prometheus, such as from SAS Viya services, that data must be collected from Prometheus, converted, and exported Google Cloud Operations.
Use this sample to deploy the components needed to enable Google Cloud Operations to view SAS Viya metric data.
These components are required to view SAS Viya metric data in Google Cloud Operations:
- Prometheus server
- Stackdriver Prometheus sidecar
SAS Viya metrics are provided as HTTP-HTTPS metric endpoints that are read by a Prometheus server, such as the one deployed with the SAS Viya monitoring components.
Google supports Prometheus metrics by watching data as it is collected by the Prometheus server. Google then converts and exports that data to Google Cloud Operations.
Before using this sample, you must deploy the SAS Viya monitoring components, including the Prometheus server.
Google uses the Stackdriver Prometheus sidecar to export metrics collected by Prometheus to Google Cloud Operations. The sidecar (or extra container) is added to the Prometheus pod with a shared volume mount so that the sidecar can directly read the Prometheus server data.
Although there are several ways to deploy the sidecar to a Prometheus pod, this sample directly supports only Prometheus custom resources such as those deployed by the SAS Viya monitoring components in this repository.
The patch-prometheus.sh
script in this sample adds the sidecar to a deployed
Prometheus custom resource. The script uses environment variables to customize
the deployment for your environment. Required environment variables do not have
a default value, so the script fails if the environment variable values are not provided.
These environment variables are required:
GCP_PROJECT
- the Google Cloud Platform projectGCP_REGION
- the primary region of the Google Cloud Platform clusterGKE_CLUSTER
- the name of the Google Kubernetes Environment cluster
These environment variables are optional:
MON_NS
- the namespace of the Prometheus custom resource (defaultmonitoring
)PROM_NAME
- the name of the Prometheus custom resource (defaultv4m-prometheus
)PROM_PATH
- the sub-path to Prometheus from the Prometheus URL. This value must end with/
, which is the default value. For example, if you are using host-based ingress, the Prometheus URL might behttp://prometheus.host.mycluster.example.com
, so you would use the default value of/
. If you are using path-based ingress, the Prometheus URL might behttp://host.mycluster.example.com/prometheus
, so you would specify a value ofprometheus/
.GKE_SIDECAR_VERSION
- the version of the Stackdriver Prometheus sidecar to use. The default value is0.8.2
. See the list of releases on Stackdriver Prometheus sidecar on GitHub.
This is an example deployment:
cd samples/gke-monitoring
export GCP_PROJECT=mygcpproject
export GCP_REGION=us-east1
export GKE_CLUSTER=my-awesome-cluster
./patch-prometheus.sh
After you run the script, the Prometheus pod automatically restarts. The sidecar starts exporting metrics to Google Cloud Operations one to two minutes after the pod restarts.
After the sidecar starts successfully exporting metrics, the metrics are visible in the Metrics Explorer in Google Cloud Operations Monitoring.
To view the metrics, from the Google Cloud Platform Console, select Operations -> Monitoring -> Metrics Explorer.
All metrics collected from Prometheus begin with
external.googleapis.com/prometheus
. You can also search for the base metric
name (such as go_memstats_alloc_bytes
).
You can create charts and dashboards for viewing the SAS Viya metric data. See the Metric Explorer documentation for information about building charts and dashboards.
Use this command to check the status of the Prometheus pod and verify that it is running correctly:
kubectl get po -n monitoring prometheus-v4m-prometheus-0
Use this command to view the logs for the Stackdriver Prometheus sidecar:
kubectl logs -n monitoring prometheus-v4m-prometheus-0 -c sidecar -f