1. परिचय
इस कोडलैब में, Agent Development Kit (ADK) का इस्तेमाल करके एक मल्टी-एजेंट सिस्टम बनाया जाएगा. साथ ही, BigQuery Agent Analytics Plugin का इस्तेमाल करके एजेंट की परफ़ॉर्मेंस को मॉनिटर करने की सुविधा चालू की जाएगी. इसमें, एजेंट से कई सवाल पूछे जाएंगे. इसके बाद, बातचीत के ट्रेस और एजेंट टूल के इस्तेमाल का विश्लेषण करने के लिए, BigQuery का इस्तेमाल किया जाएगा.

आपको क्या करना होगा
- ADK का इस्तेमाल करके, मल्टी-एजेंट रिटेल असिस्टेंट बनाना
- BigQuery Agent Analytics Plugin को शुरू करें, ताकि इस एजेंट के एक्ज़ीक्यूशन के बारे में ट्रेस डेटा को कैप्चर किया जा सके और उसे BigQuery में सेव किया जा सके
- BigQuery में एजेंट के लॉग डेटा का विश्लेषण करना
आपको इन चीज़ों की ज़रूरत होगी
- कोई वेब ब्राउज़र, जैसे कि Chrome
- बिलिंग की सुविधा वाला Google Cloud प्रोजेक्ट या
- Gmail खाता. अगले सेक्शन में, इस कोडलैब के लिए 5 डॉलर का मुफ़्त क्रेडिट रिडीम करने और नया प्रोजेक्ट सेट अप करने का तरीका बताया गया है
यह कोडलैब, सभी लेवल के डेवलपर के लिए है. इसमें शुरुआती डेवलपर भी शामिल हैं. ADK डेवलपमेंट के लिए, Google Cloud Shell में कमांड-लाइन इंटरफ़ेस और Python कोड का इस्तेमाल किया जाएगा. आपको Python का विशेषज्ञ होने की ज़रूरत नहीं है. हालांकि, कोड को पढ़ने की बुनियादी जानकारी होने से, आपको कॉन्सेप्ट समझने में मदद मिलेगी.
2. शुरू करने से पहले
Google Cloud प्रोजेक्ट बनाना
- Google Cloud Console में, प्रोजेक्ट चुनने वाले पेज पर जाकर, Google Cloud प्रोजेक्ट चुनें या बनाएं.

- पक्का करें कि आपके Cloud प्रोजेक्ट के लिए बिलिंग चालू हो. किसी प्रोजेक्ट के लिए बिलिंग चालू है या नहीं, यह देखने का तरीका जानें.
Cloud Shell शुरू करें
Cloud Shell, Google Cloud में चलने वाला एक कमांड-लाइन एनवायरमेंट है. इसमें ज़रूरी टूल पहले से लोड होते हैं.
- Google Cloud Console में सबसे ऊपर मौजूद, Cloud Shell चालू करें पर क्लिक करें:

- Cloud Shell से कनेक्ट होने के बाद, Cloud Shell में पुष्टि करने के लिए यह कमांड चलाएं:
gcloud auth list
- यह पुष्टि करने के लिए कि आपका प्रोजेक्ट gcloud के साथ इस्तेमाल करने के लिए कॉन्फ़िगर किया गया है, यह निर्देश चलाएं:
gcloud config get project
- अगर आपका प्रोजेक्ट उम्मीद के मुताबिक कॉन्फ़िगर नहीं किया गया है, तो अपना प्रोजेक्ट सेट करने के लिए इस निर्देश का इस्तेमाल करें:
export PROJECT_ID=<YOUR_PROJECT_ID>
gcloud config set project $PROJECT_ID
एपीआई चालू करें
- सभी ज़रूरी एपीआई और सेवाओं को चालू करने के लिए, यह निर्देश चलाएं:
gcloud services enable bigquery.googleapis.com \
cloudresourcemanager.googleapis.com \
aiplatform.googleapis.com
- कमांड के सही तरीके से काम करने पर, आपको नीचे दिए गए मैसेज जैसा मैसेज दिखेगा:
"operations/..." ऑपरेशन पूरा हो गया है.
3. इंस्टॉल और सेट अप करना
Cloud Shell पर वापस जाएं और पक्का करें कि आप अपनी होम डायरेक्ट्री में हों.
BigQuery में adk_logs नाम का नया डेटासेट बनाने के लिए, Cloud Shell में यह कमांड चलाएं:
bq mk --dataset --location=US adk_logs
अब, चलिए एक वर्चुअल Python एनवायरमेंट बनाते हैं और ज़रूरी पैकेज इंस्टॉल करते हैं.
- Cloud Shell में नया टर्मिनल टैब खोलें. इसके बाद,
adk-agent-observabilityनाम का फ़ोल्डर बनाने और उस पर जाने के लिए, यह निर्देश चलाएं:
mkdir adk-agent-observability
cd adk-agent-observability
- वर्चुअल Python एनवायरमेंट बनाएं:
python -m venv .venv
- वर्चुअल एनवायरमेंट चालू करें:
source .venv/bin/activate
- ADK इंस्टॉल करें:
pip install --upgrade google-adk
4. ADK ऐप्लिकेशन बनाना
अब हम अपने खुदरा सहायक एजेंट को बनाते हैं. इस एजेंट को ... के लिए डिज़ाइन किया जाएगा
- ज़रूरी फ़ोल्डर और फ़ाइलों के साथ नया एजेंट ऐप्लिकेशन बनाने के लिए, adk create utility command चलाएं:
adk create retail_assistant_app
दिए गए निर्देशों का पालन करें:
- मॉडल के लिए, gemini-2.5-flash चुनें.
- बैकएंड के लिए Vertex AI चुनें.
- अपने डिफ़ॉल्ट Google Cloud प्रोजेक्ट आईडी और क्षेत्र की पुष्टि करें.
यहां इंटरैक्शन का एक उदाहरण दिया गया है:

- Cloud Shell Editor खोलने और नए बनाए गए फ़ोल्डर और फ़ाइलें देखने के लिए, Cloud Shell में 'एडिटर खोलें' बटन पर क्लिक करें:

जनरेट की गई फ़ाइलों को नोट करें:
retail_assistant_app/
├── .venv/
└── retail_assistant_app/
├── __init__.py
├── agent.py
└── .env
- init.py: इस फ़ाइल से फ़ोल्डर को Python मॉड्यूल के तौर पर मार्क किया जाता है.
- agent.py: इसमें एजेंट की शुरुआती परिभाषा शामिल होती है.
- .env: इस फ़ाइल को देखने के लिए, आपको शायद देखें > छिपी हुई फ़ाइलें टॉगल करें पर क्लिक करना पड़े

- .env फ़ाइल में आपके प्रोजेक्ट के लिए एनवायरमेंट वैरिएबल होते हैं. उन वैरिएबल को अपडेट करें जिन्हें प्रॉम्प्ट से सही तरीके से सेट नहीं किया गया था:
GOOGLE_GENAI_USE_VERTEXAI=1
GOOGLE_CLOUD_PROJECT=<YOUR_GOOGLE_PROJECT_ID>
GOOGLE_CLOUD_LOCATION=<YOUR_GOOGLE_CLOUD_REGION>
5. अपने एजेंट को तय करना
अब हम एक क्रमबद्ध मल्टी-एजेंट सिस्टम के बारे में बताते हैं.
- रीयल टाइम ट्रेंड एजेंट: यह Google Search का इस्तेमाल करके, फ़ैशन के मौजूदा ट्रेंड के बारे में जानकारी देता है.
- इन्वेंट्री डेटा एजेंट: यह BigQuery टूलसेट का इस्तेमाल करके, उपलब्ध प्रॉडक्ट के लिए thelook_ecommerce के सार्वजनिक डेटासेट से क्वेरी करता है.
- खुदरा दुकान के असिस्टेंट (रूट) एजेंट: यह एजेंट, वर्कफ़्लो को व्यवस्थित करता है. इसके लिए, यह ट्रेंड एजेंट से सलाह लेता है और इन्वेंट्री एजेंट से मिलते-जुलते प्रॉडक्ट के बारे में पूछता है.
retail_assistant_app/agent.py के पूरे कॉन्टेंट को इस कोड से बदलें.
import os
import uuid
import asyncio
import google.auth
import dotenv
from google.genai import types
from google.adk.agents import Agent
from google.adk.apps import App
from google.adk.runners import InMemoryRunner
from google.adk.tools import AgentTool, google_search
from google.adk.tools.bigquery import BigQueryCredentialsConfig, BigQueryToolset
from google.adk.plugins.bigquery_agent_analytics_plugin import BigQueryAgentAnalyticsPlugin
dotenv.load_dotenv()
# --- Configuration ---
PROJECT_ID = os.getenv('GOOGLE_CLOUD_PROJECT', 'project_not_set')
DATASET_ID = "adk_logs"
TABLE_ID = "retail_assistant_agent_logs"
APP_NAME = "retail_assistant_agent"
USER_ID = "test_user"
# --- Toolsets ---
credentials, _ = google.auth.default()
credentials_config = BigQueryCredentialsConfig(credentials=credentials)
bigquery_toolset = BigQueryToolset(
credentials_config=credentials_config
)
# --- Agents ---
# 1. Trend Spotter
real_time_agent = Agent(
name="real_time_agent",
model="gemini-2.5-flash",
description="Researches external factors like weather, local events, and current fashion trends.",
instruction="""
You are a real-time research agent.
Use Google Search to find real-time information relevant to the user's request,
such as the current weather in their location or trending styles.
""",
tools=[google_search]
)
# 2. Inventory Manager
inventory_data_agent = Agent(
name="inventory_data_agent",
model="gemini-2.5-flash",
description="Oversees product inventory in the BigQuery `thelook_ecommerce` dataset to find available items and prices.",
instruction=f"""
You manage the inventory. You have access to the `bigquery-public-data.thelook_ecommerce` dataset via the BigQuery toolset.
Run all BigQuery queries the project id of: '{PROJECT_ID}'
Your workflow:
1. Look at the products table.
2. Find items that match the requirements, factor in the results from the trend_setter agent if there are any.
3. Return with a user friendly response, including the list of specific products and prices.
""",
tools=[bigquery_toolset]
)
# 3. Root Orchestrator
root_agent = Agent(
name="retail_assistant",
model="gemini-2.5-flash",
description="The primary orchestrator, responsible for handling user input, delegating to sub-agents, and synthesizing the final product recommendation.",
instruction="""
You are a Retail Assistant.
You can ask the 'real_time_agent' agent for any realtime information needed, or style advice, include any information provided by the user.
You should ask the 'inventory_data_agent' agent to find a maximum of 3 available items matching that style.
Combine the results into a recommendation.
""",
tools=[AgentTool(agent=real_time_agent)],
sub_agents=[inventory_data_agent]
)
6. BigQuery Agent Analytics प्लगिन की मदद से लॉग जनरेट करना
अब, एक्ज़ीक्यूशन डेटा कैप्चर करने के लिए, BigQuery Agent Analytics Plugin को कॉन्फ़िगर करें.
इसके लिए, आपको App क्लास का एक इंस्टेंस बनाना होगा. यह क्लास, आपके एजेंट के लिए रनटाइम कंटेनर के तौर पर काम करती है. यह बातचीत के लूप को मैनेज करती है, उपयोगकर्ता की स्थिति को हैंडल करती है, और अटैच किए गए किसी भी प्लगिन (जैसे कि हमारे एजेंट के आंकड़ों का लॉग करने वाला प्लगिन) को व्यवस्थित करती है.
नीचे दिया गया कोड:
- Logging Plugin को शुरू करता है: ज़रूरी कनेक्शन की जानकारी के साथ
BigQueryAgentAnalyticsPluginबनाता है. - प्लगिन को इंटिग्रेट करता है: शुरू किए गए BigQuery प्लगिन को
Appकंस्ट्रक्टर में पास करता है. इससे यह पक्का होता है कि एजेंट के एक्ज़ीक्यूशन इवेंट अपने-आप कैप्चर और लॉग हो जाएं. - एजेंट के काम करने और लॉग करने की सुविधा: यह सुविधा,
runner.run_asyncके ज़रिए बातचीत के फ़्लो को लागू करती है. साथ ही, प्लगिन अपने संसाधनों को बंद करने से पहले, इवेंट के पूरे क्रम को इकट्ठा करके BigQuery को भेजता है.
इस कोड को कॉपी करके, agent.py फ़ाइल में एजेंट की परिभाषाओं के नीचे चिपकाएं:
async def main(prompt: str):
"""Runs a conversation with the BigQuery agent using the ADK Runner."""
bq_logger_plugin = BigQueryAgentAnalyticsPlugin(
project_id=PROJECT_ID, dataset_id=DATASET_ID, table_id=TABLE_ID
)
app = App(name=APP_NAME, root_agent=root_agent, plugins=[bq_logger_plugin])
runner = InMemoryRunner(app=app)
try:
session_id = f"{USER_ID}_{uuid.uuid4().hex[:8]}"
my_session = await runner.session_service.create_session(
app_name=APP_NAME, user_id=USER_ID, session_id=session_id
)
async for event in runner.run_async(
user_id=USER_ID,
new_message=types.Content(
role="user", parts=[types.Part.from_text(text=prompt)]
),
session_id=my_session.id,
):
if event.content.parts and event.content.parts[0].text:
print(f"** {event.author}: {event.content.parts[0].text}")
except Exception as e:
print(f"Error in main: {e}")
finally:
print("Closing BQ Plugin...")
await bq_logger_plugin.close()
print("BQ Plugin closed.")
if __name__ == "__main__":
prompts = [
"what outfits do you have available that are suitable for the weather in london this week?",
"You are such a cool agent! I need a gift idea for my friend who likes yoga.",
"I'd like to complain - the products sold here are not very good quality!"
]
for prompt, prompt in enumerate(prompts):
asyncio.run(main(prompt))
इंस्ट्रुमेंटेशन सेट अप करने के बाद, अब एजेंट को काम करते हुए देखने का समय है. बातचीत के वर्कफ़्लो को ट्रिगर करने के लिए, स्क्रिप्ट चलाएं.
python retail_assistant_app/agent.py
आपको दिखेगा कि खुदरा स्टोर में मौजूद असिस्टेंट, वर्कफ़्लो को व्यवस्थित कर रही है:
- यह रीयल टाइम ट्रेंड एजेंट (real_time_agent) से, लंदन में मौसम की जानकारी देने और फ़ैशन के सही रुझानों को खोजने के लिए कहता है.
- इसके बाद, यह इन्वेंट्री डेटा एजेंट (inventory_data_agent) को यह काम सौंपता है कि वह
thelook_ecommerceBigQuery डेटासेट में, उन रुझानों से मेल खाने वाले खास प्रॉडक्ट के लिए क्वेरी करे. - आखिर में, रूट ऑर्केस्ट्रेटर, नतीजों को मिलाकर एक फ़ाइनल सुझाव तैयार करता है.
इस दौरान, प्लगिन एजेंट के एक्ज़ीक्यूशन ट्रेस को BigQuery पर स्ट्रीम करता है.
7. एजेंट के लॉग का विश्लेषण करना
टूल का इस्तेमाल
अब हम देख सकते हैं कि हमारा एजेंट पर्दे के पीछे क्या कर रहा था! डेटा को BigQuery में स्ट्रीम कर दिया गया है और अब उसका विश्लेषण किया जा सकता है:
- Google Cloud Console में, BigQuery खोजें.
- एक्सप्लोरर पैनल में, अपना प्रोजेक्ट ढूंढें.
adk_logsडेटासेट को बड़ा करें.retail_assitant_agent_logsटेबल खोलें और क्वेरी पर क्लिक करें.

आपके एजेंट ने कौनसे टूल कॉल किए हैं, यह देखने के लिए BigQuery एडिटर में यह क्वेरी चलाएं. साथ ही, टूल से जुड़ी किसी भी गड़बड़ी को कैप्चर करें:
SELECT
-- Extract text between "Tool Name: " and the next comma (or end of line)
REGEXP_EXTRACT(content, r'Tool Name: ([^,]+)') AS tool_name,
-- Count every time a tool finished (successfully or with an error)
COUNT(*) AS total_finished_runs,
-- Count it as a failure if it's an explicit system error OR contains "error" in the text
COUNTIF(event_type = 'TOOL_ERROR' OR REGEXP_CONTAINS(content, r'(?i)\berror\b')) AS failure_count
FROM
`.adk_logs.retail_assistant_agent_logs`
WHERE
event_type IN ('TOOL_COMPLETED', 'TOOL_ERROR')
GROUP BY
1
इसे चार्ट के तौर पर देखने के लिए, विज़ुअलाइज़ेशन पर क्लिक करें:

टोकन का इस्तेमाल
अपने एजेंट की लागत का अनुमान लगाने के लिए, हर एजेंट के इस्तेमाल किए गए प्रॉम्प्ट टोकन और कैंडिडेट टोकन को इकट्ठा करें:
SELECT
t.agent,
SUM(CAST(REGEXP_EXTRACT(t.content, r'prompt:\s*(\d+)') AS INT64)) AS prompt_tokens,
SUM(CAST(REGEXP_EXTRACT(t.content, r'candidates:\s*(\d+)') AS INT64)) AS candidate_tokens
FROM
`adk_logs.retail_assistant_agent_logs` AS t
WHERE
t.event_type = 'LLM_RESPONSE'
AND t.content LIKE '%Token Usage: %'
GROUP BY 1
इसे चार्ट के तौर पर देखने के लिए, विज़ुअलाइज़ेशन पर क्लिक करें:

8. [बोनस] उपयोगकर्ता की भावनाओं का विश्लेषण करना
अब हम एजेंट को दिए गए उपयोगकर्ता के इनपुट के बारे में विश्लेषण करेंगे.
- क्लाउड रिसॉर्स कनेक्शन बनाएं, ताकि BigQuery, Vertex AI की सेवाओं के साथ इंटरैक्ट कर सके.:
bq mk --connection --location=us \
--connection_type=CLOUD_RESOURCE test_connection
आपको इस तरह का जवाब दिखेगा:
Connection 517325854360.us.test_connection successfully created
- क्लाउड संसाधन कनेक्शन बनाने के लिए:
export SERVICE_ACCOUNT_EMAIL=$(bq show --format=prettyjson --connection us.test_connection | grep "serviceAccountId" | cut -d '"' -f 4)
- यह पुष्टि करने के लिए कि सेवा खाता बन गया है, यह कमांड चलाएं:
echo $SERVICE_ACCOUNT_EMAIL
आपको अपना सेवा खाता दिखेगा:

- संसाधन कनेक्शन सेवा खाते को, Vertex AI के साथ इंटरैक्ट करने के लिए ज़रूरी प्रोजेक्ट-लेवल की अनुमतियां दें:
gcloud projects add-iam-policy-binding $(gcloud config get-value project) \
--member="serviceAccount:$SERVICE_ACCOUNT_EMAIL" \
--role='roles/bigquery.connectionUser' \
gcloud projects add-iam-policy-binding $(gcloud config get-value project) \
--member="serviceAccount:$SERVICE_ACCOUNT_EMAIL" \
--role='roles/aiplatform.user'
कुछ मिनट इंतज़ार करें. इसके बाद, उपयोगकर्ता की भावना का विश्लेषण करने के लिए, BigQuery के AI.SCORE फ़ंक्शन का इस्तेमाल करें:
SELECT
timestamp,
user_id,
content,
AI.SCORE((
'What is the sentiment of the user in this text:', content,
'Use a scale from 1 to 5.'),
connection_id => 'us.test_connection') AS user_sentiment
FROM
`adk_logs.retail_assistant_agent_logs`
WHERE
event_type = 'USER_MESSAGE_RECEIVED'
ORDER BY
user_sentiment DESC;
AI.SCORE फ़ंक्शन, उपयोगकर्ता के हर इनपुट के लिए 1 से 5 के बीच की भावना की वैल्यू असाइन करेगा. आपको इस तरह के नतीजे दिखेंगे: 
9. क्लीन अप करें
अपने Google Cloud खाते से शुल्क लिए जाने से बचने के लिए, इस वर्कशॉप के दौरान बनाए गए संसाधनों को मिटाएं.
स्क्रिप्ट से बनाए गए लॉगिंग डेटासेट को मिटाएं:
bq rm -r -f -d $PROJECT_ID:adk_logs
bigquery-adk-codelab डायरेक्ट्री और उसके कॉन्टेंट को हटाने के लिए:
cd ..
rm -rf adk-agent-observability
10. बधाई हो
बधाई हो! आपने एजेंट डेवलपमेंट किट (एडीके) की मदद से, मल्टी-एजेंट सिस्टम बनाया हो. साथ ही, आपने BigQuery Agent Analytics Plugin को इंटिग्रेट किया हो, ताकि एजेंट के व्यवहार को ट्रैक और ऑडिट किया जा सके.