Questa pagina descrive come configurare e visualizzare i log delle operazioni batch di archiviazione utilizzando Cloud Logging. Un job di operazioni batch di archiviazione può essere configurato per generare voci di log di Cloud Logging per ogni job di trasformazione. Ogni voce di log corrisponde alla trasformazione tentata di un oggetto.
Le operazioni batch di archiviazione supportano il logging sia in Cloud Logging sia in Cloud Audit Logs di Cloud Storage. Sebbene entrambe le opzioni acquisiscano le azioni delle operazioni batch di archiviazione, ti consigliamo di utilizzare Cloud Logging. Cloud Logging fornisce una piattaforma centralizzata per l'analisi dei log, il monitoraggio in tempo reale e il filtraggio avanzato, offrendo una soluzione solida per la gestione e la comprensione dell'attività delle operazioni batch.
Prima di iniziare
Verifica di avere accesso a Cloud Logging. Per utilizzare Cloud Logging, ti consigliamo di concedere il ruolo di Identity and Access Management Logs Viewer (roles/logging.viewer). Il ruolo di Identity and Access Management Logs Viewer (roles/logging.viewer) fornisce le autorizzazioni di Identity and Access Management necessarie per visualizzare i dati di Cloud Logging.
Per ulteriori informazioni sulle autorizzazioni di accesso a Logging, vedi Controllo dell'accesso
con IAM.
Per verificare e concedere le autorizzazioni IAM:
- Visualizza l'accesso attuale per verificare l'accesso di ogni entità.
- Concedi un ruolo a entità pertinenti nel tuo progetto.
Informazioni sui dettagli di logging
Quando il logging è abilitato, le operazioni batch di archiviazione acquisiscono i seguenti dettagli:
Azione registrata: il valore dell'azione registrata è sempre
transform.Stati registrati: per ogni azione, puoi scegliere di registrare uno o entrambi i seguenti stati:
SUCCEEDED: l'azione è stata eseguita correttamente.FAILED: l'azione non è riuscita.
Abilita il logging
Per abilitare il logging, specifica le azioni e gli stati da registrare.
Riga di comando
Quando crei un job di operazioni batch di archiviazione con gcloud
storage batch-operations jobs create, utilizza i flag --log-actions e
--log-action-states per abilitare il logging.
gcloud storage batch-operations jobs create JOB_NAME \ --manifest-location=MANIFEST_LOCATION \ --delete-object \ --log-actions=transform \ --log-action-states=LOG_ACTION_STATES
Dove:
JOB_NAMEè il nome che vuoi assegnare al job. Ad esempio,my-job.MANIFEST_LOCATIONè la posizione del manifest. Ad esempio,gs://my-bucket/manifest.csv.LOG_ACTION_STATESè un elenco di stati separati da virgole da registrare. Ad esempio,succeeded,failed.
API REST
Create a storage batch operations
job
con un
LoggingConfig.
{ "loggingConfig": { "logActions": ["TRANSFORM"], "logActionStates": ["LOG_ACTION_STATES"], } }
Dove:
LOG_ACTION_STATES è un elenco di stati separati da virgole da registrare. Ad esempio, "SUCCEEDED","FAILED".
Visualizza i log
Per visualizzare i log delle operazioni batch di archiviazione:
Console
Vai al Cloud de Confiance menu di navigazione menu e seleziona Logging > Esplora log :<br\></br\>
Seleziona un Cloud de Confiance progetto.
Dal menu Esegui l'upgrade, passa da Visualizzatore log legacy a Esplora log.
Per filtrare i log in modo da mostrare solo le voci delle operazioni batch di archiviazione, digita
storage_batch_operations_jobnel campo della query e fai clic su Esegui query.Nel riquadro Risultati della query, fai clic su Modifica data/ora per modificare il periodo di tempo per il quale restituire i risultati.
Per ulteriori informazioni sull'utilizzo di Esplora log, vedi Utilizzo di Esplora log.
Riga di comando
Per utilizzare gcloud CLI per cercare i log delle operazioni batch di archiviazione, utilizza il
gcloud logging read
comando.
Specifica un filtro per limitare i risultati ai log delle operazioni batch di archiviazione.
gcloud logging read "resource.type=storage_batch_operations_job"
API REST
Utilizza il entries.list
metodo dell'API Cloud Logging.
Per filtrare i risultati in modo da includere solo le voci relative alle operazioni batch di archiviazione, utilizza il campo filter. Di seguito è riportato un esempio di oggetto della richiesta JSON:
{
"resourceNames":
[
"projects/my-project-name"
],
"orderBy": "timestamp desc",
"filter": "resource.type=\"storage_batch_operations_job\""
}
Dove:
my-project-name è il nome del tuo progetto.
Formato dei log delle operazioni batch di archiviazione
Tutti i campi specifici delle operazioni batch di archiviazione sono contenuti in un oggetto jsonPayload. Sebbene il contenuto esatto di jsonPayload vari in base a il tipo di prestazione, esiste una struttura comune condivisa in tutte le TransformActivityLog voci. Questa sezione illustra i campi di log comuni e poi i campi specifici dell'operazione.
Campi di log comuni
I seguenti campi vengono visualizzati in tutti i log:
jsonPayload: { "@type": "type.googleapis.com/google.cloud.storagebatchoperations.logging.TransformActivityLog", "completeTime": "YYYY-MM-DDTHH:MM:SS.SSSSSSSSSZ", "status": { "errorMessage": "String indicating error", "errorType": "ENUM_VALUE", "statusCode": "ENUM_VALUE" }, "logName": "projects/PROJECT_ID/logs/storagebatchoperations.googleapis.com%2Ftransform_activity", "receiveTimestamp": "YYYY-MM-DDTHH:MM:SS.SSSSSSSSSZ", "resource": { "labels": { "location":"us-central1", "job_id": "BATCH_JOB_ID", "resource_container": "RESOURCE_CONTAINER", // ... other labels }, "type": "storagebatchoperations.googleapis.com/Job" }, // Operation-specific details will be nested here (for example, // "DeleteObject", "PutObjectHold", "RewriteObject", "PutMetadata") // Each operation-specific object will also contain the following // object: "objectMetadataBefore": { // "gcsObject": { // "bucket": "BUCKET_NAME", // "generation": "GENERATION_NUMBER", // "objectKey": "OBJECT_PATH" // } // } }La tabella seguente descrive ciascuno dei campi di log comuni:
Campi di log comuni Tipo Descrizione @typeStringa Specifica il tipo di payload della voce di log e indica che il log rappresenta un TransformActivityLogper le operazioni batch di archiviazione.completeTimeTimestamp Il timestamp conforme a ISO 8601 in cui l'operazione è stata completata. statusOggetto Fornisce informazioni sul risultato dell'attività dell'operazione batch. status.errorMessageStringa Un messaggio di errore se l'operazione non riesce. Il messaggio di errore viene visualizzato solo se il valore di status.statusCodenon èOK.status.errorTypeStringa Il tipo di errore. Il tipo di errore viene visualizzato solo se il valore di status.statusCodenon èOK.status.statusCodeStringa Il codice di stato dell'operazione. L'operazione ha esito positivo se il valore è OK; qualsiasi altro valore indica un errore.logNameStringa Il nome completo della risorsa del log, che indica il progetto e lo stream di log. receiveTimestampTimestamp Il timestamp in cui la voce di log è stata ricevuta dal sistema di logging. resourceOggetto Informazioni sulla risorsa che ha generato la voce di log. resource.labelsOggetto Coppie chiave-valore che forniscono ulteriori informazioni identificative sulla risorsa. resource.typeStringa Il tipo di risorsa che ha generato il log. objectMetadataBeforeOggetto Contiene i metadati dell'oggetto prima del tentativo di operazione batch. objectMetadataBefore.gcsObjectOggetto Dettagli sull'oggetto. objectMetadataBefore.gcsObject.bucketStringa Il nome del bucket in cui si trova l'oggetto. objectMetadataBefore.gcsObject.generationStringa Il numero di generazione dell'oggetto prima dell'operazione. objectMetadataBefore.gcsObject.objectKeyStringa Il percorso completo dell'oggetto all'interno del bucket. Contenuti
jsonPayloadspecifici dell'operazioneLa differenza tra le voci di log per le diverse operazioni batch risiede nell'oggetto di primo livello nidificato all'interno di
jsonPayload. In una determinata voce di log è disponibile solo uno dei seguenti oggetti, corrispondente all'operazione batch specifica eseguita:Elimina oggetto (
DeleteObject)jsonPayload: { "DeleteObject": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } } } }Inserisci blocco oggetto (
PutObjectHold)jsonPayload: { "PutObjectHold": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } }, "temporaryHoldAfter": True, "eventBasedHoldAfter": True } }Riscrivi oggetto (
RewriteObject)jsonPayload: { "RewriteObject": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } }, "kmsKeyVersionAfter": "projects/my-gcp-project/locations/us-central1/keyRings/my-keyring-01/cryptoKeys/my-encryption-key/cryptoKeyVersions/1" } }Inserisci metadati (
PutMetadata)jsonPayload: { "PutMetadata": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } }, "content_disposition_after": "attachment; filename=\"report_final.pdf\"", "content_encoding_after": "gzip", "content_language_after": "en-US", "content_type_after": "application/pdf", "cache_control_after": "public, max-age=3600", "custom_time_after": "2025-06-27T10:00:00Z", "custom_metadata_after": { "project": "marketing", "version": "2.0", "approvedBy": "Admin" } } }
La tabella seguente descrive i campi di log specifici dell'operazione:
Campi di log specifici dell'operazione Tipo Descrizione PutObjectHoldOggetto Indica un'operazione di blocco su un oggetto. PutObjectHold.temporaryHoldAfterBooleano Se il valore è True, indica che è stato applicato un blocco temporaneo all'oggetto al termine del job di operazioni batch di archiviazione. I valori validi sonoTrueoFalse.PutObjectHold.eventBasedHoldAfterBooleano Se il valore è True, indica che è stato applicato un blocco basato su eventi all'oggetto al termine del job di operazioni batch di archiviazione. I valori validi sonoTrueoFalse.RewriteObjectOggetto Indica un'operazione di riscrittura su un oggetto. RewriteObject.kmsKeyVersionAfterStringa La versione della chiave di Cloud Key Management Service utilizzata dopo il job di riscrittura. Il campo kmsKeyVersionAfterviene compilato se la chiave di crittografia dell'oggetto è stata modificata in seguito alla riscrittura. È un campo facoltativo, il che significa che potrebbe non essere presente se la versione della chiave di Cloud KMS è rimasta invariata dopo la riscrittura.PutMetadataOggetto Indica un'operazione di aggiornamento dei metadati su un oggetto. PutMetadata.content_disposition_afterStringa Specifica il valore dell'intestazione Content-Dispositional termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se la disposizione dei contenuti è stata impostata o modificata.PutMetadata.content_encoding_afterStringa Specifica il valore dell'intestazione Content-Encodingal termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se la codifica dei contenuti è stata impostata o modificata.PutMetadata.content_language_afterStringa Specifica il valore dell'intestazione Content-Languageal termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se la lingua dei contenuti è stata impostata o modificata.PutMetadata.content_type_afterStringa Specifica il valore dell'intestazione Content-Typeal termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se il tipo di contenuti è stato impostato o modificato.PutMetadata.cache_control_afterStringa Specifica il valore dell'intestazione Cache-Controlal termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se il controllo della cache è stato impostato o modificato.PutMetadata.custom_time_afterStringa Specifica il valore dell'intestazione Custom-Timeal termine del jobPutMetadata. È un campo facoltativo e viene compilato solo se l'ora personalizzata è stata impostata o modificata.PutMetadata.custom_metadata_afterMappa (chiave: stringa, valore: stringa) Contiene una mappa di Custom- Metadatacoppie chiave-valore dopo la trasformazione. Questo campo include tutti i metadati definiti dall'utente impostati o modificati sull' oggetto. Consente l'archiviazione flessibile di metadati aggiuntivi.