Scrivere voci di log ed eseguirne query utilizzando uno script Python
Questa guida rapida introduce alcune delle funzionalità di Cloud Logging e ti mostra come fare quanto segue:
- Scrivi le voci di log utilizzando uno script Python.
- Visualizza le voci di log utilizzando uno script Python.
- Elimina le voci di log utilizzando uno script Python.
- Esegui il routing dei log in un bucket Cloud Storage.
Il logging può instradare le voci di log alle seguenti destinazioni:
- Bucket Cloud Storage
- Set di dati di BigQuery
- Pub/Sub
- Bucket di Logging
- Progetti Google Cloud
Prima di iniziare
Per completare questa guida introduttiva, devi disporre di un progetto Google Cloud con la fatturazione abilitata. Se non hai un progetto Google Cloud o se la fatturazione non è attivata per il tuo progetto Google Cloud, svolgi i seguenti passaggi:- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
Questa guida rapida utilizza Cloud Logging e Cloud Storage. Utilizzo di questi delle risorse può comportare dei costi. Al termine della guida rapida, puoi per evitare la fatturazione continua eliminando le risorse che hai creato. Consulta Esegui la pulizia in questa pagina per ulteriori dettagli.
Per iniziare
Per utilizzare l'ambiente Cloud Shell o un ambiente Linux generico completa questa guida rapida. Python è preinstallato in Cloud Shell.
Cloud Shell
Apri Cloud Shell e verifica la configurazione del progetto Google Cloud:
Nella console Google Cloud, fai clic su terminal. Attivare Cloud Shell.
Cloud Shell si apre in una finestra e mostra un messaggio di benvenuto.
Il messaggio di benvenuto ripete l'ID progetto Google Cloud configurato. Se non si tratta del progetto Google Cloud che vuoi utilizzare, esegui il seguente comando dopo aver sostituito PROJECT_ID con l'ID del progetto:
gcloud config set project PROJECT_ID
Linux
Assicurati che Python sia installato e configurato. Per informazioni sulla preparazione della macchina per lo sviluppo Python, consulta Impostazione di un ambiente di sviluppo Python.
Installa la libreria client di Cloud Logging:
pip install --upgrade google-cloud-logging
Configura le autorizzazioni Identity and Access Management per il tuo progetto Google Cloud. Nel passaggi seguenti, crei un account di servizio per progetto Google Cloud, quindi generi e scarichi un file sulla workstation Linux.
-
Nella console Google Cloud, vai alla pagina Account di servizio:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo IAM e Console di amministrazione.
Seleziona il progetto Google Cloud della guida rapida e fai clic su Crea un account di servizio:
- Inserisci un nome per l'account.
- Inserisci una descrizione dell'account.
- Fai clic su Crea e continua.
Fai clic sul campo Seleziona un ruolo e seleziona Amministratore Logging.
Fai clic su Fine per completare la creazione dell'account di servizio.
Crea un file della chiave e scaricalo sulla workstation:
- Per il tuo account di servizio, fai clic su more_vert Altre opzioni, e seleziona Gestisci chiavi.
- Nel riquadro Chiavi, fai clic su Aggiungi chiave.
- Fai clic su Crea nuova chiave.
In Tipo di chiave, seleziona JSON e fai clic su Crea. Dopo qualche istante, in una finestra viene visualizzato un messaggio simile a:
-
Nella workstation Linux, fornisci le credenziali di autenticazione all'applicazione impostando la variabile di ambiente
GOOGLE_APPLICATION_CREDENTIALS
sul percorso del file della chiave. Ad esempio:export GOOGLE_APPLICATION_CREDENTIALS="/home/user/Downloads/FILE_NAME.json"
Questa variabile di ambiente si applica solo alla sessione di shell attuale, Pertanto, se apri una nuova sessione, imposta di nuovo la variabile.
Clona origine
Per configurare Cloud Shell per questa guida rapida, segui questi passaggi:
Clona il progetto GitHub
python-logging
:git clone https://github.com/googleapis/python-logging
La directory
samples/snippets
contiene i due script utilizzati in questa guida rapida:snippets.py
consente di gestire le voci in un log.export.py
ti consente di gestire le esportazioni dei log.
Passa alla directory
snippets
:cd python-logging/samples/snippets
Scrivi voci di log
Lo script snippets.py
utilizza le librerie client Python per scrivere voci di log
in Logging. Quando l'opzione write
è specificata nel comando
lo script scrive le seguenti voci di log:
- Una voce con dati non strutturati e nessun livello di gravità specificato.
- Una voce con dati non strutturati e un livello di gravità di
ERROR
. - Una voce con dati strutturati JSON e nessun livello di gravità specificato.
Per scrivere nuove voci di log nel log my-log
, esegui lo script snippets.py
con
l'opzione write
:
python snippets.py my-log write
Visualizza voci di log
Per visualizzare le voci di log in Cloud Shell, esegui snippets.py
script con l'opzione list
:
python snippets.py my-log list
Il comando viene completato con il risultato:
Listing entries for logger my-log: * 2018-11-15T16:05:35.548471+00:00: Hello, world! * 2018-11-15T16:05:35.647190+00:00: Goodbye, world! * 2018-11-15T16:05:35.726315+00:00: {u'favorite_color': u'Blue', u'quest': u'Find the Holy Grail', u'name': u'King Arthur'}
Se il risultato non mostra voci, riprova a eseguire il comando. Sono necessari momenti per consentire a Logging di ricevere ed elaborare le voci di log.
Puoi anche visualizzare le voci di log utilizzando Esplora log. Per ulteriori informazioni vedi Visualizzare i log utilizzando Esplora log.
Eliminare le voci di log
Per eliminare tutte le voci di log nel log my-log
, esegui snippets.py
con l'opzione delete
:
python snippets.py my-log delete
Il comando viene completato con il risultato:
Deleted all logging entries for my-log
.
Log di route
In questa sezione:
- Crea un bucket Cloud Storage come destinazione per i dati.
- Crea un sink che copia le nuove voci di log nella destinazione.
- Aggiorna le autorizzazioni del bucket Cloud Storage.
- Scrivi voci di log in Logging.
- Facoltativamente, verifica il contenuto del bucket Cloud Storage.
Crea destinazione
La destinazione di esportazione per questa guida rapida è un bucket Cloud Storage. Per creare un bucket Cloud Storage, segui questi passaggi:
-
Nella console Google Cloud, vai alla pagina Bucket:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Cloud Storage.
- Fai clic su Crea bucket.
- Inserisci un nome per il bucket.
- In Tipo di località, seleziona Regione, in modo da scegliere una località del bucket con con una latenza minima.
- Per Classe di archiviazione predefinita, seleziona Standard.
- Per Controllo dell'accesso, seleziona Granulare.
- Per Strumenti di protezione, seleziona Nessuno, quindi fai clic su Crea.
Questa guida rapida utilizza il nome di un bucket Cloud Storage
myloggingproject-1
.
Crea un sink
Un sink è una regola che determina se Logging instrada una nuova la voce di log in una destinazione. Un sink ha tre attributi:
- Nome
- Destinazione
- Filtro
Per ulteriori informazioni sui canali, consulta Canali.
Se una voce di log appena raggiunta soddisfa le condizioni della query, allora viene indirizzato alla destinazione.
Lo script export.py
utilizza le librerie client Python per creare, elencare,
modificare ed eliminare i sink. Per creare l'emissario mysink
che esporta tutte le voci di log con una gravità di almeno INFO
nel bucket Cloud Storage myloggingproject-1
, esegui il seguente comando:
python export.py create mysink myloggingproject-1 "severity>=INFO"
Per visualizzare i sink, esegui lo script export.py
con l'opzione list
:
python export.py list
Lo script restituisce quanto segue:
mysink: severity>=INFO -> storage.googleapis.com/myloggingproject-1
Aggiorna le autorizzazioni della destinazione
Le autorizzazioni della destinazione, in questo caso l'account Cloud Storage
non vengono modificate quando crei un sink mediante lo script export.py
.
Devi modificare le impostazioni delle autorizzazioni del bucket Cloud Storage in
concedi l'autorizzazione di scrittura al sink. Per informazioni sugli account di servizio,
ambiti di accesso e ruoli Identity and Access Management,
consulta Account di servizio.
Per aggiornare le autorizzazioni nel bucket Cloud Storage:
Identifica l'identità dello scrittore del sink:
-
Nella console Google Cloud, vai alla pagina Router dei log:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Logging.
Viene visualizzata una tabella di riepilogo dei sink.
Individua il tuo canale nella tabella, seleziona more_vert Menu e poi Visualizza i dettagli del canale.
Copia l'identità autore negli appunti.
-
-
Nella console Google Cloud, vai alla pagina Bucket:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Cloud Storage.
Per aprire la visualizzazione dettagliata, fai clic sul nome del bucket.
Seleziona Autorizzazioni e fai clic su Concedi l'accesso.
Incolla l'identità autore nella casella Nuove entità. Rimuovi il Prefisso
serviceAccount:
dell'indirizzo di identità dell'autore.Imposta Ruolo su
Storage Object Creator
e poi fai clic su Salva.
Per saperne di più, consulta Impostare le autorizzazioni di destinazione.
Convalida il sink
Per verificare che l'obiettivo e la destinazione siano configurati correttamente:
Scrivi nuove voci di log nel log
my-log
:python snippets.py my-log write
Visualizza i contenuti del bucket Cloud Storage:
-
Nella console Google Cloud, vai alla pagina Bucket:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Cloud Storage.
Per aprire la visualizzazione dettagliata, fai clic sul nome del bucket. I dettagli mostra l'elenco delle cartelle che contengono i dati. Se non esistono dati nella tua bucket, viene visualizzato il seguente messaggio:
There are no live objects in this bucket.
Come descritto nella sezione Voci di log in arrivo, potrebbero essere necessarie 2 o 3 ore prima che le prime voci vengano visualizzate o prima di ricevere la notifica di un errore di configurazione.
Una volta che il bucket ha ricevuto i dati, la visualizzazione dettagliata mostra un risultato simile al seguente:
I dati di ogni cartella sono organizzati in una serie di cartelle etichettate con la cartella di primo livello composta da un nome log successivamente, l'anno, il mese e il giorno. Per visualizzare i dati che sono stati esportate dal sink, fai clic sul nome della cartella
my-log
, continuare a fare clic sulle sottocartelle con anno, mese e giorno finché raggiunge un file che termina conjson
:Il file JSON contiene le voci di log esportate nel tuo nel bucket Cloud Storage. Fai clic sul nome del file JSON per visualizzarne il contenuto. I contenuti sono simile a:
{"insertId":"yf1cshfoivz48", "logName":"projects/loggingproject-222616/logs/my-log", "receiveTimestamp":"2018-11-15T23:06:14.738729911Z", "resource":{"labels":{"project_id":"loggingproject-222616"},"type":"global"}, "severity":"ERROR", "textPayload":"Goodbye, world!", "timestamp":"2018-11-15T23:06:14.738729911Z"}
Perché il livello di gravità di
ERROR
è superiore a quello a livello diINFO
, la voce di log contenente la stringa ""Addio mondo!" viene esportato nella destinazione del sink. Le altre voci di log scritte non sono state esportate nella destinazione perché il loro livello di gravità è stato impostato sul valore predefinito, che è inferiore aINFO
.
-
Risoluzione dei problemi
Esistono diversi motivi per cui un bucket Cloud Storage potrebbe essere vuoto:
Il bucket non ha ricevuto dati. Potrebbero essere necessarie 2 o 3 ore prima che le prime voci vengano visualizzate nella o prima di ricevere la notifica di un errore di configurazione. Per ulteriori informazioni, consulta Voce del log in ritardo.
Si è verificato un errore di configurazione. In questo caso, riceverai un messaggio email simile alla seguente riga dell'oggetto:
[ACTION REQUIRED] Logging export config error in myloggingproject.
I contenuti del corpo dell'email descrivono il problema di configurazione. Ad esempio, se non aggiorni le autorizzazioni di destinazione, nell'email viene elencato il seguente codice di errore:
bucket_permission_denied
Per correggere questa particolare condizione, consulta Aggiorna le autorizzazioni della destinazione in questa pagina.
Non sono state scritte voci di log dopo la creazione del sink. Il sink applicata solo alle nuove voci di log arrivate. Per correggere la situazione, scrivi nuove voci di log:
python snippets.py my-log write
Esegui la pulizia
Per evitare che al tuo account Google Cloud vengano addebitati costi per le risorse utilizzate in questa pagina, segui questi passaggi.
(Facoltativo) Elimina le voci di log che hai creato. Se non elimini le voci del log, queste scadranno e verranno rimosse. Vedi Quote e limiti.
Per eliminare tutte le voci di log nel log
my-log
, esegui questo comando:python snippets.py my-log delete
Elimina il progetto Google Cloud o le risorse di avvio rapido.
Per eliminare il tuo progetto Google Cloud, nel riquadro Informazioni sul progetto della console Google Cloud, fai clic su Vai alle impostazioni progetto, quindi fai clic su Chiudi.
Per eliminare le risorse della guida rapida:
Elimina il sink eseguendo questo comando:
python export.py delete mysink
Elimina il bucket Cloud Storage. Vai alla sezione nella console Google Cloud e fai clic su Storage > Bucket. Seleziona la casella accanto al nome del bucket e fai clic su Elimina.
Passaggi successivi
- Per scoprire come leggere, scrivere e configurare i log delle tue applicazioni, consulta l'API Cloud Logging.
- Per informazioni su Esplora log, consulta Visualizza i log utilizzando Esplora log.
- Per scoprire come indirizzare i dati dei log alle destinazioni supportate, consulta la panoramica su routing e archiviazione.
- Per scoprire come raccogliere le voci di log dalle istanze VM, consulta la Panoramica di Ops Agent.
- Per informazioni su controllo e conformità, consulta Panoramica di Cloud Audit Logs.