Antes de comenzar
En este instructivo, se supone que leíste y seguiste las instrucciones que se indican a continuación:
- Desarrolla un agente Agent2Agent para desarrollar un agente como una instancia de
A2aAgent. - Autenticación de usuarios para autenticarte como usuario para consultar el agente.
- Importa e inicializa el SDK para inicializar el cliente para obtener una instancia implementada (si es necesario).
Obtén una instancia de un agente
Para consultar un A2aAgent, primero debes
crear una instancia nueva o
obtener una existente.
Para obtener el A2aAgent correspondiente a un ID de recurso específico, haz lo siguiente:
SDK de Vertex AI para Python
import vertexai
from google.genai import types
PROJECT_ID = "PROJECT_ID"
LOCATION = "LOCATION"
RESOURCE_ID = "RESOURCE_ID"
RESOURCE_NAME = f"projects/{PROJECT_ID}/locations/{LOCATION}/reasoningEngines/{RESOURCE_ID}"
client = vertexai.Client(
project=PROJECT_ID,
location=LOCATION,
http_options=types.HttpOptions(
api_version="v1beta1",
)
)
remote_agent = client.agent_engines.get(name=RESOURCE_NAME)
print(remote_agent)
donde
PROJECT_IDes el Google Cloud ID del proyecto en el que desarrollas e implementas agentes.LOCATIONes una de las regiones admitidas.RESOURCE_IDes el ID del agente implementado como unreasoningEnginerecurso.
SDK de A2A para Python
Este método usa el SDK oficial de A2A para Python, que proporciona una biblioteca cliente para interactuar con agentes compatibles con A2A. Para obtener más información, consulta la documentación del SDK de A2A para Python.
Primero, instala el SDK:
pip install a2a-sdk>=0.3.4Luego, obtén la tarjeta del agente para crear una instancia del cliente. El A2AClient controla el descubrimiento y la comunicación por ti.
from google.auth import default
from google.auth.transport.requests import Request
from a2a.client import ClientConfig, ClientFactory
from a2a.types import TransportProtocol
import httpx
# We assume 'agent_card' is an existing AgentCard object.
# Fetch credentials for authentication for demo purpose. Use your own auth
credentials, _ = default(scopes=['https://www.googleapis.com/auth/cloud-platform'])
credentials.refresh(Request())
# Create the client by chaining the factory and config initialization.
factory = ClientFactory(
ClientConfig(
supported_transports=[TransportProtocol.http_json], # only support http_json
use_client_preference=True,
httpx_client=httpx.AsyncClient(
headers={
"Authorization": f"Bearer {credentials.token}",
"Content-Type": "application/json",
}
),
)
)
a2a_client = factory.create(agent_card)
Biblioteca de solicitudes de Python
El protocolo A2A se basa en extremos HTTP estándar. Puedes interactuar con estos extremos mediante cualquier cliente HTTP.
Recupera la URL de A2A de la tarjeta del agente y define los encabezados de la solicitud.
from google.auth import default
from google.auth.transport.requests import Request
# We assume 'agent_card' is an existing object
a2a_url = agent_card.url
# Get an authentication token for demonstration purposes. Use your own authentication mechanism.
credentials, _ = default(scopes=['https://www.googleapis.com/auth/cloud-platform'])
credentials.refresh(Request())
headers = {
"Authorization": f"Bearer {credentials.token}",
"Content-Type": "application/json",
}
Cuando se usa el SDK de Vertex AI para Python, el remote_agent objeto corresponde a una
AgentEngine clase que contiene lo siguiente:
remote_agent.api_resourcecon información sobre el agente implementado. También puedes llamar aremote_agent.operation_schemas()para mostrar la lista de operaciones que admiteremote_agent. Consulta Operaciones admitidas para obtener más detalles.remote_agent.api_clientque permite interacciones de servicio síncronasremote_agent.async_api_clientque permite interacciones de servicio asíncronas
En el resto de esta sección, se supone que tienes una instancia de AgentEngine, denominada remote_agent.
Operaciones admitidas
Un agente A2A alojado en Agent Engine expone un conjunto de operaciones que corresponden directamente a los extremos de la API del protocolo A2A.
on_message_send: Envía un mensaje nuevo al agente para iniciar una tarea.on_get_task: Recupera el estado y los artefactos de una tarea existente.on_cancel_task: Cancela una tarea en ejecución.handle_authenticated_agent_card: Recupera las capacidades y habilidades completas del agente.
Recupera la tarjeta del agente
Ten en cuenta que Agent Engine no publica la tarjeta del agente público. Para recuperar la tarjeta del agente autenticado, haz lo siguiente:
SDK de Vertex AI para Python
response = await remote_agent.handle_authenticated_agent_card()
SDK de A2A para Python
response = await a2a_client.get_card()
Biblioteca de solicitudes de Python
card_endpoint = f"{a2a_url}/v1/card"
response = httpx.get(card_endpoint, headers=headers)
print(json.dumps(response.json(), indent=4))
Envía un mensaje
Para enviar un mensaje, sigue estos pasos:
SDK de Vertex AI para Python
message_data = {
"messageId": "remote-agent-message-id",
"role": "user",
"parts": [{"kind": "text", "text": "What is the exchange rate from USD to EUR today?"}],
}
response = await remote_agent.on_message_send(**message_data)
Puedes anular el tiempo de espera que se usa para on_message_send si configuras el campo timeout de HttpOptions cuando creas vertexai.Client.
SDK de A2A para Python
from a2a.types import Message, Part, TextPart
import pprint
message = Message(
message_id="remote-agent-message-id",
role="user",
parts=[Part(root=TextPart(text="What's the currency rate of USD and EUR"))],
)
response_iterator = a2a_client.send_message(message)
async for chunk in response_iterator:
pprint.pp(chunk)
Biblioteca de solicitudes de Python
import httpx
import json
endpoint = f"{a2a_url}/v1/message:send"
payload = {
"message": {
"messageId": "remote-agent-message-id",
"role": "1",
"content": [{"text": "What is the exchange rate from USD to EUR today?"}],
},
"metadata": {"source": "python_script"},
}
response = httpx.post(endpoint, json=payload, headers=headers)
print(json.dumps(response.json(), indent=4))
Obtén una tarea
Para obtener una tarea y su estado, haz lo siguiente:
SDK de Vertex AI para Python
task_data = {
"id": task_id,
}
response = await remote_agent.on_get_task(**task_data)
SDK de A2A para Python
from a2a.types import TaskQueryParams
task_data ={
"id":task_id,
}
response = await a2a_client.get_task(TaskQueryParams(**task_data))
Biblioteca de solicitudes de Python
task_end_point = f"{a2a_url}/v1/tasks/{task_id}"
response = httpx.get(task_end_point, headers=headers)
print(json.dumps(response.json(), indent=4))
Cancela una tarea
Para cancelar una tarea, sigue estos pasos:
SDK de Vertex AI para Python
task_data = {
"id": task_id,
}
response = await remote_agent.on_cancel_task(**task_data)
SDK de A2A para Python
from a2a.types import TaskQueryParams
task_data ={
"id":task_id,
}
response = await a2a_client.cancel_task(TaskQueryParams(**task_data))
Biblioteca de solicitudes de Python
task_end_point = f"{a2a_url}/v1/tasks/{task_id}:cancel"
response = httpx.post(task_end_point, headers=headers)
print(json.dumps(response.json(), indent=4))