En esta página, se describe cómo configurar y ver los registros de operaciones de almacenamiento por lotes con Cloud Logging. Se puede configurar un trabajo de operaciones de almacenamiento por lotes para generar entradas de registro de Cloud Logging para cada trabajo de transformación. Cada entrada de registro corresponde a la transformación intentada de un objeto.
Las operaciones de almacenamiento por lotes admiten el registro en Cloud Logging y en los registros de auditoría de Cloud Storage. Si bien ambas opciones capturan acciones de operaciones de almacenamiento por lotes, recomendamos usar Cloud Logging. Cloud Logging proporciona una plataforma centralizada para el análisis de registros, la supervisión en tiempo real y el filtrado avanzado, lo que ofrece una solución sólida para administrar y comprender la actividad de tus operaciones por lotes.
Antes de comenzar
Verifica que tengas acceso a Cloud Logging. Para usar Cloud Logging, recomendamos otorgar el rol de Identity and Access Management Logs Viewer (roles/logging.viewer). El rol de Identity and Access Management Logs Viewer (roles/logging.viewer) proporciona los permisos de Identity and Access Management necesarios para ver tus datos de Cloud Logging.
Para obtener más información sobre los permisos de acceso de Logging, consulta Control de acceso
con IAM.
Para verificar y otorgar los permisos de IAM, completa los siguientes pasos:
- Visualiza el acceso actual para verificar el acceso que tiene cada entidad.
- Otorga una función a los principales relevantes de tu proyecto.
Comprende los detalles de registro
Cuando el registro está habilitado, las operaciones de almacenamiento por lotes capturan los siguientes detalles:
Acción registrable: El valor de la acción registrable siempre es
transform.Estados registrables: Para cada acción, puedes elegir registrar uno o ambos de los siguientes estados:
SUCCEEDED: La acción se realizó correctamente.FAILED: La acción falló.
Habilitar registro
Para habilitar el registro, especifica las acciones y los estados que se registrarán.
Línea de comandos
Cuando crees un trabajo de operaciones de almacenamiento por lotes con gcloud
storage batch-operations jobs create, usa las marcas --log-actions y
--log-action-states para habilitar el registro.
gcloud storage batch-operations jobs create JOB_NAME \ --manifest-location=MANIFEST_LOCATION \ --delete-object \ --log-actions=transform \ --log-action-states=LOG_ACTION_STATES
Aquí:
JOB_NAMEes el nombre que deseas asignarle a tu trabajo. Por ejemplo,my-job.MANIFEST_LOCATIONes la ubicación de tu manifiesto. Por ejemplo,gs://my-bucket/manifest.csv.LOG_ACTION_STATESes una lista separada por comas de los estados que se registrarán. Por ejemplo,succeeded,failed.
API de REST
Create a storage batch operations
job
con un
LoggingConfig.
{ "loggingConfig": { "logActions": ["TRANSFORM"], "logActionStates": ["LOG_ACTION_STATES"], } }
Aquí:
LOG_ACTION_STATES es una lista separada por comas de los estados que se registrarán. Por ejemplo, "SUCCEEDED","FAILED".
Ver registros
Para ver los registros de operaciones de almacenamiento por lotes, haz lo siguiente:
Console
Ve al Cloud de Confiance menú de navegación menu y selecciona Logging > Explorador de registros :<br\></br\>
Selecciona un Cloud de Confiance proyecto.
En el menú Actualizar (Upgrade), cambia del Visor de registros heredados a Explorador de registros.
Para filtrar tus registros de modo que solo muestren las entradas de operaciones de almacenamiento por lotes, escribe
storage_batch_operations_joben el campo de consulta y haz clic en Ejecutar consulta.En el panel Resultados de la consulta, haz clic en Editar hora para cambiar el período de los resultados mostrados.
Para obtener más información sobre el uso del Explorador de registros, consulta Usa el Explorador de registros.
Línea de comandos
Para usar gcloud CLI a fin de buscar registros
de operaciones de almacenamiento por lotes, usa el
gcloud logging read
comando.
Especifica un filtro para limitar tus resultados a los registros de operaciones de almacenamiento por lotes.
gcloud logging read "resource.type=storage_batch_operations_job"
API de REST
Usa el entries.list
método de la API de Cloud Logging.
Para filtrar tus resultados y que solo incluyan las entradas relacionadas con las operaciones de almacenamiento por lotes, usa el campo filter. El siguiente es un objeto de solicitud JSON de muestra:
{
"resourceNames":
[
"projects/my-project-name"
],
"orderBy": "timestamp desc",
"filter": "resource.type=\"storage_batch_operations_job\""
}
Aquí:
my-project-name es el nombre de tu proyecto.
Formato de registro de operaciones de almacenamiento por lotes
Todos los campos específicos de las operaciones de almacenamiento por lotes se encuentran dentro de un objeto jsonPayload. Si bien el contenido exacto de jsonPayload varía según
el tipo de trabajo, existe una estructura común compartida en todas las
TransformActivityLog entradas. En esta sección, se describen los campos de registro comunes y, luego, se detallan los campos específicos de la operación.
Campos de registro comunes
Los siguientes campos aparecen en todos los registros:
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" // } // } }En la siguiente tabla, se describe cada uno de los campos de registro comunes:
Campos de registro comunes Tipo Descripción @typeString Especifica el tipo de carga útil de la entrada de registro y que el registro representa un TransformActivityLogpara las operaciones de almacenamiento por lotes.completeTimeMarca de tiempo La marca de tiempo compatible con ISO 8601 en la que se completó la operación. statusObjeto Proporciona información sobre el resultado de la actividad de operaciones por lotes. status.errorMessageString Un mensaje de error si la operación falla. El mensaje de error solo aparece si el valor de status.statusCodeno esOK.status.errorTypeString El tipo de error. El tipo de error solo aparece si el valor de status.statusCodeno esOK.status.statusCodeString El código de estado de la operación. La operación se realiza correctamente si el valor es OK; cualquier otro valor indica una falla.logNameString El nombre completo del recurso del registro, que indica el proyecto y el flujo de registro. receiveTimestampMarca de tiempo La marca de tiempo en la que el sistema de registro recibió la entrada de registro. resourceObjeto Información sobre el recurso que generó la entrada de registro. resource.labelsObjeto Pares clave-valor que proporcionan información de identificación adicional sobre el recurso. resource.typeString El tipo de recurso que generó el registro. objectMetadataBeforeObjeto Contiene metadatos del objeto antes de que se intentara la operación por lotes. objectMetadataBefore.gcsObjectObjeto Detalles sobre el objeto. objectMetadataBefore.gcsObject.bucketString El nombre del bucket en el que reside el objeto. objectMetadataBefore.gcsObject.generationString El número de generación del objeto antes de la operación. objectMetadataBefore.gcsObject.objectKeyString La ruta de acceso completa del objeto dentro del bucket. Contenido
jsonPayloadespecífico de la operaciónLa diferencia entre las entradas de registro para diferentes operaciones por lotes radica en el objeto de nivel superior anidado dentro de
jsonPayload. Solo uno de los siguientes objetos está disponible en una entrada de registro determinada, que corresponde a la operación por lotes específica que se realizó:Borrar objeto (
DeleteObject)jsonPayload: { "DeleteObject": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } } } }Colocar una conservación de objetos (
PutObjectHold)jsonPayload: { "PutObjectHold": { "objectMetadataBefore": { "gcsObject": { "bucket": "test-bucket", "generation": "1678912345678901", "objectKey": "test_object.txt" } }, "temporaryHoldAfter": True, "eventBasedHoldAfter": True } }Reescribir objeto (
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" } }Colocar metadatos (
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" } } }
En la siguiente tabla, se describen los campos de registro específicos de la operación:
Campos de registro específicos de la operación Tipo Descripción PutObjectHoldObjeto Indica una operación de conservación en un objeto. PutObjectHold.temporaryHoldAfterBooleano Si el valor es True, indica que se aplicó una conservación temporal al objeto después de que se completó el trabajo de operaciones de almacenamiento por lotes. Los valores válidos sonTrueoFalse.PutObjectHold.eventBasedHoldAfterBooleano Si el valor es True, indica que se aplicó una conservación basada en eventos al objeto después de que se completó el trabajo de operaciones de almacenamiento por lotes. Los valores válidos sonTrueoFalse.RewriteObjectObjeto Indica una operación de reescritura en un objeto. RewriteObject.kmsKeyVersionAfterString La versión de la clave de Cloud Key Management Service que se usó después del trabajo de reescritura. El campo kmsKeyVersionAfterse propaga si la clave de encriptación del objeto cambió como resultado de la reescritura. Es un campo opcional, lo que significa que es posible que no esté presente si la versión de la clave de Cloud KMS no cambió después de la reescritura.PutMetadataObjeto Indica una operación de actualización de metadatos en un objeto. PutMetadata.content_disposition_afterString Especifica el Content-Dispositionvalor del encabezado después de que se completa elPutMetadatatrabajo. Es un campo opcional y solo se propaga si se configuró o modificó la disposición del contenido.PutMetadata.content_encoding_afterString Especifica el valor del encabezado Content-Encodingdespués de que se completa el trabajoPutMetadata. Es un campo opcional y solo se propaga si se configuró o modificó la codificación del contenido.PutMetadata.content_language_afterString Especifica el valor del encabezado Content-Languagedespués de que se completa el trabajoPutMetadata. Es un campo opcional y solo se propaga si se configuró o modificó el idioma del contenido.PutMetadata.content_type_afterString Especifica el Content-Typevalor del encabezado después de que se completa elPutMetadatatrabajo. Es un campo opcional y solo se propaga si se configuró o modificó el tipo de contenido.PutMetadata.cache_control_afterString Especifica el valor del encabezado Cache-Controldespués de que se completa el trabajoPutMetadata. Es un campo opcional y solo se propaga si se configuró o modificó el control de caché.PutMetadata.custom_time_afterString Especifica el Custom-Timevalor del encabezado después de que se completa elPutMetadatatrabajo. Es un campo opcional y solo se propaga si se configuró o modificó la hora personalizada.PutMetadata.custom_metadata_afterMapa (clave: cadena, valor: cadena) Contiene un mapa de Custom- Metadatapares clave-valor después de la transformación. Este campo incluye cualquier metadato definido por el usuario que se haya configurado o modificado en el objeto. Permite el almacenamiento flexible de metadatos adicionales.