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 Cloud Logging per ogni job di trasformazione. Ogni voce di log corrisponde al tentativo di trasformazione di un oggetto.
Le operazioni batch di archiviazione supportano la registrazione sia in Cloud Logging che in Cloud Storage Cloud Audit Logs. 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 efficace 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 Identity and Access Management Logs Viewer (roles/logging.viewer). Il ruolo Identity and Access Management Logs Viewer (roles/logging.viewer) fornisce le autorizzazioni Identity and Access Management necessarie per visualizzare i dati di Cloud Logging.
Per saperne di più sulle autorizzazioni di accesso a Logging, consulta Controllo dell'accesso con IAM.
Per verificare e concedere le autorizzazioni IAM, completa i seguenti passaggi:
- Visualizza l'accesso attuale per verificare l'accesso di ogni entità.
- Concedi un ruolo alle entità pertinenti nel tuo progetto.
Informazioni sui dettagli di registrazione
Quando la registrazione è abilitata, le operazioni batch di archiviazione acquisiscono i seguenti dettagli:
Azione registrata: il valore dell'azione registrata è sempre
transform.Stati registrabili: 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 attivare la registrazione, 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 attivare la registrazione.
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 dare al tuo lavoro. Ad esempio,my-job.MANIFEST_LOCATIONè la posizione del tuo manifest. Ad esempio,gs://my-bucket/manifest.csv.LOG_ACTION_STATESè un elenco separato da virgole di stati 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 separato da virgole
di stati da registrare. Ad esempio, "SUCCEEDED","FAILED".
Visualizza i log
Per visualizzare i log delle operazioni batch di archiviazione:
Console
Vai al Google Cloud menu di navigazione menu e seleziona Logging > Esplora log :<br\></br\>
Seleziona un Google Cloud progetto.
Nel menu Esegui l'upgrade, passa dal 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 cui 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 comando gcloud logging read.
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 metodo dell'API Cloud Logging entries.list.
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 oggetto richiesta JSON di esempio:
{
"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 del 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 al
tipo di lavoro, esiste una struttura comune condivisa in tutte le voci
TransformActivityLog. Questa sezione descrive i campi di log comuni e
poi quelli 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 allo standard ISO 8601 in cui è stata completata l'operazione. statusOggetto Fornisce informazioni sul risultato dell'attività di operazione batch. status.errorMessageStringa Un messaggio di errore se l'operazione non va a buon fine. 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 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 il flusso di log. receiveTimestampTimestamp Il timestamp di ricezione della voce di log da parte del 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 per l'operazioneLa differenza tra le voci di log per 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" } } } }Metti in attesa l'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 i 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 per l'operazione Tipo Descrizione PutObjectHoldOggetto Indica un'operazione di sospensione su un oggetto. PutObjectHold.temporaryHoldAfterBooleano Se il valore è True, indica che è stato applicato un blocco temporaneo all'oggetto dopo il completamento del job batch di operazioni di archiviazione. I valori validi sonoTrueoFalse.PutObjectHold.eventBasedHoldAfterBooleano Se il valore è True, indica che è stato applicato un blocco basato su eventi all'oggetto dopo il completamento 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 Cloud Key Management Service utilizzata dopo il job di riscrittura. Il campo kmsKeyVersionAfterviene compilato se la chiave di crittografia dell'oggetto è cambiata a seguito della riscrittura. È un campo facoltativo, il che significa che potrebbe non essere presente se la versione della chiave 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-Dispositiondopo il completamento del jobPutMetadata. Si tratta di 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-Encodingdopo il completamento 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-Languagedopo il completamento 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-Typedopo il completamento del jobPutMetadata. È un campo facoltativo e viene compilato solo se il tipo di contenuto è stato impostato o modificato.PutMetadata.cache_control_afterStringa Specifica il valore dell'intestazione Cache-Controldopo il completamento del jobPutMetadata. Si tratta di un campo facoltativo che viene compilato solo se il controllo della cache è stato impostato o modificato.PutMetadata.custom_time_afterStringa Specifica il valore dell'intestazione Custom-Timedopo il completamento 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 coppie chiave-valore Custom- Metadatadopo la trasformazione. Questo campo include tutti i metadati definiti dall'utente impostati o modificati nell'oggetto. Consente l'archiviazione flessibile di metadati aggiuntivi.