Desarrollar y desplegar agentes en Vertex AI Agent Engine
En esta página se muestra cómo crear y desplegar un agente en el tiempo de ejecución de Vertex AI Agent Engine con los siguientes frameworks de agentes:
Flujo de procesamiento de consultas de LlamaIndex (vista previa)
En esta guía de inicio rápido se explican los siguientes pasos:
Configura tu Google Cloud proyecto.
Instala el SDK de Vertex AI para Python y el framework que elijas.
Desarrolla un agente de cambio de divisas.
Despliega el agente en el tiempo de ejecución de Vertex AI Agent Engine.
Prueba el agente implementado.
Para consultar la guía de inicio rápido sobre cómo usar Agent Development Kit, consulta Desarrollar y desplegar agentes en Vertex AI Agent Engine con Agent Development Kit.
Antes de empezar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
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 and Cloud Storage 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 and Cloud Storage 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. -
Usuario de Vertex AI (
roles/aiplatform.user) -
Administrador de almacenamiento (
roles/storage.admin) Ejecuta el siguiente comando para instalar el SDK de Vertex AI para Python y otros paquetes necesarios:
LangGraph
pip install --upgrade --quiet google-cloud-aiplatform[agent_engines,langchain]>=1.112LangChain
pip install --upgrade --quiet google-cloud-aiplatform[agent_engines,langchain]>=1.112AG2
pip install --upgrade --quiet google-cloud-aiplatform[agent_engines,ag2]>=1.112LlamaIndex
pip install --upgrade --quiet google-cloud-aiplatform[agent_engines,llama_index]>=1.112Autenticarse como usuario
Colab
Ejecuta el siguiente código:
from google.colab import auth auth.authenticate_user(project_id="PROJECT_ID")Cloud Shell
No tienes que hacer nada.
Shell local
Ejecuta el siguiente comando:
gcloud auth application-default loginModo Exprés
Si usas Vertex AI en modo exprés, no tienes que hacer nada.
Ejecuta el siguiente código para importar Vertex AI Agent Engine e inicializar el SDK:
(Opcional) Antes de probar un agente que desarrolles, debes importar Vertex AI Agent Engine e inicializar el SDK de la siguiente manera:
Proyecto de Google Cloud
import vertexai vertexai.init( project="PROJECT_ID", # Your project ID. location="LOCATION", # Your cloud region. )Donde:
PROJECT_IDes el Google Cloud ID de proyecto en el que desarrollas y despliegas agentes.LOCATIONes una de las regiones admitidas.
Modo Exprés
Si usas Vertex AI en modo exprés, ejecuta el siguiente código:
import vertexai vertexai.init( api_key="API_KEY" )donde API_KEY es la clave de API que usas para autenticar el agente.
Antes de implementar un agente, debes importar Vertex AI Agent Engine e inicializar el SDK de la siguiente manera:
Proyecto de Google Cloud
import vertexai client = vertexai.Client( project="PROJECT_ID", # Your project ID. location="LOCATION", # Your cloud region. )Donde:
PROJECT_IDes el Google Cloud ID de proyecto en el que desarrollas y despliegas agentes.LOCATIONes una de las regiones admitidas.
Modo Exprés
Si usas Vertex AI en modo exprés, ejecuta el siguiente código:
import vertexai client = vertexai.Client( api_key="API_KEY" )donde API_KEY es la clave de API que usas para autenticar el agente.
Desarrolla una herramienta de cambio de divisas para tu agente:
def get_exchange_rate( currency_from: str = "USD", currency_to: str = "EUR", currency_date: str = "latest", ): """Retrieves the exchange rate between two currencies on a specified date.""" import requests response = requests.get( f"https://api.frankfurter.app/{currency_date}", params={"from": currency_from, "to": currency_to}, ) return response.json()Instancia un agente:
LangGraph
from vertexai import agent_engines agent = agent_engines.LanggraphAgent( model="gemini-2.0-flash", tools=[get_exchange_rate], model_kwargs={ "temperature": 0.28, "max_output_tokens": 1000, "top_p": 0.95, }, )LangChain
from vertexai import agent_engines agent = agent_engines.LangchainAgent( model="gemini-2.0-flash", tools=[get_exchange_rate], model_kwargs={ "temperature": 0.28, "max_output_tokens": 1000, "top_p": 0.95, }, )AG2
from vertexai import agent_engines agent = agent_engines.AG2Agent( model="gemini-2.0-flash", runnable_name="Get Exchange Rate Agent", tools=[get_exchange_rate], )LlamaIndex
from vertexai.preview import reasoning_engines def runnable_with_tools_builder(model, runnable_kwargs=None, **kwargs): from llama_index.core.query_pipeline import QueryPipeline from llama_index.core.tools import FunctionTool from llama_index.core.agent import ReActAgent llama_index_tools = [] for tool in runnable_kwargs.get("tools"): llama_index_tools.append(FunctionTool.from_defaults(tool)) agent = ReActAgent.from_tools(llama_index_tools, llm=model, verbose=True) return QueryPipeline(modules = {"agent": agent}) agent = reasoning_engines.LlamaIndexQueryPipelineAgent( model="gemini-2.0-flash", runnable_kwargs={"tools": [get_exchange_rate]}, runnable_builder=runnable_with_tools_builder, )Prueba el agente de forma local:
LangGraph
agent.query(input={"messages": [ ("user", "What is the exchange rate from US dollars to SEK today?"), ]})LangChain
agent.query( input="What is the exchange rate from US dollars to SEK today?" )AG2
agent.query( input="What is the exchange rate from US dollars to SEK today?" )LlamaIndex
agent.query( input="What is the exchange rate from US dollars to SEK today?" )
Para obtener los permisos que necesitas para usar Vertex AI Agent Engine, pide a tu administrador que te conceda los siguientes roles de gestión de identidades y accesos en tu proyecto:
Para obtener más información sobre cómo conceder roles, consulta el artículo Gestionar acceso a proyectos, carpetas y organizaciones.
También puedes conseguir los permisos necesarios a través de roles personalizados u otros roles predefinidos.
Instalar e inicializar el SDK de Vertex AI para Python
Desarrollar un agente
Desplegar un agente
Despliega el agente creando un recurso reasoningEngine en Vertex AI:
LangGraph
remote_agent = client.agent_engines.create(
agent,
config={
"requirements": ["google-cloud-aiplatform[agent_engines,langchain]"],
},
)
LangChain
remote_agent = client.agent_engines.create(
agent,
config={
"requirements": ["google-cloud-aiplatform[agent_engines,langchain]"],
},
)
AG2
remote_agent = client.agent_engines.create(
agent,
config={
"requirements": ["google-cloud-aiplatform[agent_engines,ag2]"],
},
)
LlamaIndex
remote_agent = client.agent_engines.create(
agent,
config={
"requirements": ["google-cloud-aiplatform[agent_engines,llama_index]"],
},
)
Usar un agente
Prueba el agente implementado enviando una consulta:
LangGraph
remote_agent.query(input={"messages": [
("user", "What is the exchange rate from US dollars to SEK today?"),
]})
LangChain
remote_agent.query(
input="What is the exchange rate from US dollars to SEK today?"
)
AG2
remote_agent.query(
input="What is the exchange rate from US dollars to SEK today?"
)
LlamaIndex
remote_agent.query(
input="What is the exchange rate from US dollars to SEK today?"
)
Limpieza
Para evitar que se apliquen cargos en tu cuenta de Google Cloud por los recursos utilizados en esta página, sigue estos pasos.
remote_agent.delete(force=True)