סוכנים של Agent Development Kit (ADK) יוצרים אינטראקציה עם שירותים חיצוניים מחוץ ל- Google Cloud. גם זהויות של סוכנים וגם ניהול זהויות והרשאות גישה (IAM) מאפשרים לכם לבצע אימות בשירותים של Google Cloud. עם זאת, הם לא יכולים להוכיח את הזהות שלהם בפלטפורמות חיצוניות שלא תומכות באיחוד הזהויות של Google.
סוכני ADK צריכים גישה לפרטי כניסה שונים כדי ליצור אינטראקציה עם ישויות חיצוניות כמו שירותי MCP, כלי ADK וממשקי API. דוגמאות נפוצות:
- מפתחות API לפלטפורמות לעיבוד תשלומים
- שילובי שם משתמש וסיסמה למסדי נתונים מדור קודם שפועלים בשרתים מקומיים
- מפתחות פרטיים לחיבורים של פרוטוקול TLS הדדי (mTLS)
SecretManagerClient בחבילה google.adk.integrations.secret_manager.secret_client. המודול הזה מספק ממשק סטנדרטי לסוכנים לאחזור סודות מ-Secret Manager בזמן הריצה.
במאמר הזה מוסבר איך לנהל סודות של שירותים חיצוניים ב-ADK באמצעות Secret Manager.
היתרונות של שימוש ב-Secret Manager עם ADK
ניהול ידני של סודות עלול ליצור סיכוני אבטחה ולהגדיל את העומס על המפתחים. Secret Manager יכול לעזור לפתור את הבעיות האלה באמצעות הפעולות הבאות:
- אם מטמיעים סודות בקוד של הסוכן, נוצר סיכון אבטחה משמעותי. השימוש בשיטה הזו עלול להוביל לגישה לא מורשית למערכות ייצור. השימוש ב-Secret Manager מסיר נתונים רגישים מקוד המקור. כך האפליקציה שלכם תהיה מאובטחת יותר.
- אם מטמיעים סודות סטטיים באמצעות משתני סביבה, סיבוב פרטי הכניסה הופך למורכב. כדי להחיל את העדכונים, צריך להפעיל מחדש את קובצי ה-deployment. מנהל הסודות מאחזר את פרטי הכניסה באופן דינמי בזמן הריצה, כך שאפשר לבצע עדכונים בלי להשבית את המערכת.
- אם כותבים קוד שחוזר על עצמו (boilerplate) בהתאמה אישית לכל כלי, מגדילים את הטרחה של המפתחים ואת הסיכון לשגיאות.
SecretManagerServiceClientשילוב ה-ADK התקני מספק גישה ברורה וניתנת לשימוש חוזר לאחזור פרטי כניסה.
לפני שמתחילים
לפני שמשלבים את Secret Manager עם ADK, צריך לבצע את הפעולות הבאות:
- הגדרת סוכן באמצעות ADK כדי להשתמש בתכונה הזו צריך ADK בגרסה 1.29 ואילך ל-Python.
- מקצים את תפקיד ה-IAM
Secret Manager Secret Accessorלזהות של הסוכן. התפקיד הזה מאפשר לסוכן לאחזר סודות בזמן ריצה. - יוצרים סוד ומוסיפים גרסה של הסוד, כמו מפתח API, ב-Secret Manager.
איך סוכן ADK מאחזר סודות בזמן ריצה
מודול secret_client.SecretManagerClient מאחזר פרטי כניסה ללוגיקה של קוד הסוכן של Python בזמן הריצה. הלוגיקה של תזמור הסוכנים
שולחת הנחיות למודל שפה גדול (LLM) כדי להחליט איזה כלי להפעיל,
אבל המערכת לא שולחת את הסוד למודל השפה הגדול.
הסוכן מבצע את השלבים הבאים במהלך שלב זמן הריצה:
- לפני שאגנט ADK מפעיל כלי של צד שלישי, האגנט מאתחל את מודול
SecretManagerClientומפעיל את הפונקציהget_secret(). - סוכן ה-ADK משתמש בזהות הסוכן כדי לבצע אימות מול Secret Manager.
- מודול
SecretManagerClientמחזיר את הסוד בטקסט לא מוצפן לסוכן ADK. - הסוכן של ADK משתמש בסוד כדי לבצע קריאה מאומתת לכלי של צד שלישי.
שליפת סודות בסוכן ADK בזמן ריצה
בדוגמת הקוד הבאה אפשר לראות איך משתמשים במודול SecretManagerClient כדי לאחזר סוד בצורה מאובטחת בסוכן ADK. הסוכן מאחזר את הסוד באופן פנימי כדי למנוע חשיפה של פרטי כניסה רגישים לחלון ההקשר או להיסטוריית השיחות של ה-LLM.
Python
כדי להריץ את הקוד הזה, קודם צריך להגדיר סביבת פיתוח בשפת Python ולהתקין את Secret Manager Python SDK. ב-Compute Engine או ב-GKE, צריך לעבור אימות באמצעות ההיקף cloud-platform.