Questo documento descrive come configurare il logging di Gemini Code Assist Standard ed Enterprise per un progetto utilizzando la Google Cloud console o un'API.
Limitazioni
La registrazione dei dati di log di Gemini Standard ed Enterprise è limitata alle interazioni degli utenti con Gemini Code Assist all'interno di un IDE. Google Cloud
Per impostazione predefinita, i log di Gemini vengono raccolti per progetto. Google Cloud Per istruzioni su come configurare un progetto centralizzato per raccogliere i log da più progetti, consulta Configurare il logging per più progetti.
Gemini Code Assist su GitHub non supporta il logging con Cloud Logging.
Prima di iniziare
Verifica che il tuo Google Cloud progetto sia collegato a un account di fatturazione.
Verificare le autorizzazioni IAM
Per configurare il logging di Gemini Code Assist, devi disporre di autorizzazioni IAM specifiche. Per rispettare il principio del privilegio minimo, concedi un ruolo personalizzato che contenga solo le autorizzazioni necessarie.
Chiedi all'amministratore di creare un ruolo personalizzato che includa le seguenti autorizzazioni:
serviceusage.services.enable: per abilitare le API per il tuo progetto.cloudaicompanion.loggingSettings.create: per creare le impostazioni di logging.cloudaicompanion.loggingSettings.get: per visualizzare le impostazioni di logging.cloudaicompanion.loggingSettings.list: per elencare le impostazioni di logging.cloudaicompanion.loggingSettings.update: per aggiornare le impostazioni di logging.cloudaicompanion.loggingSettingBindings.create: per associare le impostazioni di logging a un progetto.cloudaicompanion.loggingSettingBindings.get: per visualizzare le associazioni delle impostazioni di logging.cloudaicompanion.loggingSettingBindings.list: per elencare le associazioni delle impostazioni di logging.
In alternativa, puoi concedere i ruoli predefiniti
Amministratore delle impostazioni di Gemini per Google Cloud (roles/cloudaicompanion.settingsAdmin) e
Amministratore di Service Usage (roles/serviceusage.serviceUsageAdmin).
Tuttavia, questi ruoli includono le autorizzazioni per configurare tutte le impostazioni di amministratore di Gemini per Google Cloud
e gestire l'utilizzo dei servizi, che potrebbero essere più di quelle necessarie
per configurare le impostazioni di logging.
Configurare il logging di Gemini Code Assist
Le sezioni seguenti forniscono i passaggi necessari per abilitare la raccolta e l'archiviazione dell'attività di Gemini Code Assist Standard ed Enterprise in Cloud Logging, tra cui:
Log di prompt e risposte di Gemini Code Assist Standard ed Enterprise, come input utente, informazioni contestuali e risposte.
Log di metadati di Gemini Code Assist Standard ed Enterprise, come metadati di telemetria e righe di codice accettate dall'utente.
Per maggiori dettagli su entrambi i tipi di log, consulta Visualizzare i log di Gemini.
Abilitare il logging per Gemini Code Assist in un progetto
Seleziona una delle seguenti opzioni:
Console
Verifica di aver abilitato l' API **Cloud Logging** nel progetto.
Nella Google Cloud console, vai alla pagina Amministrazione di Gemini.
Viene caricata la pagina Gemini per Google Cloud.
Fai clic su Impostazioni nel menu di navigazione a sinistra.
Viene caricata la pagina Impostazioni.
(Facoltativo) Fai clic su Logging per i metadati di Code Assist per registrare i metadati generati dagli utenti di Gemini Code Assist Standard ed Enterprise nel progetto.
(Facoltativo) Fai clic su Logging per prompt e risposte di Code Assist per registrare i prompt e le risposte generati dagli utenti di Gemini Code Assist Standard ed Enterprise nel progetto.
Fai clic su Salva modifiche.
API
Per abilitare il logging di Gemini Code Assist Standard ed
Enterprise, utilizza la risorsa loggingSettings per definire le impostazioni di logging
che vuoi e la risorsa loggingSettings.settingBindings per
associare le impostazioni a un progetto:
Verifica di aver abilitato l'API Cloud Logging nel progetto.
Crea l'impostazione e un valore specifico per l'impostazione:
Ottieni il token:
TOKEN=$(gcloud auth print-access-token)
Abilita i log di Gemini Code Assist Standard ed Enterprise. I log utente e i log di metadati sono abilitati rispettivamente con i campi
log_prompts_and_responseselog_metadata. Se non vuoi abilitare uno dei campi, escludilo dalla richiesta.Esegui il comando seguente per creare l'impostazione:
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"Sostituisci quanto segue:
CONTAINER_PROJECT_NAME: inserisci l'ID progetto del progetto in cui è archiviata la risorsa di associazione. Questo è il progetto padre dell'associazione.LOGS_SETTING_ID: inserisci un nome di impostazione univoco, ad esempiogcalm.
Se il comando ha esito positivo, restituisce un corpo della risposta che mostra
log_prompts_and_responseselog_metadataimpostati sutrue:{ "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 }Esegui il comando seguente per creare l'associazione delle impostazioni dei log di Gemini Code Assist Standard ed 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"
Sostituisci quanto segue:
TARGET_PROJECT_NAME: inserisci il progetto di destinazione a cui deve essere associata l'associazione. Spesso è lo stesso del progetto contenitore. Tuttavia, puoi associare un'impostazione a più progetti in modo che la risorsa di impostazione non debba essere duplicata.LOGS_BINDING_ID: utilizza lo stesso LOGS_SETTING_ID quando hai creato l'impostazione, ma aggiungicib1. Ad esempio, utilizzagcalmb1.
Se il comando ha esito positivo, restituisce i metadati dell'operazione nel seguente 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 }
Disabilitare il logging per Gemini Code Assist in un progetto
Seleziona una delle seguenti opzioni:
Console
Nella Google Cloud console, vai alla pagina Amministrazione di Gemini.
Viene caricata la pagina Gemini per Google Cloud.
Fai clic su Impostazioni nel menu di navigazione a sinistra.
Viene caricata la pagina Impostazioni.
Fai clic su Logging per i metadati di Code Assist per disattivare la registrazione dei metadati relativi all'utilizzo di Gemini Code Assist Standard ed Enterprise nel progetto.
Fai clic su Salva modifiche.
API
Per disabilitare il logging di Gemini Code Assist Standard ed Enterprise, utilizza il metodo loggingSetting.
Crea l'impostazione e un valore specifico per l'impostazione:
Ottieni il token:
TOKEN=$(gcloud auth print-access-token)
Esegui il comando seguente per disabilitare le impostazioni dei log di Gemini Code Assist Standard ed 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"Sostituisci quanto segue:
CONTAINER_PROJECT_NAME: inserisci l'ID progetto padre.LOGS_SETTING_ID: inserisci il nome dell'impostazione esistente, ad esempiogcalm.Se il comando ha esito positivo, restituisce un corpo della risposta che mostra
log_prompts_and_responseselog_metadataimpostati sufalse:{ "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 }
Configurare il logging per più progetti
Puoi utilizzare i log di Gemini Code Assist per creare metriche e dashboard per monitorare l'utilizzo per progetto. Se la tua organizzazione ha più progetti, puoi configurare un progetto di logging centralizzato per raccogliere i log da più progetti e generare dashboard in questi progetti.
Creare un progetto di logging centralizzato
Questo progetto fungerà da hub per i log degli altri progetti.
Nella Google Cloud console, vai alla pagina Creazione progetto.
Nella finestra Nuovo progetto, inserisci i valori per i seguenti campi:
- Nome progetto: un nome per il progetto di logging centralizzato.
- Account di fatturazione: seleziona un account di fatturazione.
- Organizzazione: seleziona la tua organizzazione. Un progetto centralizzato può raccogliere i log solo dai progetti della stessa organizzazione.
- Località: seleziona una località.
Fai clic su Crea.
Configurare i sink di log
Per indirizzare i log al progetto centralizzato, configura i sink di log in ognuno dei singoli progetti da cui vuoi raccogliere i log.
Per configurare i sink di log per ogni progetto:
- Nella Google Cloud console, passa a un progetto da cui vuoi raccogliere i log da.
Vai alla pagina Router dei log:
Fai clic su Crea sink.
In Dettagli sink, inserisci un nome e una descrizione per il sink, quindi fai clic su Avanti.
In Destinazione sink, procedi come segue:
- Nel menu Seleziona il servizio sink, seleziona Bucket di Logging.
- Nel menu Bucket di log, seleziona Usa un bucket di log in un altro progetto.
Nel campo Destinazione sink, inserisci quanto segue:
logging.googleapis.com/projects/CENTRALIZED_PROJECT_ID/locations/global/buckets/_DefaultSostituisci
CENTRALIZED_PROJECT_IDcon l'ID progetto del progetto di logging centralizzato che hai creato.Fai clic su Avanti.
In Scegli i log da includere nel sink, crea un filtro di inclusione inserendo quanto segue nel campo Filtro di inclusione:
resource.type="cloudaicompanion.googleapis.com/Instance"Fai clic su Avanti.
In Scegli i log da escludere dal sink, lascia vuoto il filtro di esclusione e fai clic su Crea sink.
Dopo aver creato il sink, nella pagina Router dei log, individua il sink che hai creato.
Nella colonna Identità del writer, copia l'indirizzo email completo del account di servizio.
Configurare l'accesso
Per concedere al sink l'accesso per scrivere i log nel progetto centralizzato:
- Nella Google Cloud console, passa al progetto centralizzato che hai creato.
Vai alla pagina IAM:
Fai clic su Concedi l'accesso.
Nel campo Nuove entità, incolla l'indirizzo email del account di servizio che hai copiato nella sezione precedente.
Fai clic su Aggiungi un altro ruolo.
Cerca e seleziona il ruolo Writer del bucket di log (
roles/logging.bucketWriter).Fai clic su Salva.
Creare una dashboard nel progetto centralizzato
Dopo aver configurato il progetto centralizzato per ricevere i log, puoi creare una dashboard per visualizzare le metriche di più progetti:
Nella Google Cloud console, vai a Monitoraggio > Dashboard:
Fai clic su Crea dashboard.
Nella barra degli strumenti, fai clic su Impostazioni, quindi seleziona JSON > Editor JSON.
Nell'editor JSON, incolla il seguente codice:
{ "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" } } } } ] } }Sostituisci quanto segue:
CENTRALIZED_PROJECT_ID: l'ID progetto del progetto di logging centralizzato che hai creato.SOURCE_PROJECT_ID_1eSOURCE_PROJECT_ID_2: gli ID progetto dei progetti da cui vuoi raccogliere i log. Se vuoi raccogliere i log da più di due progetti, puoi aggiungere altri ID progetto alle clausoleindella query.
Disabilitare il logging per più progetti
Se hai configurato il logging di Gemini Code Assist per più progetti, puoi disabilitarlo eliminando i sink di log che indirizzano i log al progetto centralizzato. Per interrompere l'invio dei log da un singolo progetto al progetto centralizzato, elimina il sink di log che hai creato in quel progetto:
- Nella Google Cloud console, passa a un progetto da cui vuoi interrompere la raccolta dei log.
Vai alla pagina Router dei log:
Identifica il sink che indirizza i log al progetto centralizzato.
Nella riga del sink, fai clic su Altre azioni e seleziona Elimina sink.
Nella finestra di dialogo visualizzata, fai clic su Elimina.
Ripeti questi passaggi per ogni progetto per cui vuoi interrompere l'invio dei log al progetto centralizzato.
Passaggi successivi
- Visualizzare i log di Gemini Code Assist.
- Visualizzare altre impostazioni di amministratore di Gemini Code Assist.