Google monitora e gestisce da remoto l'hardware di Google Distributed Cloud connected. A questo scopo, gli ingegneri Google hanno accesso Secure Shell (SSH) all'hardware Distributed Cloud connesso. Se Google rileva un problema, un tecnico di Google ti contatta per risolverlo. Se hai identificato un problema, contatta immediatamente l'Assistenza Google per diagnosticarlo e risolverlo.
Upgrade software di Distributed Cloud connesso
Questa sezione descrive come utilizzare Metrics Explorer per verificare se un cluster connesso a Distributed Cloud è in fase di upgrade software.
Questa procedura utilizza le seguenti metriche di monitoraggio:
Versione attuale del cluster (
/edge_cluster/current_cluster_version): indica la versione attuale del software Distributed Cloud connesso in esecuzione sul cluster.Versione del cluster di destinazione (
/edge_cluster/target_cluster_version): indica la versione di destinazione di Distributed Cloud Connected a cui viene eseguito l'upgrade del cluster.
Per completare i passaggi descritti in questa sezione, devi soddisfare i seguenti prerequisiti:
- Accesso alla console Google Cloud e al tuo progetto Distributed Cloud connesso Google Cloud .
- Il ruolo IAM Visualizzatore Monitoring, che consente di visualizzare le metriche di Monitoring.
- (Facoltativo) il valore
machine_iddella macchina Distributed Cloud connected di destinazione per filtrare i risultati restituiti.
Utilizza Esplora metriche per controllare le versioni software attuali e di destinazione del cluster
Vai a Metrics Explorer:
Nella console Google Cloud , vai alla sezione Monitoraggio.
Nell'albero di navigazione a sinistra, fai clic su Esplora metriche.
Seleziona il tipo di risorsa di destinazione:
Nella pagina Metrics Explorer, vai alla pagina Configurazione.
Fai clic su Seleziona una metrica.
Utilizza la barra di ricerca per cercare il tipo di risorsa Cluster. Puoi anche utilizzare l'identificatore di risorsa completo
edgecontainer.googleapis.com/Cluster.Nei risultati restituiti, fai clic sul tipo di risorsa Cluster.
Ottieni la versione software attuale del cluster:
Nella sezione Metrica, cerca il valore
current_cluster_version.Seleziona la metrica Tempo di attività della macchina. Il percorso completo è
edgecontainer.googleapis.com/edge_cluster/current_cluster_version.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.
Ottieni la versione software di destinazione del cluster:
Fai clic su Aggiungi query.
Nella sezione Metrica, cerca il valore
target_cluster_version.Seleziona la metrica Versione cluster di destinazione. Il percorso completo è
edgecontainer.googleapis.com/edge_cluster/target_cluster_version.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.
Controlla lo stato dell'upgrade software del cluster nel grafico visualizzato.
Se le righe Versione attuale del cluster e Versione di destinazione del cluster indicano valori diversi, il cluster è in fase di upgrade del software.
Se le righe Versione attuale del cluster e Versione di destinazione del cluster indicano lo stesso valore, il cluster non è in fase di upgrade del software.
Verifica il risultato del passaggio precedente utilizzando il seguente comando:
gcloud edge-cloud container clusters describe CLUSTER_ID --location=REGION
Sostituisci quanto segue:
CLUSTER_ID: l'ID del cluster di destinazione.REGION: la Google Cloud regione in cui è stato creato il cluster.
Nell'output del comando, annota i valori dei seguenti campi:
- Se il valore del campo
statusèUPDATING, il cluster è in fase di upgrade del software. - Se i valori dei campi
clusterVersionetargetVersionsono diversi, confrontali con i valori restituiti da Metrics Explorer.
Comprendere i risultati
La seguente tabella spiega i risultati restituiti da Metrics Explorer e dal comando gcloud.
| Stato del cluster | Diagnosi | Risoluzione |
|---|---|---|
| Healthy I valori di currentVersion e targetVersion corrispondonoIl valore di `status` è RUNNING |
Il cluster esegue la versione di destinazione del software Distributed Cloud connesso. | Nessuno. |
| Upgrade Il valore di currentVersion è inferiore a targetVersionIl valore di "status" è UPDATING |
Il cluster esegue l'upgrade alla versione di destinazione del software Distributed Cloud connected. | Monitora il cluster in Metrics Explorer finché i valori della versione del cluster attuale e di destinazione non corrispondono. |
| Bloccato Il valore di currentVersion è inferiore a targetVersion a tempo indeterminatoIl valore di `status` è UPDATING a tempo indeterminato |
L'upgrade alla versione di destinazione del software Distributed Cloud connesso non è riuscito su almeno un nodo del cluster. | Controlla la connettività della macchina e i log di sistema; contatta Google per ricevere assistenza. |
| Rollback Il valore di currentVersion è superiore a targetVersionIl valore di "status" è UPDATING |
luster sta eseguendo il rollback a una versione precedente del software Google Distributed Cloud connesso. | Contatta Google per identificare il motivo del rollback. |
Se l'upgrade software sul cluster non è riuscito o il cluster è stato sottoposto a rollback a una versione software precedente, controlla quanto segue:
- Stato del nodo. Verifica che ogni macchina fisica Distributed Cloud connessa disponga della connettività di rete e che il tempo di attività venga segnalato come descritto nella sezione successiva.
- Periodi di manutenzione. Verifica se l'upgrade software è stato messo in pausa a causa di un periodo di esclusione dalla manutenzione.
- Log di sistema. Esamina i log di sistema per identificare i possibili motivi dell'errore di upgrade del software, ad esempio i timeout di espulsione dei pod.
Se i passaggi di risoluzione elencati nella tabella non risolvono il problema, contatta
l'assistenza Google
con il valore machine_id della macchina interessata e il timestamp dell'interruzione.
Riavvii delle macchine Distributed Cloud connected
Questa sezione descrive come utilizzare Metrics Explorer per verificare se una macchina fisica connessa a Distributed Cloud è stata riavviata e determinare il motivo del riavvio. Il monitoraggio dei riavvii consente di determinare se facevano parte di una manutenzione pianificata o se sono stati causati da un guasto hardware o da un'interruzione di corrente.
Questa procedura utilizza le seguenti metriche di monitoraggio:
Uptime macchina (
/machine/uptime): indica il tempo, in secondi, trascorso dall'ultimo riavvio.Riavvii della macchina (
/machine/restart_count): indica il numero totale di riavvii della macchina di destinazione dal suo deployment.
Per completare i passaggi descritti in questa sezione, devi soddisfare i seguenti prerequisiti:
- Accesso alla console Google Cloud e al tuo progetto Distributed Cloud connesso Google Cloud .
- Il ruolo IAM Visualizzatore Monitoring, che consente di visualizzare le metriche di Monitoring.
- (Facoltativo) il valore
machine_iddella macchina Distributed Cloud connected di destinazione per filtrare i risultati restituiti.
Utilizzare Esplora metriche per controllare l'uptime e il conteggio dei riavvii della macchina
Vai a Metrics Explorer:
Nella console Google Cloud , vai alla sezione Monitoraggio.
Nell'albero di navigazione a sinistra, fai clic su Esplora metriche.
Seleziona il tipo di risorsa di destinazione:
Nella pagina Metrics Explorer, vai alla pagina Configurazione.
Fai clic su Seleziona una metrica.
Utilizza la barra di ricerca per cercare il tipo di risorsa Macchina. Puoi anche utilizzare l'identificatore di risorsa completo
edgecontainer.googleapis.com/Machine.Nei risultati restituiti, fai clic sul tipo di risorsa Macchina.
Controlla l'uptime della macchina:
Nella sezione Metrica, cerca il valore
uptime.Seleziona la metrica Tempo di attività della macchina. Il percorso completo è
edgecontainer.googleapis.com/machine/uptime.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.Nel grafico temporale visualizzato, verifica che il grafico dell'uptime sia in continuo aumento. Se in un determinato momento il valore di uptime scende a zero e si riavvia, significa che la macchina è stata riavviata.
Controlla il conteggio dei riavvii della macchina:
Nella sezione Metrica, cerca il valore
restart_count.Seleziona la metrica Riavvii del computer. Il percorso completo è
edgecontainer.googleapis.com/machine/restart_count.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.Nel grafico temporale visualizzato, verifica che la linea del grafico rimanga a
0, il che indica che non si sono verificati riavvii. Se in un dato momento la linea raggiunge il picco di1significa che la macchina è stata riavviata; annota il timestamp esatto del riavvio per ulteriori risoluzioni dei problemi.(Facoltativo) Per visualizzare i singoli eventi anziché un grafico, vai alla sezione Aggregazione della pagina, imposta il campo Periodo di allineamento su
1 minutee il campo Allineatore per serie su Delta.
Comprendere i risultati
La seguente tabella spiega i risultati restituiti da Metrics Explorer.
| Stato della macchina | Diagnosi | Risoluzione |
|---|---|---|
| Stabile La metrica "Tempo di attività della macchina" aumenta costantemente Il delta della metrica "Riavvii della macchina" è 0 |
La macchina non è stata riavviata. | Nessuno. |
| Riavvio pulito La metrica "Tempo di attività della macchina" scende a 0La metrica "Riavvii della macchina" sale a 1 |
La macchina è stata riavviata e riconnessa a Google Cloud. | Controlla i log di sistema per determinare il motivo del riavvio. |
| Interruzione di corrente Il grafico della metrica "Tempo di attività della macchina" presenta un'interruzione senza dati La metrica "Riavvii della macchina" non è cambiata durante l'interruzione del tempo di attività della macchina |
La macchina ha perso alimentazione o connettività di rete prima di poter essere riavviata. | Controlla i cavi di alimentazione e di rete, la configurazione della rete locale e lo stato dell'indicatore LED. |
| Intermittente Il valore della metrica "Macchina connessa" alterna 0 e 1Il valore della metrica "Connettività di rete" alterna 0 e 1 |
Connessione di rete instabile, perdita di pacchetti o latenza eccessiva. | Controlla la rete locale per verificare la presenza di congestione e hardware difettoso. |
Se i passaggi di risoluzione elencati nella tabella non risolvono il problema, contatta
l'assistenza Google
con il valore machine_id della macchina interessata e il timestamp dell'interruzione.
Connettività delle macchine di Distributed Cloud connected
Questa sezione descrive come controllare la connettività a internet e Google Cloud per le macchine connesse a Distributed Cloud utilizzando la funzionalità Metrics Explorer di Cloud Monitoring.
Questa procedura utilizza le seguenti metriche di monitoraggio:
Attrezzo connesso (
/machine/connected): indica se l'attrezzo è connesso a Google Cloud.Connettività di rete (
/machine/network/connectivity): indica se l'interfaccia di rete principale della macchina ha connettività a internet.
Per completare i passaggi descritti in questa sezione, devi soddisfare i seguenti prerequisiti:
- Accesso alla console Google Cloud e al tuo progetto Distributed Cloud connesso Google Cloud .
- Il ruolo IAM Visualizzatore Monitoring, che consente di visualizzare le metriche di Monitoring.
- (Facoltativo) il valore
machine_iddella macchina Distributed Cloud connected di destinazione per filtrare i risultati restituiti.
Utilizzare Esplora metriche per controllare la connettività della macchina
Vai a Metrics Explorer:
Nella console Google Cloud , vai alla sezione Monitoraggio.
Nell'albero di navigazione a sinistra, fai clic su Esplora metriche.
Seleziona il tipo di risorsa di destinazione:
Nella pagina Metrics Explorer, vai alla pagina Query.
Utilizza la barra di ricerca per cercare il tipo di risorsa Macchina. Puoi anche utilizzare l'identificatore di risorsa completo
edgecontainer.googleapis.com/Machine.Nei risultati restituiti, fai clic sul tipo di risorsa Macchina.
Controlla la connessione della macchina a Google Cloud:
Nella sezione Metrica, cerca il valore
connected.Seleziona la metrica Macchina connessa. Il percorso completo è
edgecontainer.googleapis.com/machine/connected.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.Nel grafico temporale visualizzato, verifica che la linea Integrità rimanga al 100% in modo contiguo. Se in un determinato momento questo valore è 0% o Non integro, la macchina ha perso la connettività con Google Cloud all'ora indicata.
Controlla la connettività a internet della macchina:
Nella sezione Metrica, cerca il valore
connectivity.Seleziona la metrica Connettività di rete. Il percorso completo è
edgecontainer.googleapis.com/machine/network/connectivity.(Facoltativo) Filtra in base al valore
machine_iddi destinazione utilizzando la sezione Filtro.Nel grafico temporale visualizzato, verifica che la linea Integrità rimanga al 100% in modo contiguo. Se in un determinato momento questo valore è 0% Non integro, la macchina ha perso la connettività a internet all'ora indicata.
Comprendere i risultati
La seguente tabella spiega i risultati restituiti da Metrics Explorer.
| Stato della macchina | Diagnosi | Risoluzione |
|---|---|---|
| In buono stato Il valore della metrica "Macchina connessa" è 1Il valore della metrica "Connettività di rete" è 1 |
Funzionamento normale. | Nessuno. |
| Disconnesso Il valore della metrica "Macchina connessa" è 0Il valore della metrica "Connettività di rete" è 1 |
La macchina è connessa a internet, ma non riesce a connettersi a Google Cloud. | Controlla le regole firewall per i servizi Google e gli endpoint API. Verifica che gli agenti connessi di Distributed Cloud siano in esecuzione sulla macchina. |
| Isolato Il valore della metrica "Macchina connessa" è 0Il valore della metrica "Connettività di rete" è 0 |
La macchina non ha connettività a internet. | Controlla i cavi di alimentazione e di rete, la configurazione della rete locale e lo stato dell'indicatore LED. Verifica la configurazione di VLAN e routing. |
| Intermittente Il valore della metrica "Macchina connessa" alterna 0 e 1Il valore della metrica "Connettività di rete" alterna 0 e 1 |
Connessione di rete instabile, perdita di pacchetti o latenza eccessiva. | Controlla la rete locale per verificare la presenza di congestione e hardware difettoso. |
Se noti valori costanti di 0 per una delle metriche, segui i passaggi per la risoluzione dei problemi descritti
nella tabella per risolverli. Se il problema persiste, contatta l'Assistenza Google
con il valore machine_id della macchina interessata e il timestamp dell'interruzione.
Macchine virtuali bloccate nello stato Pending
Un workload della macchina virtuale può bloccarsi nello stato Pending e non essere pianificato su un nodo se si verifica uno dei seguenti scenari:
- Distributed Cloud connesso non può allocare le risorse richieste, come tempo CPU, memoria o spazio su disco, alla macchina virtuale.
- Si è verificato un errore nella configurazione della macchina virtuale.
- Si è verificato un errore con l'archiviazione della macchina virtuale.
- Il nodo di destinazione è compromesso.
Per risolvere il problema, segui questi passaggi:
Ottieni le credenziali del cluster come descritto in Ottenere le credenziali per un cluster.
Ottieni informazioni sulla macchina virtuale interessata:
kubectl describe virtualmachine VM_NAME -n NAMESPACE
Sostituisci quanto segue:
VM_NAME: il nome della macchina virtuale di destinazione.NAMESPACE: lo spazio dei nomi della macchina virtuale di destinazione.
Il comando restituisce un output simile al seguente:
Status: ... State: Pending ... Events: Type Reason Age From Message ---- ------ ---- ---- ------- Normal SuccessfulCreate 15m virtualmachine-controller Created virtual machine my-stuck-vm Warning DiskProvisioningFailed 14m virtualmachine-controller Failed to provision disk: DataVolume my-stuck-vm-data-disk not ready Warning PVCNotBound 14m virtualmachine-controller PersistentVolumeClaim my-stuck-vm-data-disk is in phase Pending Warning VMINotCreated 10m virtualmachine-controller VirtualMachineInstance cannot be created: dependencies not readyL'output del comando contiene messaggi che potrebbero indicare vincoli delle risorse, errori di pianificazione, guasti di archiviazione e altri problemi.
Esamina l'output per determinare le cause dell'errore di pianificazione, come spiegato nelle sezioni successive.
Risorse insufficienti
Potresti visualizzare un messaggio che indica risorse insufficienti, ad esempio CPU, memoria o spazio su disco. Ad esempio:
5/8 nodes are available: 3 Insufficient memory, 3 Insufficient CPU.
Per risolvere il problema, controlla le risorse allocate alle macchine virtuali interessate e ad altri carichi di lavoro pianificati sul nodo, poi procedi nel seguente modo a seconda delle esigenze aziendali:
- Fare lo scale down di altri workload pianificati sul nodo.
- Riduci la quantità di risorse allocate alla macchina virtuale interessata.
- Aggiungi altre macchine al cluster interessato.
Nodi con taint
Potresti visualizzare un messaggio che indica che il nodo di destinazione è compromesso. Ad esempio:
5/8 nodes are available: 3 node(s) had taint {<taint-key>:<taint-value>}, that the pod didn't tolerate.
Per risolvere il problema, procedi nel seguente modo:
Utilizza il seguente comando per verificare la presenza di taint sul nodo:
kubectl get nodes -o custom-columns=NAME:.metadata.name,TAINTS:.spec.taints
Il comando restituisce un output simile al seguente:
NAME TAINTS node-name-1 [map[effect:PreferNoSchedule key:node-role.kubernetes.io/master] map[effect:PreferNoSchedule key:node-role.kubernetes.io/control-plane]] node-name-2 <none>Esegui una delle seguenti operazioni:
- Per le contaminazioni impreviste, rimuovile come descritto in Contaminazioni e tolleranze.
- Per i taint previsti, aggiungi le tolleranze corrispondenti alla configurazione della macchina virtuale, come descritto in Taint e tolleranze.
Errori di archiviazione
Potresti visualizzare un messaggio che indica un errore con lo spazio di archiviazione della macchina virtuale. Ad esempio:
5/8 nodes are available: 3 node(s) had volume node affinity conflict, 3 node(s) had unbound immediate PersistentVolumeClaims.
Questo messaggio potrebbe indicare che il volume permanente corrispondente non viene montato sul nodo di destinazione.
Per risolvere il problema, procedi nel seguente modo:
Utilizza il seguente comando per ottenere lo stato delle rivendicazioni di volumi permanenti (PVC) nello spazio dei nomi della macchina virtuale interessata:
kubectl get pvc -n NAMESPACE
Sostituisci
NAMESPACEcon il nome dello spazio dei nomi di destinazione.Il comando restituisce un output simile al seguente:
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE windows-robin-disk-0 Bound pvc-b1a1d264-84bf-4e58-857d-f37f629d5082 25Gi RWX robin-block-immediate 30h windows-robin-disk-1 Bound pvc-0130b9a8-7fed-4df0-8226-d79273792a16 25Gi RWX robin-block-immediate 30h windows-robin-vm-0-restored-windows-robin-disk-0 Pending gce-pd-gkebackup-in 26mVerifica che la PVC corrispondente abbia lo stato
Bound; se lo stato èPending, il sottosistema di archiviazione non è riuscito a eseguire il provisioning del volume. In questi casi, devi risolvere i problemi relativi alla configurazione del sottosistema di archiviazione e assicurarti che sia disponibile l'StorageClassappropriato.