Los agentes del Kit de desarrollo de agentes (ADK) interactúan con servicios externos fuera de Google Cloud. Tanto las identidades de agentes como la administración de identidades y accesos (IAM) te permiten autenticarte con los servicios de Google Cloud. Sin embargo, no pueden probar la identidad en plataformas externas que no admiten la federación de identidades de Google.
Los agentes del ADK requieren acceso a varias credenciales para interactuar con entidades externas, como servicios de MCP, herramientas del ADK y APIs. Estos son algunos ejemplos comunes:
- Claves de API para plataformas de procesamiento de pagos
- Combinaciones de nombre de usuario y contraseña para bases de datos locales heredadas
- Claves privadas para conexiones de TLS mutuo (mTLS)
SecretManagerClient dentro del paquete google.adk.integrations.secret_manager.secret_client. Este módulo proporciona una interfaz estándar para que los agentes recuperen secretos de Secret Manager en el tiempo de ejecución.
En este documento, se explica cómo administrar los secretos de los servicios externos en el ADK con Secret Manager.
Ventajas de usar Secret Manager con el ADK
La administración manual de secretos puede generar riesgos de seguridad y aumentar el esfuerzo de los desarrolladores. Secret Manager puede ayudar a resolver estos problemas de las siguientes maneras:
- Si incorporas secretos en el código del agente, creas un riesgo de seguridad significativo. Esta práctica puede generar acceso no autorizado a los sistemas de producción. El uso de Secret Manager quita los datos sensibles de tu código fuente. Esto ayuda a que tu aplicación sea más segura.
- Si incorporas secretos estáticos a través de variables de entorno, la rotación de credenciales se vuelve complicada. Para aplicar las actualizaciones, debes reiniciar los contenedores de implementación. Secret Manager recupera las credenciales de forma dinámica en el tiempo de ejecución, lo que permite realizar actualizaciones sin tiempo de inactividad del sistema.
- Si escribes código estándar
SecretManagerServiceClientpara cada herramienta, aumentas el trabajo repetitivo de los desarrolladores y el riesgo de errores. La integración estandarizada del ADK proporciona un enfoque limpio y reutilizable para recuperar credenciales.
Antes de comenzar
Antes de integrar Secret Manager con el ADK, completa los siguientes pasos:
- Configura un agente con el ADK. Esta función requiere la versión 1.29 o posterior del ADK para Python.
- Otorga el rol de IAM
Secret Manager Secret Accessora la identidad del agente. Este rol permite que tu agente recupere secretos durante el tiempo de ejecución. - Crea un secreto y agrega una versión del secreto, como una clave de API, en Secret Manager.
Cómo un agente del ADK recupera secretos en el tiempo de ejecución
El módulo secret_client.SecretManagerClient recupera credenciales en la lógica del código del agente de Python en el tiempo de ejecución. La lógica de organización del agente envía instrucciones al modelo de lenguaje grande (LLM) para decidir qué herramienta ejecutar, pero el sistema no envía el secreto al LLM.
El agente ejecuta los siguientes pasos durante la fase de tiempo de ejecución:
- Antes de que un agente del ADK invoque una herramienta de terceros, el agente inicializa el módulo
SecretManagerClienty llama a la funciónget_secret(). - El agente del ADK usa la identidad del agente para autenticarse en Secret Manager.
- El módulo
SecretManagerClientdevuelve el secreto de texto simple al agente del ADK. - El agente del ADK usa el secreto para realizar una llamada autenticada a la herramienta de terceros.
Recupera secretos dentro de un agente del ADK en el tiempo de ejecución
En el siguiente muestra de código, se muestra cómo puedes usar el módulo SecretManagerClient para recuperar un secreto de forma segura dentro de un agente del ADK. El agente recupera el secreto de forma interna para evitar exponer credenciales sensibles a la ventana de contexto o el historial de conversación del LLM.
Python
Para ejecutar este código, primero configura un entorno de desarrollo de Python e instala el SDK de Python para Secret Manager. En Compute Engine o GKE, debes autenticarte con el permiso cloud-platform.
¿Qué sigue?
- Explora el Kit de desarrollo de agentes.