Risolvere i problemi di installazione e avvio di Ops Agent

Questo documento fornisce informazioni che aiutano a diagnosticare e risolvere i problemi di installazione e avvio di Ops Agent. Se l' agente è in esecuzione, ma non riesce a importare log o metriche, consulta Risolvere i problemi di importazione dei dati.

Prima di iniziare

Prima di provare a risolvere un problema, controlla lo stato dei controlli di integrità dell'agente.

Installazione dell'agente non riuscita

Quando esegui lo script di installazione , potresti riscontrare i seguenti errori.

Il sistema operativo non è supportato

Se il sistema operativo non è supportato, l'installazione di Ops Agent non riesce. Il messaggio di errore potrebbe essere simile al seguente:

Linux

https://packages.cloud.google.com/yum/repos/google-cloud-ops-agent-el6-x86_64-all/repodata/repomd.xml: [Errno 14] PYCURL ERROR 22 - "The requested URL returned error: 404 Not Found"
Trying other mirror.
To address this issue please refer to the below wiki article

https://wiki.centos.org/yum-errors

If above article doesn't help to resolve this issue please use https://bugs.centos.org/.

Error: Cannot retrieve repository metadata (repomd.xml) for repository: google-cloud-ops-agent. Please verify its path and try again

È installato un agente legacy in conflitto con Ops Agent

Se su una VM sono già installati l'agente Cloud Logging o l'agente Cloud Monitoring, questi sono in conflitto con il nuovo agente. Il messaggio di errore potrebbe essere simile al seguente:

Linux

Error:
 Problem: problem with installed package stackdriver-agent-6.0.5-1.el8.x86_64 - package google-cloud-ops-agent-0.1.0-1.el8.x86_64 conflicts with stackdriver-agent provided by stackdriver-agent-6.0.5-1.el8.x86_64

Ops Agent utilizza nuovi file di configurazione non compatibili con i vecchi agenti. Per saperne di più, consulta la guida Configura Ops Agent.

Per correggere questo errore, segui questi passaggi:

  1. Salva i file di configurazione personalizzati per l' agente Cloud Monitoring e l'agente Cloud Logging.

  2. Disinstalla il vecchio agente Cloud Monitoring e agente Cloud Logging.

    Dopo aver disinstallato l'agente, la Google Cloud console potrebbe impiegare fino a un' ora per segnalare questa modifica.

L'installazione di Ops Agent non riesce dopo l'installazione non riuscita dell'agente Monitoring

L'installazione di Ops Agent non riesce dopo un tentativo non riuscito di installare l'agente Monitoring. Su un sistema operativo Debian, i messaggi di errore quando l'installazione di Ops Agent non riesce sono simili ai seguenti:

Linux

...
E: The repository 'https://packages.cloud.google.com/apt google-cloud-monitoring-jammy-all Release' does not have a Release file.
...
Could not refresh the google-cloud-ops-agent apt repositories.

Se provi a installare l'agente Monitoring su un sistema operativo non supportato da questo agente, l'installazione non riesce. L'errore di installazione si verifica dopo che il repository dell'agente Monitoring è stato aggiunto al sistema. Anche l'installazione di Ops Agent dopo un'installazione non riuscita dell'agente Monitoring non riesce a causa di un repository dell'agente Monitoring non valido.

Non tutti i sistemi operativi supportati da Ops Agent sono supportati anche dall'agente Monitoring. Per informazioni sui sistemi operativi supportati, consulta Ops Agent: sistemi operativi Linux e Agente Monitoring: sistemi operativi Linux.

Per installare Ops Agent:

  1. Rimuovi il repository per l'agente Monitoring:

    Se lo script add-monitoring-agent-repo.sh è presente sul tuo sistema, esegui il seguente comando:

    sudo bash add-monitoring-agent-repo.sh --remove-repo
    

    In caso contrario, rimuovi manualmente il repository:

    Debian

    sudo rm /etc/apt/sources.list.d/google-cloud-monitoring.list

    RHEL

     sudo rm /etc/yum.repos.d/google-cloud-monitoring.repo

    Suse

    sudo rm /etc/zypp/repos.d/google-cloud-monitoring.repo

  2. Esegui lo script di installazione di Ops Agent.

L'installazione di Ops Agent non riesce perché l'aggiornamento del repository non riesce

L'installazione di Ops Agent non riesce perché l'aggiornamento dei repository installati non riesce.

Linux

Per un esempio del messaggio di errore per un sistema operativo Debian, in cui l'aggiornamento del repository si verifica a causa di una chiamata a apt-get update, consulta la voce di risoluzione dei problemi L'installazione di Ops Agent non riesce dopo l'installazione non riuscita dell'agente Monitoring.

Se si verificano errori durante l'aggiornamento dei repository, devi risolverli prima di poter installare Ops Agent. Potresti essere in grado di risolvere questi errori eliminando o disattivando i repository non necessari.

Dopo aver aggiornato i repository, puoi installare Ops Agent eseguendo lo script di installazione di Ops Agent.

L'aggiornamento del repository non riesce perché la chiave pubblica non è disponibile

Linux

L'aggiornamento di un repository, a causa di una chiamata a apt-get update, non riesce perché la chiave pubblica non è disponibile. Questo può verificarsi anche durante l'installazione o l'upgrade di Ops Agent. Potresti visualizzare il seguente errore:

W: GPG error: http://packages.cloud.google.com/apt google-cloud-ops-agent-focal-all InRelease: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY C0BA5CE6DC6315A3
E: The repository 'http://packages.cloud.google.com/apt google-cloud-ops-agent-focal-all InRelease' is not signed.

Per correggere questo errore, esegui il seguente comando per aggiungere la chiave mancante al sistema:

curl -fsSL https://packages.cloud.google.com/apt/doc/apt-key.gpg \
    | sudo gpg --dearmor -o /etc/apt/trusted.gpg.d/google-cloud-ops-agent.gpg

L'agente è installato, ma non è in esecuzione

Se hai installato l'agente, ma non è in esecuzione, il problema potrebbe essere uno dei seguenti:

I servizi dell'agente non sono in esecuzione

Quando i servizi dell'agente sono in esecuzione come previsto, l'agente Metriche e l'agente Logging vengono visualizzati come in esecuzione quando esegui una query sullo stato:

Per Linux

sudo systemctl status google-cloud-ops-agent"*"

Per brevità, alcune righe dell'output sono state eliminate.

● google-cloud-ops-agent.service - Google Cloud Ops Agent
     Loaded: loaded (/lib/systemd/system/google-cloud-ops-agent.service; enabled; vendor preset: enabled)
     Active: active (exited) since Wed 2023-05-03 21:22:28 UTC; 4 weeks 0 days ago
    Process: 3353828 ExecStartPre=/opt/google-cloud-ops-agent/libexec/google_cloud_ops_agent_engine -in /etc/go>
    Process: 3353837 ExecStart=/bin/true (code=exited, status=0/SUCCESS)
   Main PID: 3353837 (code=exited, status=0/SUCCESS)
        CPU: 195ms

[...]

● google-cloud-ops-agent-opentelemetry-collector.service - Google Cloud Ops Agent - Metrics Agent
     Loaded: loaded (/lib/systemd/system/google-cloud-ops-agent-opentelemetry-collector.service; static)
     Active: active (running) since Wed 2023-05-03 21:22:29 UTC; 4 weeks 0 days ago
    Process: 3353840 ExecStartPre=/opt/google-cloud-ops-agent/libexec/google_cloud_ops_agent_engine -service=ot>
   Main PID: 3353855 (otelopscol)
      Tasks: 9 (limit: 2355)
     Memory: 65.3M
        CPU: 40min 31.555s
     CGroup: /system.slice/google-cloud-ops-agent-opentelemetry-collector.service
             └─3353855 /opt/google-cloud-ops-agent/subagents/opentelemetry-collector/otelopscol --config=/run/g>

[...]

● google-cloud-ops-agent-fluent-bit.service - Google Cloud Ops Agent - Logging Agent
     Loaded: loaded (/lib/systemd/system/google-cloud-ops-agent-fluent-bit.service; static)
     Active: active (running) since Wed 2023-05-03 21:22:29 UTC; 4 weeks 0 days ago
    Process: 3353838 ExecStartPre=/opt/google-cloud-ops-agent/libexec/google_cloud_ops_agent_engine -service=fl>
   Main PID: 3353856 (google_cloud_op)
      Tasks: 31 (limit: 2355)
     Memory: 58.3M
        CPU: 29min 6.771s
     CGroup: /system.slice/google-cloud-ops-agent-fluent-bit.service
             ├─3353856 /opt/google-cloud-ops-agent/libexec/google_cloud_ops_agent_wrapper -config_path /etc/goo>
             └─3353872 /opt/google-cloud-ops-agent/subagents/fluent-bit/bin/fluent-bit --config /run/google-clo>

[...]

Per Windows

Get-Service google-cloud-ops-agent*

Status   Name               DisplayName
------   ----               -----------
Running  google-cloud-op... Google Cloud Ops Agent
Running  google-cloud-op... Google Cloud Ops Agent - Logging Agent
Running  google-cloud-op... Google Cloud Ops Agent - Metrics Agent

Se il servizio dell'agente non è in esecuzione, potresti visualizzare il seguente stato:

Linux

$ sudo service google-cloud-ops-agent status
● google-cloud-ops-agent.service - Google Cloud Ops Agent
   Loaded: loaded (/lib/systemd/system/google-cloud-ops-agent.service; enabled; vendor preset: enabled)
   Active: inactive (dead) since Wed 2021-06-30 21:20:43 UTC; 6s ago

Windows

Get-Service google-cloud-ops-agent

Status   Name                    DisplayName
------   ----                    -----------
Stopped  google-cloud-ops-agent  Google Cloud Ops Agent

Per correggere questo errore, esegui il seguente comando per avviare il servizio:

Linux

sudo service google-cloud-ops-agent start

Windows

Start-Service google-cloud-ops-agent

Se il servizio non viene avviato, la configurazione potrebbe non essere valida.

Conflitto con gli agenti attualmente installati

  • Sulla VM sono già installati l'agente Cloud Logging o l'agente Cloud Monitoring e la loro configurazione è in conflitto con quella del nuovo agente. Il messaggio di errore potrebbe essere simile al seguente:

    Windows

    We detected an existing Windows service for the StackdriverLogging agent,
    which is not compatible with the Ops Agent when the Ops Agent configuration
    has a non-empty logging section. Please either remove the logging section
    from the Ops Agent configuration, or disable the StackdriverLogging agent,
    and then retry enabling the Ops Agent.
    

    Per correggere questo errore, hai due opzioni:

    1. Disattiva la sezione in conflitto del file di configurazione di Ops Agent. Per saperne di più, consulta la guida Configura Ops Agent.

    2. Disattiva l'agente Cloud Logging in conflitto o l'agente Cloud Monitoring .

      1. Salva tutti i file di configurazione personalizzati per l'agente Cloud Logging.
      2. Disinstalla il vecchio agente Cloud Monitoring e agente Cloud Logging.

      Dopo aver disinstallato l'agente, la Google Cloud console potrebbe impiegare fino a un' ora per segnalare questa modifica.

La porta richiesta non è disponibile

L'avvio di Ops Agent o di uno dei suoi componenti può non riuscire quando la porta necessaria al componente è utilizzata da un altro processo. Ops Agent utilizza le seguenti porte:

  • Porta 20201, per il componente "Agente Metriche"
  • Porta 20202, per il componente "Agente Logging"

Se un processo diverso da un componente di Ops Agent utilizza la porta 20201 o la porta 20202, arresta il processo e riavvia Ops Agent. Segui questi passaggi per determinare quale processo utilizza le porte:

Linux

Componente Agente Metriche: per vedere quale processo utilizza la porta 20201, utilizza il seguente comando:

sudo netstat -ns -p | grep '20201'

L'output seguente mostra il risultato previsto: l'agente di raccolta di metriche di Ops Agent, otelopscol, utilizza la porta:

tcp        0      0 127.0.0.1:50138         127.0.0.1:20201         ESTABLISHED 16850/otelopscol
tcp6       0      0 :::20201                :::*                    LISTEN      16850/otelopscol
tcp6       0      0 127.0.0.1:20201         127.0.0.1:50138         ESTABLISHED 16850/otelopscol

Componente Agente Logging: per vedere quale processo utilizza la porta 20202, utilizza il seguente comando:

sudo netstat -ns -p | grep '20202'

L'output seguente mostra il risultato previsto: il raccoglitore di log di Ops Agent, fluent-bit, utilizza la porta:

tcp        0      0 0.0.0.0:20202           0.0.0.0:*               LISTEN      16640/fluent-bit
tcp        0      0 127.0.0.1:20202         127.0.0.1:52998         TIME_WAIT   -

Windows

Componente Agente Metriche: per vedere quale processo utilizza la porta 20201, utilizza il seguente comando:

netstat -na -b  | Select-String "20201" -Context 0,1

L'output seguente mostra il risultato previsto: l'agente di raccolta delle metriche di Ops Agent, google-cloud-metrics-agent_windows_amd64.exe, utilizza la porta:

>   TCP    0.0.0.0:20201          0.0.0.0:0              LISTENING
   [google-cloud-metrics-agent_windows_amd64.exe]
>   TCP    127.0.0.1:20201        127.0.0.1:50090        ESTABLISHED
   [google-cloud-metrics-agent_windows_amd64.exe]
>   TCP    127.0.0.1:50090        127.0.0.1:20201        ESTABLISHED
   [google-cloud-metrics-agent_windows_amd64.exe]
>   TCP    [::]:20201             [::]:0                 LISTENING
   [google-cloud-metrics-agent_windows_amd64.exe]

Componente Agente Logging: per vedere quale processo utilizza la porta 20202, utilizza il seguente comando:

netstat -na -b  | Select-String "20202" -Context 0,1

L'output seguente mostra il risultato previsto: l'agente di raccolta log di Ops Agent, fluent-bit.exe, utilizza la porta:

>   TCP    0.0.0.0:20202          0.0.0.0:0              LISTENING
   [fluent-bit.exe]
>   TCP    127.0.0.1:20202        127.0.0.1:57535        TIME_WAIT
>   TCP    127.0.0.1:20202        127.0.0.1:57539        TIME_WAIT
    TCP    127.0.0.1:49807        127.0.0.1:49808        ESTABLISHED

Gli errori di disponibilità delle porte possono essere rilevati dai controlli di integrità eseguiti da Ops Agent.

L'agente non dispone delle autorizzazioni API

Se l'agente non viene avviato o non riesce a importare i dati, il problema potrebbe essere che il componente "Agente Metriche" o "Agente Logging" non dispone dell'autorizzazione necessaria per accedere all'API.

Il account di servizio utilizzato da Ops Agent richiede i seguenti ruoli Identity and Access Management:

Questi ruoli includono le autorizzazioni necessarie per scrivere dati di log o metriche e devono essere concessi al account di servizio associato alla VM. Il account di servizio che utilizzi dipende da come hai configurato la VM e autorizzato l'agente. Potresti utilizzare uno dei seguenti:

Per identificare il account di servizio associato a una VM:

  1. Nella Google Cloud console, vai alla pagina Istanze VM.

    Vai a Istanze VM

    Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Compute Engine.

  2. Se necessario, fai clic sull'elenco a discesa dei Google Cloud progetti e seleziona il nome del tuo progetto.

  3. Se necessario, seleziona la scheda Istanze.

  4. Nell'elenco delle istanze VM, fai clic sul nome della VM per visualizzare la pagina Dettagli della VM.

  5. Individua la sezione API e gestione delle identità della pagina. Il account di servizio è elencato come valore del campo Service account.

Per informazioni sull'impostazione dei ruoli concessi al account di servizio, consulta Verificare e modificare i ruoli di un service account.

Gli errori di autorizzazione API possono essere rilevati dai controlli di integrità eseguiti da Ops Agent.

Configurazione non valida

Se la configurazione non è valida, potresti visualizzare il seguente errore quando provi a riavviare il servizio dell'agente:

Linux

$ sudo service google-cloud-ops-agent restart \
    && sudo service google-cloud-ops-agent status
● google-cloud-ops-agent-fluent-bit.service - Google Cloud Ops Agent - Logging Agent
   Loaded: loaded (/usr/lib/systemd/system/google-cloud-ops-agent-fluent-bit.service; static; vendor preset: disabled)
  Drop-In: /usr/lib/systemd/system/google-cloud-ops-agent-fluent-bit.service.d
           └─directories.conf
   Active: failed (Result: exit-code) since Wed 2021-06-30 22:21:08 UTC; 2s ago
  Process: 1141421 ExecStart=/opt/google-cloud-ops-agent/subagents/fluent-bit/bin/fluent-bit --config ${RUNTIME_DIRECTORY}/fluent_bit_main.conf --parser ${RUNTIME_DIRECTORY}/fluent_bit_parser.conf --log_>
  Process: 1141847 ExecStartPre=/opt/google-cloud-ops-agent/libexec/google_cloud_ops_agent_engine -service=fluentbit -in /etc/google-cloud-ops-agent/config.yaml -logs ${LOGS_DIRECTORY} -state ${STATE_DIR>
 Main PID: 1141421 (code=exited, status=0/SUCCESS)

Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Control process exited, code=exited status=1
Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Failed with result 'exit-code'.
Jun 30 22:21:08 centos8-2 systemd[1]: Failed to start Google Cloud Ops Agent - Logging Agent.
Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Service RestartSec=100ms expired, scheduling restart.
Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Scheduled restart job, restart counter is at 5.
Jun 30 22:21:08 centos8-2 systemd[1]: Stopped Google Cloud Ops Agent - Logging Agent.
Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Start request repeated too quickly.
Jun 30 22:21:08 centos8-2 systemd[1]: google-cloud-ops-agent-fluent-bit.service: Failed with result 'exit-code'.
Jun 30 22:21:08 centos8-2 systemd[1]: Failed to start Google Cloud Ops Agent - Logging Agent.

Utilizza journalctl per ottenere il messaggio di errore esatto:

sudo journalctl -xe | grep "google_cloud_ops_agent_engine"

Potresti visualizzare un messaggio simile al seguente:

Jun 30 22:00:26 centos8-2 google_cloud_ops_agent_engine[1141491]: 2021/06/30 22:00:26 the agent config file is not valid YAML. detailed error: yaml: line 21: did not find expected key

Windows

failed to generate config files: can't parse configuration: yaml: line 20: could not find expected ':'

Per correggere l'errore, correggi la configurazione non valida e riavvia l'agente. Per riferimento, consulta la guida Configura Ops Agent.

L'agente si arresta in modo anomalo e il report menziona NVIDIA

Stai tentando di eseguire Ops Agent su una VM di Compute Engine con GPU collegate. L'agente si arresta in modo anomalo e l'output menziona NVIDIA.

Si tratta di un problema noto con le versioni 2.39.0 e 2.40.0 di Ops Agent. Per risolvere il problema, installa la versione 2.38.0 di Ops Agent o le versioni 2.41.0 o successive.

Le informazioni sullo stato nella Google Cloud console non sono corrette

La Google Cloud console segnala informazioni sullo stato degli agenti sulle VM di Compute Engine in varie dashboard, ad esempio la dashboard Istanze VM in Cloud Monitoring. Se queste informazioni non corrispondono a quelle previste, la causa potrebbe essere semplicemente un ritardo dovuto al fatto che le modifiche alla configurazione vengono applicate al sistema. Tuttavia, informazioni impreviste potrebbero anche indicare che l'agente non è in esecuzione come previsto.

L'agente installato viene segnalato dalla Google Cloud console come non rilevato

L'agente deve essere in esecuzione e importare i dati affinché la Google Cloud console riconosca la sua presenza. Se hai installato l'agente, ma lo stato della console rimane "Non rilevato", significa che l'agente non è in esecuzione o è in esecuzione, ma non importa i dati. Per saperne di più, consulta le seguenti risorse:

L'agente rimosso viene segnalato dalla Google Cloud console come installato

Dopo aver disinstallato l'agente, la Google Cloud console potrebbe impiegare fino a un' ora per segnalare questa modifica.