Questo documento descrive come configurare il tuo deployment Google Kubernetes Engine in modo da utilizzare Google Cloud Managed Service per Prometheus per raccogliere metriche da Istio. Questo documento illustra come procedere nel seguente modo:
- Configura Istio per segnalare le metriche.
- Configura una risorsa PodMonitoring per Managed Service per Prometheus per raccogliere le metriche esportate.
- Accedi a una dashboard in Cloud Monitoring per visualizzare le metriche.
- Configura le regole di avviso per monitorare le metriche.
Queste istruzioni si applicano solo se utilizzi la raccolta gestita con Managed Service per Prometheus. Se invece utilizzi una raccolta di cui è stato eseguito il deployment autonomo, consulta il repository del codice sorgente per Istio per le informazioni sull'installazione.
Per informazioni su Istio, vedi Istio.
Prerequisiti
Per raccogliere metriche da Istio utilizzando Managed Service for Prometheus e la raccolta gestita, il tuo deployment deve soddisfare i seguenti requisiti:
- Il cluster deve eseguire Google Kubernetes Engine versione 1.21.4-gke.300 o successive.
- Devi eseguire Managed Service per Prometheus con la raccolta gestita abilitata. Per maggiori informazioni, consulta la Guida introduttiva alla raccolta gestita.
Istio espone le metriche in formato Prometheus automaticamente; non è necessario installarle separatamente. Puoi eseguire i seguenti controlli per verificare che il proxy Istio sia stato inserito come sidecar e che Istiod, il piano di controllo di Istio e il proxy Istio stiano emettendo le metriche per gli endpoint previsti.
Per determinare se il proxy Istio viene inserito come sidecar, esegui il comando seguente, che elenca i container in esecuzione nei pod dell'applicazione:
kubectl get pod -l app=APPLICATION_NAME -n NAMESPACE_NAME -o jsonpath='{.items[0].spec.containers[*].name}'
Se noti che i pod contengono il container sidecar
istio
, l'esportatore è stato inserito. Se il file collaterale non viene inserito, segui le istruzioni riportate in Istio: installare il file collaterale.Per verificare che le metriche vengano emesse dal proxy Istio, esegui il comando seguente, che controlla l'endpoint
/stats/prometheus
diistio
sul pod specificato:kubectl exec POD_NAME -n NAMESPACE_NAME -c istio-proxy -- curl -sS 'localhost:15090/stats/prometheus'
Se noti metriche non elaborate
istio_*
eenvoy_*
Prometheus, le metriche vengono emesse correttamente.Per verificare che le metriche vengano emesse in modo simile su Istiod, esegui questo comando, che controlla l'endpoint
/metrics
di Istio su uno dei pod nel deploymentistiod
:kubectl exec -n istio-system deployment/istiod -- curl -sS 'localhost:15014/metrics'
Definisci una risorsa PodMonitoring
Per il rilevamento dei target, l'operatore Managed Service per Prometheus richiede una risorsa PodMonitoring che corrisponde all'esportatore Istio nello stesso spazio dei nomi.
Puoi utilizzare la seguente configurazione di PodMonitoring:
Istio richiede due risorse PodMonitoring separate: una che monitora Istio e un'altra che monitora i file collaterali Istio e i gateway in entrata e in uscita. Per monitorare le metriche di proxy Istio in tutti gli spazi dei nomi nel cluster contemporaneamente, applica la risorsaistio-proxy
PodMonitoring a ogni spazio dei nomi o configura una risorsa ClusterPodMonitoring anziché una risorsa PodMonitoring per spazio dei nomi.
Se prevedi di utilizzare le dashboard Grafana fornite da Istio, oltre alle risorse di PodMonitoring descritte in questo documento, assicurati di aver configurato anche i reti di Kubelet e cAdvisor.
Per applicare le modifiche alla configurazione da un file locale, esegui questo comando:
kubectl apply -n NAMESPACE_NAME -f FILE_NAME
Puoi anche utilizzare Terraform per gestire le configurazioni.
Definisci regole e avvisi
Puoi utilizzare la seguente configurazione Rules
per definire gli avvisi sulle metriche Istio:
Per applicare le modifiche alla configurazione da un file locale, esegui questo comando:
kubectl apply -n NAMESPACE_NAME -f FILE_NAME
Puoi anche utilizzare Terraform per gestire le configurazioni.
Per maggiori informazioni sull'applicazione di regole al tuo cluster, consulta Avvisi e valutazione delle regole gestite.
Questa configurazione diRules
è stata adattata dalle regole di Istio fornite da Awesome Prometheus Alerts.
Puoi regolare le soglie di avviso in base alle tue esigenze.
Verificare la configurazione
Puoi utilizzare Metrics Explorer per verificare di aver configurato correttamente l'esportatore Istio. Cloud Monitoring potrebbe impiegare uno o due minuti per importare le metriche.
Per verificare se le metriche sono state importate, procedi nel seguente modo:
- Nella console Google Cloud, seleziona Monitoring
o fai clic sul pulsante seguente:
Vai a Monitoring - Nel riquadro di navigazione, seleziona
Metrics Explorer.
- Seleziona la scheda PromQL ed esegui la seguente query:
sum(istio_build{cluster="CLUSTER_NAME"}) by (component)
Visualizza dashboard
L'integrazione di Cloud Monitoring include la dashboard Istio Envoy Prometheus Overview. Le dashboard vengono installate automaticamente quando configuri l'integrazione. Puoi anche visualizzare le anteprime statiche delle dashboard senza installare l'integrazione.
Per visualizzare una dashboard installata, procedi come segue:
- Nella console Google Cloud, seleziona Monitoring
o fai clic sul pulsante seguente:
Vai a Monitoring - Nel pannello di navigazione, seleziona
Dashboard.
- Seleziona la scheda Elenco dashboard.
- Scegli la categoria Integrazioni.
- Fai clic sul nome della dashboard, ad esempio Panoramica di Istio Prometheus.
Per visualizzare un'anteprima statica della dashboard:
- Nella console Google Cloud, seleziona Monitoring
o fai clic sul pulsante seguente:
Vai a Monitoring - Nel riquadro di navigazione, seleziona
Integrazioni.
- Fai clic sul filtro della piattaforma di deployment Kubernetes Engine.
- Individua l'integrazione Istio e fai clic su Visualizza dettagli.
- Seleziona la scheda Dashboard.
Risolvere i problemi
Per informazioni sulla risoluzione dei problemi di importazione delle metriche, consulta la sezione Problemi con la raccolta dagli esportatori in Risolvere i problemi lato importazione.