En este documento, se describe cómo configurar el registro de Gemini Code Assist Standard y Enterprise para un proyecto mediante la Google Cloud consola o una API.
Limitaciones
El registro de datos de Gemini Standard y Enterprise en Google Cloud está limitado a las interacciones del usuario con Gemini Code Assist en un IDE.
De forma predeterminada, los registros de Gemini para Google Cloud se recopilan en por proyecto. Si deseas obtener instrucciones para configurar un proyecto centralizado para recopilar registros de varios proyectos, consulta Configura el registro de varios proyectos.
Gemini Code Assist en GitHub no admite el registro con Cloud Logging.
Antes de comenzar
Verifica que tu Google Cloud proyecto esté adjunto a una cuenta de facturación.
Verifica los permisos de IAM
Para configurar el registro de Gemini Code Assist, necesitas permisos de IAM específicos. Para seguir el principio de privilegio mínimo, otorga un rol personalizado que contenga solo los permisos necesarios.
Pídele a tu administrador que cree una función personalizada que incluya los siguientes permisos:
serviceusage.services.enable: Para habilitar las APIs de tu proyectocloudaicompanion.loggingSettings.create: Para crear la configuración de registrocloudaicompanion.loggingSettings.get: Para ver la configuración de registrocloudaicompanion.loggingSettings.list: Para enumerar la configuración de registrocloudaicompanion.loggingSettings.update: Para actualizar la configuración de registrocloudaicompanion.loggingSettingBindings.create: Para vincular la configuración de registro a un proyectocloudaicompanion.loggingSettingBindings.get: Para ver las vinculaciones de la configuración de registrocloudaicompanion.loggingSettingBindings.list: Para enumerar las vinculaciones de la configuración de registro
Como alternativa, puedes otorgar las funciones predefinidas
Administrador de configuración de Gemini para Google Cloud
(roles/cloudaicompanion.settingsAdmin) y
Administrador de uso de servicios
(roles/serviceusage.serviceUsageAdmin). Sin embargo, estas funciones incluyen
permisos para configurar todos los parámetros de configuración de administrador de Gemini para Google Cloud
y administrar el uso de servicios, lo que podría ser más de lo necesario
para configurar los parámetros de configuración de registro.
Configura el registro de Gemini Code Assist
En las siguientes secciones, se proporcionan los pasos necesarios para habilitar la recopilación y el almacenamiento de la actividad de Gemini Code Assist Standard y Enterprise en Cloud Logging, incluidos los siguientes:
Registros de instrucciones y respuestas de Gemini Code Assist Standard y Enterprise, como la entrada del usuario, la información contextual y las respuestas
Registros de metadatos de Gemini Code Assist Standard y Enterprise, como los metadatos de telemetría y las líneas de código aceptadas por el usuario
Para obtener más detalles sobre ambos tipos de registros, consulta Visualiza los registros de Gemini.
Habilita el registro para Gemini Code Assist en un proyecto
Selecciona una de las siguientes opciones:
Console
Verifica que hayas habilitado la API de **Cloud Logging** en el proyecto.
En la Google Cloud consola de, ve a la página Admin for Gemini.
Se carga la página Gemini for Google Cloud.
Haz clic en Configuración en el menú de navegación de la izquierda.
Se carga la página Configuración.
(Opcional) Haz clic en Registro de metadatos de Gemini Code Assist para registrar los metadatos que generan los usuarios de Gemini Code Assist Standard y Enterprise en el proyecto.
(Opcional) Haz clic en Registro de las instrucciones y respuestas de Gemini Code Assist para registrar las instrucciones y respuestas que generan los usuarios de Gemini Code Assist Standard y Enterprise en el proyecto.
Haz clic en Guardar cambios.
API
Para habilitar el registro de Gemini Code Assist Standard y
Enterprise, usa el recurso loggingSettings para definir la configuración de registro
que deseas y el recurso loggingSettings.settingBindings para
vincular la configuración a un proyecto:
Verifica que hayas habilitado la API de **Cloud Logging** en el proyecto.
Crea el parámetro de configuración y un valor específico del parámetro de configuración:
Obtén el token:
TOKEN=$(gcloud auth print-access-token)
Habilita los registros de Gemini Code Assist Standard y Enterprise. Los registros de usuarios y los registros de metadatos se habilitan con los campos
log_prompts_and_responsesylog_metadata, respectivamente. Si no deseas habilitar uno de los campos, exclúyelo de la solicitud.Ejecuta el siguiente comando para crear el parámetro de configuración:
curl -X POST \ -H "Authorization: Bearer $TOKEN" \ -H 'Content-Type: application/json' \ -d '{ "log_prompts_and_responses": true, "log_metadata": true, } ' \ "https://cloudaicompanion.googleapis.com/v1/projects/CONTAINER_PROJECT_NAME/locations/global/loggingSettings?logging_setting_id=LOGS_SETTING_ID"Reemplaza lo siguiente:
CONTAINER_PROJECT_NAME: Ingresa el ID del proyecto en el que se almacena el recurso de vinculación. Este es el proyecto superior de la vinculación.LOGS_SETTING_ID: Ingresa un nombre de configuración único, comogcalm.
Si el comando se ejecuta de forma correcta, muestra un cuerpo de respuesta que muestra
log_prompts_and_responsesylog_metadataestablecidos entrue:{ "name": "projects/CONTAINER_PROJECT_NAME/locations/global/loggingSettings/LOGS_SETTING_ID", "createTime": "2025-01-23T15:22:49.717166932Z", "updateTime": "2025-01-23T15:22:49.717166932Z", "log_prompts_and_responses": true, "log_metadata": true }Ejecuta el siguiente comando para crear la vinculación de configuración de registros de Gemini Code Assist Standard y Enterprise:
curl -X POST \ -H "Authorization: Bearer $TOKEN" \ -H 'Content-Type: application/json' \ -d '{ "target": "projects/TARGET_PROJECT_NAME" }' \ "https://cloudaicompanion.googleapis.com/v1/projects/CONTAINER_PROJECT_NAME/locations/global/loggingSettings/LOGS_SETTING_ID/settingBindings?setting_binding_id=LOGS_BINDING_ID"
Reemplaza lo siguiente:
TARGET_PROJECT_NAME: Ingresa el proyecto de destino al que se debe vincular la vinculación. Por lo general, es el mismo que el proyecto contenedor. Sin embargo, puedes vincular un parámetro de configuración a varios proyectos para que no se duplique el recurso de configuración.LOGS_BINDING_ID: Usa el mismo LOGS_SETTING_ID cuando creaste el parámetro de configuración, pero agrégaleb1. Por ejemplo, usagcalmb1.
Si el comando se ejecuta de forma correcta, muestra los metadatos de la operación en el siguiente formato:
{ "name": "projects/<var>CONTAINER_PROJECT_NAME</var>/locations/global/operations/operation-1737646069712-62c6140bb04bb-49261230-43701daf", "metadata": { "@type": "type.googleapis.com/google.cloud.cloudaicompanion.v1.OperationMetadata", "createTime": "2025-01-23T15:27:50.076075570Z", "target": "projects/<var>TARGET_PROJECT_NAME</var>/locations/global/loggingSettings/<var>LOGS_SETTING_ID</var>/settingBindings/<var>LOGS_BINDING_ID</var>", "verb": "create", "requestedCancellation": false, "apiVersion": "v1" }, "done": false }
Inhabilita el registro para Gemini Code Assist en un proyecto
Selecciona una de las siguientes opciones:
Console
En la Google Cloud consola de, ve a la página Admin for Gemini.
Se carga la página Gemini for Google Cloud.
Haz clic en Configuración en el menú de navegación de la izquierda.
Se carga la página Configuración.
Haz clic en Registro de metadatos de Gemini Code Assist para desactivar el registro de los metadatos del uso de Gemini Code Assist Standard y Enterprise en el proyecto.
Haz clic en Guardar cambios.
API
Para inhabilitar el registro de Gemini Code Assist Standard y Enterprise, usa el método loggingSetting.
Crea el parámetro de configuración y un valor específico del parámetro de configuración:
Obtén el token:
TOKEN=$(gcloud auth print-access-token)
Ejecuta el siguiente comando para inhabilitar la configuración de registros de Gemini Code Assist Standard y Enterprise:
curl -X POST \ -H "Authorization: Bearer $TOKEN" \ -H 'Content-Type: application/json' \ -d '{ "log_prompts_and_responses": false, "log_metadata": false, } ' \ "https://cloudaicompanion.googleapis.com/v1/projects/CONTAINER_PROJECT_NAME/locations/global/loggingSettings?logging_metadata_id=LOGS_SETTING_ID"Reemplaza lo siguiente:
CONTAINER_PROJECT_NAME: Ingresa el ID del proyecto superior.LOGS_SETTING_ID: Ingresa el nombre de configuración existente, comogcalm.Si el comando se ejecuta de forma correcta, muestra un cuerpo de respuesta que muestra
log_prompts_and_responsesylog_metadataestablecidos enfalse:{ "name": "projects/CONTAINER_PROJECT_NAME/locations/global/loggingSettings/LOGS_SETTING_ID", "createTime": "2025-01-23T15:22:49.717166932Z", "updateTime": "2025-01-23T15:22:49.717166932Z", "log_prompts_and_responses": false, "log_metadata": false }
Configura el registro de varios proyectos
Puedes usar los registros de Gemini Code Assist para crear métricas y paneles para supervisar el uso por proyecto. Si tu organización tiene varios proyectos, puedes configurar un proyecto de registro centralizado para recopilar registros de varios proyectos y generar paneles en esos proyectos.
Crea un proyecto de registro centralizado
Este proyecto servirá como un concentrador para los registros de tus otros proyectos.
En la Google Cloud consola de, ve a la página Creación de proyectos.
En la ventana Proyecto nuevo, ingresa valores para los siguientes campos:
- Nombre del proyecto: Un nombre para tu proyecto de registro centralizado
- Cuenta de facturación: Selecciona una cuenta de facturación
- Organización: Selecciona tu organización. Un proyecto centralizado solo puede recopilar registros de proyectos en la misma organización.
- Ubicación: Selecciona una ubicación
Haz clic en Crear.
Configura receptores de registros
Para dirigir los registros al proyecto centralizado, configura receptores de registros en cada uno de los proyectos individuales de los que deseas recopilar registros.
Para configurar receptores de registros para cada proyecto, haz lo siguiente:
- En la Google Cloud consola, cambia a un proyecto del que deseas recopilar registros de.
Ve a la página Enrutador de registros:
Haz clic en Crear un receptor.
En Detalles del receptor, ingresa un nombre y una descripción para el receptor y, luego, haz clic en Siguiente.
En Destino del receptor, haz lo siguiente:
- En el menú Selecciona el servicio de receptor, selecciona Bucket de Logging.
- En el menú Bucket de registros, selecciona Usar un bucket de registros en otro proyecto.
En el campo Destino del receptor, ingresa lo siguiente:
logging.googleapis.com/projects/CENTRALIZED_PROJECT_ID/locations/global/buckets/_DefaultReemplaza
CENTRALIZED_PROJECT_IDpor el ID del proyecto de registro centralizado que creaste.Haz clic en Siguiente.
En Elige registros para incluirlos en el receptor, crea un filtro de inclusión. Para ello, ingresa lo siguiente en el campo Filtro de inclusión:
resource.type="cloudaicompanion.googleapis.com/Instance"Haz clic en Siguiente.
En Elige registros para filtrar fuera del receptor, deja el filtro de exclusión en blanco y haz clic en Crear receptor.
Después de crear el receptor, en la página Enrutador de registros, busca el receptor que creaste.
En la columna Identidad del escritor, copia la dirección de correo electrónico completa de la cuenta de servicio.
Configura el acceso
Para otorgar acceso a tu receptor para escribir registros en el proyecto centralizado, haz lo siguiente:
- En la Google Cloud consola de, cambia al proyecto centralizado que creaste.
Ve a la página IAM:
Haz clic en Otorgar acceso.
En el campo Miembros nuevos, pega la dirección de correo electrónico de la cuenta de servicio que copiaste en la sección anterior.
Haz clic en Agregar otra función.
Busca y selecciona la función Escritor de buckets de registros (
roles/logging.bucketWriter).Haz clic en Guardar.
Crea un panel en el proyecto centralizado
Después de configurar tu proyecto centralizado para recibir registros, puedes crear un panel para ver las métricas de varios proyectos:
En la Google Cloud consola de, ve a Monitoring > Paneles:
Haz clic en Crear panel de control.
En la barra de herramientas, haz clic en Configuración y, luego, selecciona JSON > Editor de JSON.
En el Editor de JSON, pega el siguiente código:
{ "displayName": "Multi-Project Gemini Code Assist Overview from Metadata Logs", "dashboardFilters": [], "labels": {}, "mosaicLayout": { "columns": 48, "tiles": [ { "height": 16, "width": 24, "widget": { "title": "Active Users by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "event_date", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "event_date", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "DAU" } ], "plotType": "LINE", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\n COUNT (DISTINCT JSON_VALUE(labels, '$.user_id')) as DAU, CAST(timestamp AS DATE) AS event_date\nFROM\n `CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\n JSON_VALUE(labels, '$.user_id') is not NULL\n AND (\n JSON_VALUE(json_payload, '$.chatExposure.originalRequestId') is not NULL\n OR JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId') is not NULL\n OR JSON_VALUE(json_payload, '$.codeExposure.originalRequestId') is not NULL\n )\n AND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\n AND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\nevent_date\nORDER BY\nevent_date\n" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } }, { "xPos": 24, "height": 16, "width": 24, "widget": { "title": "Acceptance Rate by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "exposures_date", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "exposures_date", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "acceptance_rate" } ], "plotType": "LINE", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\nexposures_date,\nacceptances_count / exposures_count as acceptance_rate\nFROM\n(\nSELECT\nCOUNT (DISTINCT JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId')) as acceptances_count, CAST(timestamp AS DATE) AS acceptances_date\nFROM\n`CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\nJSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId') is not NULL\nAND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\nAND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\nacceptances_date\n) as acceptances\nJOIN\n(\nSELECT\nCOUNT (DISTINCT JSON_VALUE(json_payload, '$.codeExposure.originalRequestId')) as exposures_count, CAST(timestamp AS DATE) AS exposures_date\nFROM\n`CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\nJSON_VALUE(json_payload, '$.codeExposure.originalRequestId') is not NULL\nAND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\nAND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\nexposures_date\n) as exposures\nON\nexposures.exposures_date = acceptances.acceptances_date\nORDER BY\nexposures_date ASC" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } }, { "yPos": 16, "height": 16, "width": 24, "widget": { "title": "Code Suggestions by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "exposures_date", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "exposures_date", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "exposures_count" } ], "plotType": "STACKED_BAR", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\n COUNT (DISTINCT JSON_VALUE(json_payload, '$.codeExposure.originalRequestId')) as exposures_count, CAST(timestamp AS DATE) AS exposures_date\nFROM\n `CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\n JSON_VALUE(json_payload, '$.codeExposure.originalRequestId') is not NULL\n AND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\n AND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\n exposures_date\nORDER BY\n exposures_date" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } }, { "yPos": 16, "xPos": 24, "height": 16, "width": 24, "widget": { "title": "Code Acceptances by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "acceptances_date", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "acceptances_date", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "acceptances_count" } ], "plotType": "STACKED_BAR", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\n COUNT (DISTINCT JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId')) as acceptances_count, CAST(timestamp AS DATE) AS acceptances_date\nFROM\n `CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\n JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId') is not NULL\n AND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\n AND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\n acceptances_date\nORDER BY\n acceptances_date\n" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } }, { "yPos": 32, "height": 16, "width": 24, "widget": { "title": "Lines of Code Accepted by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "line_count_day", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "line_count_day", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "lines_count" } ], "plotType": "STACKED_BAR", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\n SUM(lines) as lines_count,\n CAST(max_timestamp AS DATE) AS line_count_day\nFROM\n(\n SELECT\n JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId') as request_id,\n MAX(CAST(JSON_VALUE(json_payload, '$.codeAcceptance.linesCount') AS INT)) as lines,\n MAX(timestamp) as max_timestamp\n FROM\n `CENTRALIZED_PROJECT_ID.global._Default._Default`\n WHERE\n JSON_VALUE(json_payload, '$.codeAcceptance.originalRequestId') is not NULL\n AND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\n AND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\n GROUP BY\n request_id\n )\nGROUP BY\n line_count_day\nORDER BY\n line_count_day" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } }, { "yPos": 32, "xPos": 24, "height": 16, "width": 24, "widget": { "title": "Chat Exposures by Day", "id": "", "xyChart": { "chartOptions": { "displayHorizontal": false, "mode": "COLOR", "showLegend": false }, "dataSets": [ { "breakdowns": [], "dimensions": [ { "column": "chat_exposures_date", "columnType": "DATE", "maxBinCount": 0, "sortColumn": "chat_exposures_date", "sortOrder": "SORT_ORDER_ASCENDING", "timeBinSize": "0s", "xMax": 0, "xMin": 0 } ], "legendTemplate": "", "measures": [ { "aggregationFunction": { "parameters": [], "type": "average" }, "column": "chat_exposures_count" } ], "plotType": "STACKED_BAR", "targetAxis": "Y1", "timeSeriesQuery": { "opsAnalyticsQuery": { "queryExecutionRules": { "useReservedSlots": false }, "queryHandle": "", "savedQueryId": "", "sql": "SELECT\n COUNT (DISTINCT JSON_VALUE(json_payload, '$.chatExposure.originalRequestId')) as chat_exposures_count, CAST(timestamp AS DATE) AS chat_exposures_date\nFROM\n `CENTRALIZED_PROJECT_ID.global._Default._Default`\nWHERE\n JSON_VALUE(json_payload, '$.chatExposure.originalRequestId') is not NULL\n AND resource.type = \"cloudaicompanion.googleapis.com/Instance\"\n AND (JSON_VALUE(resource.labels, '$.resource_container') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2') or JSON_VALUE(resource.labels, '$.project_id') in ('SOURCE_PROJECT_ID_1', 'SOURCE_PROJECT_ID_2'))\nGROUP BY\n chat_exposures_date\nORDER BY\n chat_exposures_date" }, "outputFullDuration": false, "unitOverride": "" } } ], "thresholds": [], "yAxis": { "label": "", "scale": "LINEAR" } } } } ] } }Reemplaza lo siguiente:
CENTRALIZED_PROJECT_ID: El ID del proyecto de registro centralizado que creasteSOURCE_PROJECT_ID_1ySOURCE_PROJECT_ID_2: Los IDs de los proyectos de los que deseas recopilar registros. Si deseas recopilar registros de más de dos proyectos, puedes agregar más IDs de proyectos a las cláusulasinde la consulta.
Inhabilita el registro de varios proyectos
Si configuraste el registro de Gemini Code Assist para varios proyectos, puedes inhabilitarlo borrando los receptores de registros que enrutan los registros al proyecto centralizado. Para dejar de enviar registros de un proyecto individual al proyecto centralizado, borra el receptor de registros que creaste en ese proyecto:
- En la Google Cloud consola de, cambia a un proyecto del que deseas dejar de recopilar registros.
Ve a la página Enrutador de registros:
Identifica el receptor que enruta los registros a tu proyecto centralizado.
En la fila de ese receptor, haz clic en Más acciones y, luego, selecciona Borrar receptor.
En el diálogo que aparece, haz clic en Borrar.
Repite estos pasos para cada proyecto al que deseas dejar de enviar registros al proyecto centralizado.
¿Qué sigue?
- Visualiza los registros de Gemini Code Assist.
- Visualiza otros parámetros de configuración de administrador de Gemini Code Assist.