Prima di utilizzare Vertex AI Agent Engine, devi assicurarti che il tuo ambiente sia configurato. Devi disporre di un progetto Google Cloud con la fatturazione abilitata, disporre delle autorizzazioni richieste, configurare un bucket Cloud Storage e installare l'SDK Vertex AI per Python. Utilizza i seguenti argomenti per assicurarti di essere pronto per iniziare a lavorare con Vertex AI Agent Engine.
Per un esempio di riferimento di Terraform per semplificare la configurazione e l'implementazione dell'ambiente Vertex AI Agent Engine, valuta la possibilità di esplorare l'agent-starter-pack.
Configura con Google Cloud
Puoi configurare Google Cloud per Vertex AI Agent Engine creando un progetto Google Cloud .
Google Cloud progetto
Ogni progetto può essere identificato in due modi: tramite il numero del progetto o l'ID progetto. PROJECT_NUMBER viene creato automaticamente quando
crei il progetto, mentre PROJECT_ID viene creato da te
o da chiunque abbia creato il progetto. Per configurare un progetto:
- Accedi al tuo account Google Cloud . Se non conosci Google Cloud, crea un account per valutare le prestazioni dei nostri prodotti in scenari reali. I nuovi clienti ricevono anche 300 $di crediti senza costi per l'esecuzione, il test e il deployment dei workload.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the Vertex AI, Cloud Storage, Cloud Logging, Cloud Monitoring, Telemetry, Cloud Trace, and Resource Manager APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the Vertex AI, Cloud Storage, Cloud Logging, Cloud Monitoring, Telemetry, Cloud Trace, and Resource Manager APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
Ottenere i ruoli richiesti
Per ottenere le autorizzazioni
necessarie per utilizzare Vertex AI Agent Engine,
chiedi all'amministratore di concederti il ruolo IAM
Vertex AI User (roles/aiplatform.user)
nel progetto.
Per saperne di più sulla concessione dei ruoli, consulta Gestisci l'accesso a progetti, cartelle e organizzazioni.
Potresti anche riuscire a ottenere le autorizzazioni richieste tramite i ruoli personalizzati o altri ruoli predefiniti.
Configurare l'identità e le autorizzazioni per l'agente
Quando configuri l'identità e le autorizzazioni, hai a disposizione le seguenti opzioni:
Identità dell'agente (consigliata) (Anteprima): utilizza l'identità dell'agente Identity Access Management (IAM) per fornire funzionalità di gestione della sicurezza e dell'accesso quando utilizzi gli agenti su Vertex AI Agent Engine Runtime. L'identità dell'agente è associata a ogni singolo agente.
Service account: i service account sono condivisi tra gli agenti di cui esegui il deployment in Vertex AI Agent Engine. Hai due opzioni per il account di servizio:
- Agente di servizio predefinito:per impostazione predefinita, gli agenti utilizzano l'agente di servizio AI Platform Reasoning Engine. Questo account di servizio gestito da Google ha il ruolo
Vertex AI Reasoning Engine Service Agent
(
roles/aiplatform.reasoningEngineServiceAgent), che include le autorizzazioni predefinite richieste per gli agenti di cui è stato eseguito il deployment. - Service account personalizzato:puoi specificare il tuo account di servizio da utilizzare per gli agenti. In questo modo hai un controllo più granulare sulle autorizzazioni concesse agli agenti.
- Agente di servizio predefinito:per impostazione predefinita, gli agenti utilizzano l'agente di servizio AI Platform Reasoning Engine. Questo account di servizio gestito da Google ha il ruolo
Vertex AI Reasoning Engine Service Agent
(
Identità dell'agente
Per configurare le policy IAM prima di eseguire il deployment dell'agente, puoi
creare un'identità dell'agente senza eseguire il deployment del codice dell'agente. Per farlo, crea
un'istanza di Agent Engine con solo il campo identity_type:
remote_app = client.agent_engines.create(
config={
"identity_type": types.IdentityType.AGENT_IDENTITY,
},
)
Dopo aver creato l'istanza di Agent Engine con l'identità dell'agente, puoi:
Esegui il provisioning dell'identità dell'agente con i seguenti ruoli consigliati:
roles/serviceusage.serviceUsageConsumer: concedi all'agente l'autorizzazione a utilizzare la quota del progetto e l'SDK Vertex AI.
Concedi all'identità dell'agente ruoli aggiuntivi in base alle esigenze del tuo caso d'uso.
Aggiungi il codice agente utilizzando
agent_engine.update(...).
Service agent predefinito
Per impostazione predefinita, viene utilizzato l'agente di servizio del motore di ragionamento di AI Platform. Puoi visualizzare l'elenco completo delle autorizzazioni predefinite nella documentazione IAM.
Se il tuo agente richiede autorizzazioni aggiuntive rispetto al set predefinito, puoi concedere a questo service agent ruoli aggiuntivi:
Vai alla pagina IAM e seleziona la casella di controllo "Includi concessioni di ruoli fornite da Google".
Trova l'entità corrispondente a
service-PROJECT_NUMBER@gcp-sa-aiplatform-re.iam.gserviceaccount.com.Aggiungi i ruoli richiesti all'entità facendo clic sul pulsante di modifica e poi sul pulsante di salvataggio.
Generare manualmente l'agente di servizio predefinito
Sebbene il service agent Reasoning Engine venga sottoposto a provisioning automatico durante il deployment di Vertex AI Agent Engine, potrebbero verificarsi scenari in cui è necessario generarlo manualmente in anticipo. Ciò è particolarmente importante quando devi concedere ruoli specifici all'agente di servizio per garantire che il processo di deployment disponga delle autorizzazioni necessarie ed evitare potenziali errori di deployment.
Ecco i passaggi per generare manualmente un agente di servizio del motore di ragionamento:
Genera l'agente di servizio Reasoning Engine utilizzando Google Cloud CLI.
gcloud beta services identity create --service=aiplatform.googleapis.com --project=PROJECT-ID-OR-PROJECT-NUMBERVai alla pagina IAM e fai clic su Concedi l'accesso.
Nella sezione Aggiungi entità, inserisci
service-PROJECT_NUMBER@gcp-sa-aiplatform-re.iam.gserviceaccount.comnel campo Nuove entità.Nella sezione Assegna ruoli, trova e seleziona i ruoli di cui hai bisogno.
Fai clic sul pulsante Salva.
Service account personalizzato
Per utilizzare il tuo account di servizio, devi concedergli le autorizzazioni necessarie
per eseguire l'agente. Il tuo account di servizio personalizzato probabilmente richiede il ruolo
Utente Vertex AI (roles/aiplatform.user).
Se non hai un account di servizio, creane uno. Vedi Creare service account.
Concedi al account di servizio il ruolo Utente Vertex AI (
roles/aiplatform.user).Concedi all'account di servizio tutti gli altri ruoli richiesti dal codice agente.
Per eseguire il deployment dell'agente con questo account di servizio, concediti il ruolo Utente service account (
roles/iam.serviceAccountUser) in questo service account personalizzato.Quando esegui il deployment dell'agente, specifica l'indirizzo email del tuo service account personalizzato. Per i dettagli, consulta Configurare un service account personalizzato.
Account di servizio personalizzato tra progetti
Se il tuo account di servizio personalizzato proviene da un altro progetto, devi eseguire configurazioni aggiuntive sia nel progetto in cui si trova il account di servizio sia nel progetto in cui viene eseguito il deployment dell'agente.
Policy dell'organizzazione Disabilita l'utilizzo dei account di servizio tra i progetti:nel progetto in cui si trova il account di servizio, assicurati che la policy dell'organizzazione
iam.disableCrossProjectServiceAccountUsageNON venga applicata. Per ulteriori dettagli, consulta Disabilita l'applicazione dell'utilizzo dei account di servizio tra i progetti.Concedi le autorizzazioni al service agent Vertex AI: nel progetto in cui si trova il account di servizio, concedi il ruolo Creatore token service account (
roles/iam.serviceAccountTokenCreator) al service agent Vertex AI (service-RESOURCE_PROJECT_NUMBER@gcp-sa-aiplatform.iam.gserviceaccount.com) del progetto in cui prevedi di eseguire il deployment dell'agente.Concedi le autorizzazioni al service account personalizzato:nel progetto in cui intendi eseguire il deployment dell'agente, concedi i ruoli necessari al account di servizio personalizzato. In genere, questo include il ruolo Utente Vertex AI (
roles/aiplatform.user) e qualsiasi altro ruolo richiesto dal codice dell'agente.
(Facoltativo) Crea un bucket Cloud Storage
La necessità di un bucket Cloud Storage dipende dal fatto che l'SDK Vertex AI Python abbia bisogno di un luogo in cui preparare il codice dell'agente prima del deployment:
Deployment dai file di origine: l'agente esiste come file. L'SDK Vertex AI per Python può raggruppare e caricare questi file direttamente nel servizio di deployment, quindi non è necessario un bucket di staging Cloud Storage.
Esegui il deployment dall'oggetto agente: l'agente esiste in memoria. L'SDK Vertex AI Python pacchettizza questo oggetto e lo carica in un bucket Cloud Storage, che funge da area di gestione temporanea per il servizio di deployment.
Esegui il deployment dai file di origine
Se esegui il deployment di un agente dai file di origine, non è necessario un bucket Cloud Storage.
Esegui il deployment dall'oggetto
Quando esegui il deployment di da un oggetto agente, Vertex AI Agent Engine esegue il staging degli artefatti degli agenti di cui è stato eseguito il deployment in un bucket Cloud Storage nell'ambito del processo di deployment. Assicurati che l'entità autenticata per utilizzare Vertex AI (tu o un account di servizio) abbia accesso Storage Admin a questo bucket. Questo è necessario perché l'SDK Vertex AI Python scrive il codice in questo bucket.
Se hai già configurato un bucket, puoi saltare questo passaggio. In caso contrario, puoi seguire le istruzioni standard per creare un bucket.
Chiedi all'amministratore di concederti il ruolo IAM Amministratore archiviazione (roles/storage.admin) nel progetto.
ConsoleGoogle Cloud
- Nella console Google Cloud , vai alla pagina Bucket in Cloud Storage.
- Fai clic su Crea.
- Nella pagina Crea un bucket, inserisci le informazioni del bucket. Per andare al passaggio
successivo, fai clic su Continua.
-
Nella sezione Inizia, segui questi passaggi:
- Inserisci un nome univoco globale che soddisfi i requisiti per la denominazione dei bucket.
- Per aggiungere un'etichetta bucket, espandi la sezione Etichette (), fai clic su add_box
Aggiungi etichetta e specifica un
keye unvalueper l'etichetta.
-
Nella sezione Scegli dove archiviare i tuoi dati, segui questi passaggi:
- Seleziona un Tipo di località.
- Scegli una posizione in cui i dati del bucket vengono archiviati in modo permanente dal menu a discesa Tipo di località.
- Se selezioni il tipo di località a due regioni, puoi anche scegliere di attivare la replica turbo utilizzando la casella di controllo pertinente.
- Per configurare la replica tra bucket, seleziona
Aggiungi una replica tra bucket mediante Storage Transfer Service e
segui questi passaggi:
Configura la replica tra bucket
- Nel menu Bucket, seleziona un bucket.
Nella sezione Impostazioni di replica, fai clic su Configura per configurare le impostazioni per il job di replica.
Viene visualizzato il riquadro Configura replica tra bucket.
- Per filtrare gli oggetti da replicare in base al prefisso del nome dell'oggetto, inserisci un prefisso da cui includere o escludere gli oggetti, quindi fai clic su Aggiungi un prefisso.
- Per impostare una classe di archiviazione per gli oggetti replicati, seleziona una classe di archiviazione dal menu Classe di archiviazione. Se salti questo passaggio, gli oggetti replicati utilizzeranno per impostazione predefinita la classe di archiviazione del bucket di destinazione.
- Fai clic su Fine.
-
Nella sezione Scegli come archiviare i tuoi dati, segui questi passaggi:
- Seleziona una classe di archiviazione predefinita per il bucket o Autoclass per la gestione automatica della classe di archiviazione dei dati del bucket.
- Per attivare lo spazio dei nomi gerarchico, nella sezione Ottimizza l'archiviazione per workload con uso intensivo dei dati, seleziona Abilita uno spazio dei nomi gerarchico in questo bucket.
- Nella sezione Scegli come controllare l'accesso agli oggetti, seleziona se il bucket applica o meno la prevenzione dell'accesso pubblico e seleziona un metodo di controllo dell'accesso per gli oggetti del bucket.
-
Nella sezione Scegli come proteggere i dati degli oggetti, segui questi passaggi:
- Seleziona una delle opzioni in Protezione dei dati che vuoi impostare per il bucket.
- Per attivare l'eliminazione temporanea, fai clic sulla casella di controllo Criterio di eliminazione temporanea (per il recupero dei dati) e specifica il numero di giorni per cui vuoi conservare gli oggetti dopo l'eliminazione.
- Per impostare il controllo delle versioni degli oggetti, seleziona la casella di controllo Controllo delle versioni degli oggetti (per il controllo delle versioni) e specifica il numero massimo di versioni per oggetto e il numero di giorni dopo i quali scadono le versioni non correnti.
- Per abilitare il criterio di conservazione su oggetti e bucket, seleziona la casella di controllo Conservazione (per la conformità), quindi procedi nel seguente modo:
- Per attivare il blocco della conservazione degli oggetti, fai clic sulla casella di controllo Abilita conservazione degli oggetti.
- Per attivare Bucket Lock, fai clic sulla casella di controllo Imposta criterio di conservazione del bucket e scegli un'unità di tempo e una durata per il periodo di conservazione.
- Per scegliere come verranno criptati i dati degli oggetti, espandi la sezione Crittografia dei dati () e seleziona un metodo di crittografia dei dati.
- Seleziona una delle opzioni in Protezione dei dati che vuoi impostare per il bucket.
-
Nella sezione Inizia, segui questi passaggi:
- Fai clic su Crea.
Riga di comando
-
Crea un bucket Cloud Storage e configuralo nel seguente modo:
-
Sostituisci
STORAGE_CLASScon la classe di archiviazione che preferisci. -
Sostituisci
LOCATIONcon la tua posizione preferita (ASIA,EUoUS) -
Sostituisci
BUCKET_NAMEcon un nome del bucket che soddisfi i requisiti per i nomi dei bucket.
gcloud storage buckets create gs://BUCKET_NAME --default-storage-class STORAGE_CLASS --location LOCATION
Installare e inizializzare l'SDK Vertex AI Python
Questa sezione presuppone che tu abbia configurato un ambiente di sviluppo Python o che tu stia utilizzando Colab (o qualsiasi altro runtime adatto che lo abbia configurato per te).
(Facoltativo) Configurare un ambiente virtuale
Ti consigliamo inoltre di configurare un ambiente virtuale per isolare le dipendenze.
Installazione
Per ridurre al minimo l'insieme di dipendenze da installare, abbiamo suddiviso le dipendenze in:
agent_engines: l'insieme di pacchetti richiesti per il deployment in Vertex AI Agent Engine.adk: l'insieme di pacchetti Agent Development Kit compatibili.langchain: il set di pacchetti LangChain e LangGraph compatibili.ag2: l'insieme di pacchetti AG2 compatibili.llama_index: l'insieme di pacchetti LlamaIndex compatibili.
Quando installi l'SDK Vertex AI Python, puoi specificare le dipendenze richieste (separate da virgole). Per installarli tutti:
pip install google-cloud-aiplatform[agent_engines,adk,langchain,ag2,llama_index]>=1.112.0Per utilizzare Agent2Agent (A2A) su Agent Engine, devi installare anche il pacchetto a2a-sdk:
pip install a2a-sdk>=0.3.4Autenticazione
Colab
Esegui questo codice:
from google.colab import auth
auth.authenticate_user(project_id="PROJECT_ID")
Cloud Shell
Non occorre alcun intervento.
Shell locale
Esegui questo comando:
gcloud auth application-default loginImporta e inizializza l'SDK
Esegui il seguente codice per importare e inizializzare l'SDK per Vertex AI Agent Engine:
Progetto Google Cloud
import vertexai
from vertexai import agent_engines # For the prebuilt templates
client = vertexai.Client( # For service interactions via client.agent_engines
project="PROJECT_ID",
location="LOCATION",
)
dove
PROJECT_IDè l' Google Cloud ID progetto in cui sviluppi ed esegui il deployment degli agenti.LOCATIONè una delle regioni supportate.