MCP, ADK এবং A2A দিয়ে শুরু করা

1. ওভারভিউ

এআই এজেন্টরা দ্রুত জনপ্রিয়তা বৃদ্ধি পাচ্ছে, লক্ষ্য অর্জনের জন্য তাদের স্বায়ত্তশাসিতভাবে পরিচালনা করার, শেখার এবং তাদের পরিবেশের সাথে যোগাযোগ করার ক্ষমতা দিয়ে টাস্ক অটোমেশন এবং সিদ্ধান্ত গ্রহণে বিপ্লব ঘটাচ্ছে।

কিন্তু ঠিক কিভাবে একজন এজেন্ট তৈরি করতে পারে? এই কোডল্যাব আপনাকে বিভিন্ন দেশের মুদ্রার মধ্যে রূপান্তর করতে পারে এমন একটি কারেন্সি এজেন্ট কীভাবে তৈরি করতে হয় তা দেখিয়ে আপনাকে শুরু করতে সাহায্য করবে। আপনি ইন্টারনেটে (MCP, ADK, A2A) ভাসতে দেখেছেন এমন সংক্ষিপ্ত শব্দগুলি বুঝতে আপনাকে সাহায্য করার জন্য সর্বশেষ প্রযুক্তির মাধ্যমে হাঁটার লক্ষ্য নিয়ে।

স্থাপত্য

মডেল কনটেক্সট প্রোটোকল (MCP)

মডেল কনটেক্সট প্রোটোকল (MCP) হল একটি উন্মুক্ত প্রোটোকল যা প্রমিত করে যে কীভাবে অ্যাপ্লিকেশনগুলি LLM-কে প্রসঙ্গ প্রদান করে। এমসিপি এআই মডেলগুলিকে সংস্থান, প্রম্পট এবং সরঞ্জামগুলির সাথে সংযুক্ত করার একটি প্রমিত উপায় সরবরাহ করে।

এজেন্ট ডেভেলপমেন্ট কিট (ADK)

এজেন্ট ডেভেলপমেন্ট কিট (ADK) হল একটি নমনীয় অর্কেস্ট্রেশন ফ্রেমওয়ার্ক যা এআই এজেন্টদের ডেভেলপ করা এবং মোতায়েন করার জন্য। ADK হল মডেল-অজ্ঞেয়বাদী, স্থাপনা-অজ্ঞেয়বাদী, এবং অন্যান্য কাঠামোর সাথে সামঞ্জস্যের জন্য তৈরি করা হয়েছে। ADK ডিজাইন করা হয়েছে এজেন্ট ডেভেলপমেন্টকে সফটওয়্যার ডেভেলপমেন্টের মতো অনুভব করার জন্য, যাতে ডেভেলপারদের জন্য সহজ কাজ থেকে জটিল ওয়ার্কফ্লো পর্যন্ত এজেন্টিক আর্কিটেকচার তৈরি করা, স্থাপন করা এবং অর্কেস্ট্রেট করা সহজ হয়।

Agent2Agent (A2A) প্রোটোকল

Agent2Agent (A2A) প্রোটোকল হল একটি ওপেন স্ট্যান্ডার্ড যা এআই এজেন্টদের মধ্যে নির্বিঘ্ন যোগাযোগ এবং সহযোগিতা সক্ষম করার জন্য ডিজাইন করা হয়েছে। এমসিপি যেভাবে LLM-কে ডেটা এবং টুলগুলিতে অ্যাক্সেস দেওয়ার জন্য একটি প্রমিত উপায় প্রদান করে, তেমনি A2A এজেন্টদের অন্য এজেন্টদের সাথে কথা বলার জন্য একটি প্রমিত উপায় প্রদান করে! এমন একটি বিশ্বে যেখানে এজেন্ট বিভিন্ন ফ্রেমওয়ার্ক ব্যবহার করে এবং বিভিন্ন বিক্রেতাদের দ্বারা তৈরি করা হয়, A2A একটি সাধারণ ভাষা প্রদান করে, সাইলোগুলি ভেঙে দেয় এবং আন্তঃকার্যক্ষমতা বৃদ্ধি করে।

আপনি কি শিখবেন

  • কিভাবে একটি স্থানীয় MCP সার্ভার তৈরি করবেন
  • ক্লাউড রানে MCP সার্ভার স্থাপন করা হচ্ছে
  • এমসিপি টুল ব্যবহার করে এজেন্ট ডেভেলপমেন্ট কিট দিয়ে কীভাবে এজেন্ট তৈরি করবেন
  • একটি A2A সার্ভার হিসাবে একটি ADK এজেন্টকে কীভাবে প্রকাশ করবেন
  • A2A ক্লায়েন্ট ব্যবহার করে A2A সার্ভার পরীক্ষা করা হচ্ছে

আপনি কি প্রয়োজন হবে

2. আপনি শুরু করার আগে

একটি প্রকল্প তৈরি করুন

  1. Google ক্লাউড কনসোলে , প্রকল্প নির্বাচক পৃষ্ঠায়, একটি Google ক্লাউড প্রকল্প নির্বাচন করুন বা তৈরি করুন।
  2. নিশ্চিত করুন যে আপনার ক্লাউড প্রকল্পের জন্য বিলিং সক্ষম করা আছে৷ একটি প্রকল্পে বিলিং সক্ষম কিনা তা পরীক্ষা করতে শিখুন।
  3. এই লিঙ্কে ক্লিক করে ক্লাউড শেল সক্রিয় করুন। আপনি ক্লাউড শেল থেকে সংশ্লিষ্ট বোতামে ক্লিক করে ক্লাউড শেল টার্মিনাল (ক্লাউড কমান্ড চালানোর জন্য) এবং সম্পাদক (প্রকল্প নির্মাণের জন্য) এর মধ্যে টগল করতে পারেন।
  4. একবার ক্লাউড শেলের সাথে সংযুক্ত হয়ে গেলে, আপনি পরীক্ষা করে দেখুন যে আপনি ইতিমধ্যেই প্রমাণীকৃত হয়েছেন এবং নিম্নলিখিত কমান্ডটি ব্যবহার করে প্রকল্পটি আপনার প্রকল্প আইডিতে সেট করা আছে:
gcloud auth list
  1. gcloud কমান্ড আপনার প্রকল্প সম্পর্কে জানে তা নিশ্চিত করতে ক্লাউড শেলে নিম্নলিখিত কমান্ডটি চালান।
gcloud config list project
  1. আপনার প্রকল্প সেট করতে নিম্নলিখিত কমান্ড ব্যবহার করুন:
export PROJECT_ID=<YOUR_PROJECT_ID>
gcloud config set project $PROJECT_ID
  1. নিম্নলিখিত কমান্ড ব্যবহার করে প্রয়োজনীয় API সক্রিয় করুন। এতে কয়েক মিনিট সময় লাগতে পারে।
gcloud services enable cloudresourcemanager.googleapis.com \
                       servicenetworking.googleapis.com \
                       run.googleapis.com \
                       cloudbuild.googleapis.com \
                       artifactregistry.googleapis.com \
                       aiplatform.googleapis.com \
                       compute.googleapis.com
  1. পাইথন 3.10+ আছে তা নিশ্চিত করুন

gcloud কমান্ড এবং ব্যবহারের জন্য ডকুমেন্টেশন পড়ুন।

3. ইনস্টলেশন

  1. সংগ্রহস্থল ক্লোন করুন:
git clone https://github.com/jackwotherspoon/currency-agent.git
cd currency-agent
  1. ইউভি ইনস্টল করুন (নির্ভরতা পরিচালনা করতে ব্যবহৃত):
# macOS and Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# Windows (uncomment below line)
# powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
  1. পরিবেশ ভেরিয়েবল কনফিগার করুন ( .env ফাইলের মাধ্যমে):

নিম্নলিখিতটি চালিয়ে একটি .env ফাইল তৈরি করুন:

echo "GOOGLE_GENAI_USE_VERTEXAI=TRUE" >> .env \
&& echo "GOOGLE_CLOUD_PROJECT=$PROJECT_ID" >> .env \
&& echo "GOOGLE_CLOUD_LOCATION=us-central1" >> .env

4. একটি স্থানীয় MCP সার্ভার তৈরি করুন

আপনি আপনার কারেন্সি এজেন্টকে সাজাতে যাওয়ার আগে, আপনার এজেন্টের প্রয়োজন হবে এমন আপনার টুল(গুলি) প্রকাশ করার জন্য আপনি প্রথমে একটি MCP সার্ভার তৈরি করবেন।

একটি MCP সার্ভার আপনাকে সরঞ্জাম হিসাবে নির্দিষ্ট ক্ষমতা (যেমন মুদ্রা বিনিময় হার আনা) প্রকাশ করতে হালকা প্রোগ্রাম লিখতে দেয়। একটি এজেন্ট বা এমনকি একাধিক এজেন্ট প্রমিত মডেল কনটেক্সট প্রোটোকল (MCP) ব্যবহার করে এই সরঞ্জামগুলি অ্যাক্সেস করতে পারে।

FastMCP পাইথন প্যাকেজটি একটি MCP সার্ভার তৈরি করতে ব্যবহার করা যেতে পারে যা get_exchange_rate নামক একটি একক টুলকে প্রকাশ করে। get_exchange_rate টুলটি দুটি মুদ্রার মধ্যে বর্তমান বিনিময় হার পেতে ফ্রাঙ্কফুর্টার API- এ ইন্টারনেটের মাধ্যমে একটি কল করে।

MCP সার্ভারের কোডটি mcp-server/server.py ফাইলে পাওয়া যাবে:

import logging
import os

import httpx
from fastmcp import FastMCP

# Set up logging
logger = logging.getLogger(__name__)
logging.basicConfig(format="[%(levelname)s]: %(message)s", level=logging.INFO)

mcp = FastMCP("Currency MCP Server 💵")

@mcp.tool()
def get_exchange_rate(
    currency_from: str = 'USD',
    currency_to: str = 'EUR',
    currency_date: str = 'latest',
):
    """Use this to get current exchange rate.

    Args:
        currency_from: The currency to convert from (e.g., "USD").
        currency_to: The currency to convert to (e.g., "EUR").
        currency_date: The date for the exchange rate or "latest". Defaults to "latest".

    Returns:
        A dictionary containing the exchange rate data, or an error message if the request fails.
    """
    logger.info(f"--- 🛠️ Tool: get_exchange_rate called for converting {currency_from} to {currency_to} ---")
    try:
        response = httpx.get(
            f'https://api.frankfurter.app/{currency_date}',
            params={'from': currency_from, 'to': currency_to},
        )
        response.raise_for_status()

        data = response.json()
        if 'rates' not in data:
            return {'error': 'Invalid API response format.'}
        logger.info(f'✅ API response: {data}')
        return data
    except httpx.HTTPError as e:
        return {'error': f'API request failed: {e}'}
    except ValueError:
        return {'error': 'Invalid JSON response from API.'}

if __name__ == "__main__":
    logger.info(f"🚀 MCP server started on port {os.getenv('PORT', 8080)}")
    # Could also use 'sse' transport, host="0.0.0.0" required for Cloud Run.
    asyncio.run(
        mcp.run_async(
            transport="http",
            host="0.0.0.0",
            port=os.getenv("PORT", 8080),
        )
    )

স্থানীয়ভাবে MCP সার্ভার শুরু করতে, একটি টার্মিনাল খুলুন এবং নিম্নলিখিত কমান্ডটি চালান (সার্ভারটি http://localhost:8080 এ শুরু হবে):

uv run mcp-server/server.py

পরীক্ষা করুন যে MCP সার্ভার সঠিকভাবে কাজ করছে এবং মডেল কনটেক্সট প্রোটোকল ব্যবহার করে get_exchange_rate টুল অ্যাক্সেসযোগ্য।

একটি নতুন টার্মিনাল উইন্ডোতে (যাতে আপনি স্থানীয় MCP সার্ভার বন্ধ না করেন) নিম্নলিখিতটি চালান:

uv run mcp-server/test_server.py

আপনি 1 USD (US ডলার) থেকে EUR (Euro) এর বর্তমান বিনিময় হার দেখতে পাবেন:

--- 🛠️ Tool found: get_exchange_rate ---
--- 🪛 Calling get_exchange_rate tool for USD to EUR ---
---  Success: {
  "amount": 1.0,
  "base": "USD",
  "date": "2025-05-26",
  "rates": {
    "EUR": 0.87866
  }
} ---

অসাধারন! আপনার কাছে সফলভাবে একটি টুল সহ একটি কার্যকরী MCP সার্ভার রয়েছে যা আপনার এজেন্ট অ্যাক্সেস করতে সক্ষম হবে।

পরবর্তী স্টেশনে যাওয়ার আগে, আপনি যে টার্মিনালে এটি শুরু করেছিলেন সেখানে Ctrl+C (বা Mac-এ Command+C ) চালিয়ে স্থানীয়ভাবে চলমান MCP সার্ভার বন্ধ করুন।

5. ক্লাউড রানে আপনার MCP সার্ভার স্থাপন করুন

এখন আপনি ক্লাউড রানে একটি দূরবর্তী MCP সার্ভার হিসাবে MCP সার্ভার স্থাপন করতে প্রস্তুত 🚀☁️

দূরবর্তীভাবে একটি MCP সার্ভার চালানোর সুবিধা

ক্লাউড রানে দূরবর্তীভাবে একটি MCP সার্ভার চালানো বিভিন্ন সুবিধা প্রদান করতে পারে:

  • 📈 স্কেলেবিলিটি : ক্লাউড রান সমস্ত আগত অনুরোধগুলি পরিচালনা করার জন্য দ্রুত স্কেল আউট করার জন্য তৈরি করা হয়েছে৷ ক্লাউড রান চাহিদার উপর ভিত্তি করে স্বয়ংক্রিয়ভাবে আপনার MCP সার্ভারকে স্কেল করবে।
  • 👥কেন্দ্রীভূত সার্ভার : আপনি আইএএম বিশেষাধিকারের মাধ্যমে দলের সদস্যদের সাথে একটি কেন্দ্রীভূত MCP সার্ভারে অ্যাক্সেস শেয়ার করতে পারেন, যাতে তারা স্থানীয়ভাবে তাদের নিজস্ব সার্ভার চালানোর পরিবর্তে তাদের স্থানীয় মেশিন থেকে এটিতে সংযোগ করতে দেয়। যদি MCP সার্ভারে কোনো পরিবর্তন করা হয়, তাহলে দলের সকল সদস্যরা এর থেকে উপকৃত হবেন।
  • 🔐নিরাপত্তা : ক্লাউড রান প্রমাণীকৃত অনুরোধ জোর করার একটি সহজ উপায় প্রদান করে। এটি আপনার MCP সার্ভারে শুধুমাত্র সুরক্ষিত সংযোগের অনুমতি দেয়, অননুমোদিত অ্যাক্সেস প্রতিরোধ করে।

mcp-server ডিরেক্টরিতে পরিবর্তন করুন:

cd mcp-server

ক্লাউড রানে MCP সার্ভার স্থাপন করুন:

gcloud run deploy mcp-server --no-allow-unauthenticated --region=us-central1 --source .

আপনার পরিষেবা সফলভাবে স্থাপন করা হলে আপনি নিম্নলিখিত মত একটি বার্তা দেখতে পাবেন:

Service [mcp-server] revision [mcp-server-12345-abc] has been deployed and is serving 100 percent of traffic.

MCP ক্লায়েন্ট প্রমাণীকরণ

যেহেতু আপনি প্রমাণীকরণের প্রয়োজনে --no-allow-unauthenticated উল্লেখ করেছেন, তাই দূরবর্তী MCP সার্ভারের সাথে সংযোগকারী যে কোনো MCP ক্লায়েন্টকে প্রমাণীকরণ করতে হবে।

আপনি আপনার MCP ক্লায়েন্ট কোথায় চালাচ্ছেন তার উপর নির্ভর করে ক্লাউড রানে হোস্ট এমসিপি সার্ভারের অফিসিয়াল ডক্স এই বিষয়ে আরও তথ্য প্রদান করে।

আপনার স্থানীয় মেশিনে দূরবর্তী MCP সার্ভারে একটি প্রমাণীকৃত টানেল তৈরি করতে আপনাকে ক্লাউড রান প্রক্সি চালাতে হবে।

ডিফল্টরূপে, ক্লাউড রান পরিষেবার URL-এর জন্য সমস্ত অনুরোধ ক্লাউড রান ইনভোকার ( roles/run.invoker ) IAM ভূমিকার সাথে অনুমোদিত হতে হবে৷ এই IAM নীতি বাইন্ডিং নিশ্চিত করে যে আপনার স্থানীয় MCP ক্লায়েন্টকে প্রমাণীকরণ করতে একটি শক্তিশালী নিরাপত্তা ব্যবস্থা ব্যবহার করা হয়েছে।

আপনাকে নিশ্চিত করতে হবে যে আপনি বা যে কোনো দলের সদস্যরা দূরবর্তী MCP সার্ভার অ্যাক্সেস করার চেষ্টা করছেন তাদের IAM প্রধান (Google ক্লাউড অ্যাকাউন্ট) এর সাথে আবদ্ধ roles/run.invoker IAM ভূমিকা আছে।

gcloud run services proxy mcp-server --region=us-central1

আপনি নিম্নলিখিত আউটপুট দেখতে হবে:

Proxying to Cloud Run service [mcp-server] in project [<YOUR_PROJECT_ID>] region [us-central1]
http://127.0.0.1:8080 proxies to https://mcp-server-abcdefgh-uc.a.run.app

http://127.0.0.1:8080 এ সমস্ত ট্র্যাফিক এখন প্রমাণীকরণ করা হবে এবং দূরবর্তী MCP সার্ভারে ফরোয়ার্ড করা হবে।

দূরবর্তী MCP সার্ভার পরীক্ষা করুন

একটি নতুন টার্মিনালে , রুট ফোল্ডারে ফিরে যান এবং দূরবর্তী MCP সার্ভার কাজ করছে তা নিশ্চিত করতে mcp-server/test_server.py ফাইলটি পুনরায় চালান।

cd ..
uv run mcp-server/test_server.py

স্থানীয়ভাবে সার্ভার চালানোর সময় আপনি একই রকম আউটপুট দেখতে পাবেন:

--- 🛠️ Tool found: get_exchange_rate ---
--- 🪛 Calling get_exchange_rate tool for USD to EUR ---
---  Success: {
  "amount": 1.0,
  "base": "USD",
  "date": "2025-05-26",
  "rates": {
    "EUR": 0.87866
  }
} ---

আপনি নিয়োজিত ক্লাউড রান MCP সার্ভারের লগগুলি জিজ্ঞাসা করতে পারেন যদি আপনি যাচাই করতে চান যে রিমোট সার্ভারটিকে প্রকৃতপক্ষে কল করা হয়েছে:

gcloud run services logs read mcp-server --region us-central1 --limit 5

আপনি লগগুলিতে নিম্নলিখিত আউটপুট দেখতে পাবেন:

2025-06-04 14:28:29,871 [INFO]: --- 🛠️ Tool: get_exchange_rate called for converting USD to EUR ---
2025-06-04 14:28:30,610 [INFO]: HTTP Request: GET https://api.frankfurter.app/latest?from=USD&to=EUR "HTTP/1.1 200 OK"
2025-06-04 14:28:30,611 [INFO]:  API response: {'amount': 1.0, 'base': 'USD', 'date': '2025-06-03', 'rates': {'EUR': 0.87827}}

এখন আপনার কাছে একটি দূরবর্তী MCP সার্ভার আছে, আপনি একটি এজেন্ট তৈরি করতে যেতে পারেন! 🤖

6. এজেন্ট ডেভেলপমেন্ট কিট (ADK) দিয়ে একটি এজেন্ট তৈরি করুন

আপনার একটি স্থাপন করা MCP সার্ভার আছে, এখন সময় এসেছে এজেন্ট ডেভেলপমেন্ট কিট (ADK) ব্যবহার করে মুদ্রা এজেন্ট তৈরি করার।

এজেন্ট ডেভেলপমেন্ট কিট সম্প্রতি তার v1.0.0 স্থিতিশীল রিলিজ প্রকাশ করেছে। এই মাইলফলকটি নির্দেশ করে যে পাইথন ADK এখন উৎপাদন-প্রস্তুত, ডেভেলপারদের লাইভ পরিবেশে তাদের এজেন্টদের আত্মবিশ্বাসের সাথে তৈরি এবং স্থাপন করার জন্য একটি নির্ভরযোগ্য এবং শক্তিশালী প্ল্যাটফর্ম অফার করে।

ADK ক্রিয়েটিং এজেন্টকে অত্যন্ত লাইটওয়েট করে এবং তাদের MCP টুলের জন্য অন্তর্নির্মিত সমর্থন সহ MCP সার্ভারের সাথে সহজেই সংযোগ করতে দেয়। মুদ্রা এজেন্ট ADK-এর MCPToolset ক্লাস ব্যবহার করে get_exchange_rate টুল অ্যাক্সেস করবে।

কারেন্সি এজেন্টের কোডটি currency_agent/agent.py এ অবস্থিত:

import logging
import os

from dotenv import load_dotenv
from google.adk.agents import LlmAgent
from google.adk.a2a.utils.agent_to_a2a import to_a2a
from google.adk.tools.mcp_tool import MCPToolset, StreamableHTTPConnectionParams

logger = logging.getLogger(__name__)
logging.basicConfig(format="[%(levelname)s]: %(message)s", level=logging.INFO)

load_dotenv()

SYSTEM_INSTRUCTION = (
    "You are a specialized assistant for currency conversions. "
    "Your sole purpose is to use the 'get_exchange_rate' tool to answer questions about currency exchange rates. "
    "If the user asks about anything other than currency conversion or exchange rates, "
    "politely state that you cannot help with that topic and can only assist with currency-related queries. "
    "Do not attempt to answer unrelated questions or use tools for other purposes."
)

logger.info("--- 🔧 Loading MCP tools from MCP Server... ---")
logger.info("--- 🤖 Creating ADK Currency Agent... ---")

root_agent = LlmAgent(
    model="gemini-2.5-flash",
    name="currency_agent",
    description="An agent that can help with currency conversions",
    instruction=SYSTEM_INSTRUCTION,
    tools=[
        MCPToolset(
            connection_params=StreamableHTTPConnectionParams(
                url=os.getenv("MCP_SERVER_URL", "http://localhost:8080/mcp")
            )
        )
    ],
)

মুদ্রা এজেন্ট দ্রুত পরীক্ষা করার জন্য আপনি ADK এর dev UI এর সুবিধা নিতে পারেন, adk web চালানোর মাধ্যমে অ্যাক্সেস করা যায়:

uv run adk web

একটি ব্রাউজারে, এজেন্ট দেখতে ও পরীক্ষা করতে http://localhost:8000 এ যান!

নিশ্চিত করুন যে currency_agent ওয়েব UI এর উপরের বাম কোণে এজেন্ট হিসাবে নির্বাচিত হয়েছে৷

ADK ওয়েব UI

চ্যাট এলাকায় আপনার এজেন্টকে জিজ্ঞাসা করুন "250 CAD থেকে USD কি?" . আপনি দেখতে পাবেন যে এজেন্ট আমাদের get_exchange_rate MCP টুলকে একটি প্রতিক্রিয়া দেওয়ার আগে কল করে।

ADK ওয়েব কারেন্সি এজেন্ট

এজেন্ট কাজ করে! এটি কারেন্সি কনভার্সন 💸 এর চারপাশে আবর্তিত প্রশ্নগুলি পরিচালনা করতে পারে।

7. Agent2Agent (A2A) প্রোটোকল

Agent2Agent (A2A) প্রোটোকল হল একটি ওপেন স্ট্যান্ডার্ড যা এআই এজেন্টদের মধ্যে নির্বিঘ্ন যোগাযোগ এবং সহযোগিতা সক্ষম করার জন্য ডিজাইন করা হয়েছে। এটি বিভিন্ন ফ্রেমওয়ার্ক ব্যবহার করে এবং বিভিন্ন বিক্রেতাদের দ্বারা নির্মিত এজেন্টদেরকে একটি সাধারণ ভাষায় একে অপরের সাথে যোগাযোগ করতে, সাইলো ভেঙ্গে এবং আন্তঃকার্যক্ষমতা বৃদ্ধির অনুমতি দেয়।

A2A প্রোটোকল

A2A এজেন্টদের অনুমতি দেয়:

  • আবিষ্কার করুন: অন্যান্য এজেন্ট খুঁজুন এবং প্রমিত এজেন্ট কার্ড ব্যবহার করে তাদের দক্ষতা ( এজেন্টস্কিল ) এবং ক্ষমতা ( এজেন্ট সক্ষমতা ) শিখুন।
  • যোগাযোগ করুন: নিরাপদে বার্তা এবং ডেটা বিনিময় করুন।
  • সহযোগিতা করুন: জটিল লক্ষ্যগুলি অর্জনের জন্য কাজগুলি অর্পণ করুন এবং ক্রিয়াগুলির সমন্বয় করুন৷

A2A প্রোটোকল "এজেন্ট কার্ড" এর মতো প্রক্রিয়ার মাধ্যমে এই যোগাযোগকে সহজতর করে যা ডিজিটাল ব্যবসায়িক কার্ড এজেন্টরা তাদের ক্ষমতা এবং সংযোগ তথ্যের বিজ্ঞাপন দিতে ব্যবহার করতে পারে।

A2A এজেন্ট কার্ড

এখন সময় এসেছে A2A ব্যবহার করে মুদ্রা এজেন্টকে প্রকাশ করার যাতে এটি অন্য এজেন্ট এবং ক্লায়েন্টদের দ্বারা ডাকা যায়।

A2A পাইথন SDK

A2A পাইথন SDK উপরে উল্লিখিত প্রতিটি সংস্থানের জন্য পাইডানটিক মডেল সরবরাহ করে; এজেন্টস্কিল , এজেন্ট ক্যাপাবিলিটিস এবং এজেন্টকার্ড । এটি A2A প্রোটোকলের সাথে উন্নয়ন এবং একীকরণ ত্বরান্বিত করার জন্য একটি ইন্টারফেস প্রদান করে।

একটি AgentSkill হল আপনি কীভাবে অন্য এজেন্টদের কাছে বিজ্ঞাপন দেবেন যে মুদ্রা এজেন্টের কাছে get_exchange_rate জন্য একটি টুল রয়েছে:

# A2A Agent Skill definition
skill = AgentSkill(
    id='get_exchange_rate',
    name='Currency Exchange Rates Tool',
    description='Helps with exchange values between various currencies',
    tags=['currency conversion', 'currency exchange'],
    examples=['What is exchange rate between USD and GBP?'],
)

তারপর AgentCard অংশ হিসাবে এটি এজেন্টের দক্ষতা এবং ক্ষমতার পাশাপাশি ইনপুট এবং আউটপুট মোডের মতো অতিরিক্ত বিবরণের তালিকা করবে যা এজেন্ট পরিচালনা করতে পারে:

# A2A Agent Card definition
agent_card = AgentCard(
    name='Currency Agent',
    description='Helps with exchange rates for currencies',
    url=f'http://{host}:{port}/',
    version='1.0.0',
    defaultInputModes=["text"],
    defaultOutputModes=["text"],
    capabilities=AgentCapabilities(streaming=True),
    skills=[skill],
)

সময় এসেছে কারেন্সি এজেন্টের সাথে একত্রিত করার এবং A2A এর শক্তি প্রদর্শন করার!

8. মুদ্রা এজেন্ট A2A সার্ভার প্রকাশ করা

ADK আপনার জন্য A2A প্রোটোকল ব্যবহার করে এজেন্ট তৈরি এবং সংযোগ করার প্রক্রিয়া সহজ করে। একটি A2A সার্ভার হিসাবে একটি বিদ্যমান ADK এজেন্টকে অ্যাক্সেসযোগ্য করা (প্রকাশ করা) ADK এর to_a2a(root_agent) ফাংশন দিয়ে করা হয় (সম্পূর্ণ বিবরণের জন্য ADK ডকুমেন্টেশন দেখুন)।

to_a2a ফাংশন একটি বিদ্যমান এজেন্টকে A2A এর সাথে কাজ করার জন্য রূপান্তরিত করে এবং এটিকে uvicorn মাধ্যমে সার্ভার হিসাবে প্রকাশ করতে সক্ষম হয়। এর মানে হল যে আপনি যদি আপনার এজেন্টকে উত্পাদন করার পরিকল্পনা করেন তবে আপনি যা প্রকাশ করতে চান তার উপর আপনার কঠোর নিয়ন্ত্রণ রয়েছে। to_a2a() ফাংশনটি হুডের নিচে A2A পাইথন SDK ব্যবহার করে আপনার এজেন্ট কোডের উপর ভিত্তি করে একটি এজেন্ট কার্ড স্বয়ংক্রিয়ভাবে তৈরি করে।

currency_agent/agent.py ফাইলের ভিতরে একবার দেখে নিলে আপনি to_a2a এর ব্যবহার দেখতে পাবেন এবং কারেন্সি এজেন্টকে A2A সার্ভার হিসেবে মাত্র দুটি লাইনের কোড দিয়ে কীভাবে প্রকাশ করা হয়!

from google.adk.a2a.utils.agent_to_a2a import to_a2a
# ... see file for full code

# Make the agent A2A-compatible
a2a_app = to_a2a(root_agent, port=10000)

A2A সার্ভার চালানোর জন্য, একটি নতুন টার্মিনালে নিম্নলিখিতগুলি চালান:

uv run uvicorn currency_agent.agent:a2a_app --host localhost --port 10000

সার্ভার সফলভাবে শুরু হলে, আউটপুটটি নিম্নরূপ দেখাবে যা নির্দেশ করে যে এটি 10000 পোর্টে চলছে:

[INFO]: --- 🔧 Loading MCP tools from MCP Server... ---
[INFO]: --- 🤖 Creating ADK Currency Agent... ---
INFO:     Started server process [45824]
INFO:     Waiting for application startup.
INFO:     Application startup complete.
INFO:     Uvicorn running on http://localhost:10000 (Press CTRL+C to quit)

মুদ্রা এজেন্ট এখন A2A সার্ভার হিসাবে সফলভাবে চলছে, A2A প্রোটোকল ব্যবহার করে অন্যান্য এজেন্ট বা ক্লায়েন্টদের কল করার ক্ষমতা সহ!

রিমোট এজেন্ট চলছে তা যাচাই করুন

to_a2a() ফাংশন দ্বারা স্বয়ংক্রিয়ভাবে তৈরি হওয়া কারেন্সি এজেন্টের এজেন্ট কার্ড URL-এ গিয়ে আপনার এজেন্ট চালু এবং চলছে কিনা তা আপনি দুবার চেক করতে পারেন।

আপনার ব্রাউজারে, [http://localhost:10000/.well-known/agent.json]-এ যান

আপনি নিম্নলিখিত এজেন্ট কার্ড দেখতে হবে:

{
  "capabilities": {

  },
  "defaultInputModes": [
    "text/plain"
  ],
  "defaultOutputModes": [
    "text/plain"
  ],
  "description": "An agent that can help with currency conversions",
  "name": "currency_agent",
  "preferredTransport": "JSONRPC",
  "protocolVersion": "0.3.0",
  "skills": [
    {
      "description": "An agent that can help with currency conversions I am a specialized assistant for currency conversions. my sole purpose is to use the 'get_exchange_rate' tool to answer questions about currency exchange rates. If the user asks about anything other than currency conversion or exchange rates, politely state that I cannot help with that topic and can only assist with currency-related queries. Do not attempt to answer unrelated questions or use tools for other purposes.",
      "id": "currency_agent",
      "name": "model",
      "tags": [
        "llm"
      ]
    },
    {
      "description": "Use this to get current exchange rate.\n\nArgs:\n    currency_from: The currency to convert from (e.g., \"USD\").\n    currency_to: The currency to convert to (e.g., \"EUR\").\n    currency_date: The date for the exchange rate or \"latest\". Defaults to \"latest\".\n\nReturns:\n    A dictionary containing the exchange rate data, or an error message if the request fails.",
      "id": "currency_agent-get_exchange_rate",
      "name": "get_exchange_rate",
      "tags": [
        "llm",
        "tools"
      ]
    }
  ],
  "supportsAuthenticatedExtendedCard": false,
  "url": "http://localhost:10000",
  "version": "0.0.1"
}

A2A সার্ভার পরীক্ষা করুন

আপনি এখন A2A ব্যবহার করে কিছু অনুরোধ পাঠিয়ে সার্ভার পরীক্ষা করতে পারেন!

A2A পাইথন SDK একটি a2a.client.A2AClient ক্লাস প্রদান করে যা আপনার জন্য এটিকে সহজ করে।

currency_agent/test_client.py ফাইলটিতে কোড রয়েছে যা A2A সার্ভারের বিরুদ্ধে বিভিন্ন পরীক্ষার ক্ষেত্রে চলে।

# ... see file for full code

# Example test using A2AClient
async def run_single_turn_test(client: A2AClient) -> None:
    """Runs a single-turn non-streaming test."""

    send_message_payload = create_send_message_payload(text="how much is 100 USD in CAD?")
    request = SendMessageRequest(
        id=str(uuid4()), params=MessageSendParams(**send_message_payload)
    )

    print("--- ✉️  Single Turn Request ---")
    # Send Message
    response: SendMessageResponse = await client.send_message(request)
    print_json_response(response, "📥 Single Turn Request Response")
    if not isinstance(response.root, SendMessageSuccessResponse):
        print("received non-success response. Aborting get task ")
        return

    if not isinstance(response.root.result, Task):
        print("received non-task response. Aborting get task ")
        return

    task_id: str = response.root.result.id
    print("--- ❔ Query Task ---")
    # query the task
    get_request = GetTaskRequest(id=str(uuid4()), params=TaskQueryParams(id=task_id))
    get_response: GetTaskResponse = await client.get_task(get_request)
    print_json_response(get_response, "📥 Query Task Response")

# ----- Main Entrypoint (Create client --> Run tests) -----
async def main() -> None:
    """Main function to run the tests."""
    print(f'--- 🔄 Connecting to agent at {AGENT_URL}... ---')
    try:
        async with httpx.AsyncClient() as httpx_client:
            # Create a resolver to fetch the agent card
            resolver = A2ACardResolver(
                httpx_client=httpx_client,
                base_url=AGENT_URL,
            )
            agent_card = await resolver.get_agent_card()
            # Create a client to interact with the agent
            client = A2AClient(
                httpx_client=httpx_client,
                agent_card=agent_card,
            )
            print('--- ✅ Connection successful. ---')

            await run_single_turn_test(client)
            await run_multi_turn_test(client)

    except Exception as e:
        traceback.print_exc()
        print(f'--- ❌ An error occurred: {e} ---')
        print('Ensure the agent server is running.')

নিম্নলিখিত কমান্ড ব্যবহার করে পরীক্ষা চালান:

uv run currency_agent/test_client.py

একটি সফল পরীক্ষা চালানোর ফলে নিম্নলিখিত হবে:

--- 🔄 Connecting to agent at http://localhost:10000... ---
---  Connection successful. ---
--- ✉️ Single Turn Request ---
--- 📥 Single Turn Request Response ---
{"id":"3bc92d7b-d857-4e93-9ff0-b2fb865f6e35","jsonrpc":"2.0","result":{"artifacts":[{"artifactId":"35e89e14-b977-4397-a23b-92c84bc32379","parts":[{"kind":"text","text":"Based on the current exchange rate, 1 USD is equivalent to 1.3704 CAD. Therefore, 100 USD would be 137.04 CAD.\n"}]}],"contextId":"2d66f277-152c-46ef-881d-7fe32866e9f5","history":[{"contextId":"2d66f277-152c-46ef-881d-7fe32866e9f5","kind":"message","messageId":"59819269f7d04849b0bfca7d43ec073c","parts":[{"kind":"text","text":"how much is 100 USD in CAD?"}],"role":"user","taskId":"52ae2392-84f5-429a-a14b-8413d3d20d97"},{"contextId":"2d66f277-152c-46ef-881d-7fe32866e9f5","kind":"message","messageId":"286095c6-12c9-40cb-9596-a9676d570dbd","parts":[],"role":"agent","taskId":"52ae2392-84f5-429a-a14b-8413d3d20d97"}],"id":"52ae2392-84f5-429a-a14b-8413d3d20d97","kind":"task","status":{"state":"completed"}}}

// ...

--- 🚀 First turn completed, no further input required for this test case. ---

এটা কাজ করে! আপনি সফলভাবে পরীক্ষা করেছেন যে আপনি একটি A2A সার্ভারের মাধ্যমে মুদ্রা এজেন্টের সাথে যোগাযোগ করতে পারেন! 🎉

আরও উন্নত ব্যবহারের ক্ষেত্রে দেখতে GitHub-এ a2a-নমুনা সংগ্রহস্থল দেখুন!

আপনার এজেন্ট স্থাপন করতে খুঁজছেন? Vertex AI এজেন্ট ইঞ্জিন উৎপাদনে AI এজেন্টদের মোতায়েন করার জন্য একটি পরিচালিত অভিজ্ঞতা প্রদান করে!

9. অভিনন্দন

অভিনন্দন! আপনি সফলভাবে একটি দূরবর্তী এমসিপি সার্ভার তৈরি এবং স্থাপন করেছেন, এজেন্ট ডেভেলপমেন্ট কিট (ADK) ব্যবহার করে একটি মুদ্রা এজেন্ট তৈরি করেছেন যা MCP ব্যবহার করে সরঞ্জামগুলির সাথে সংযোগ স্থাপন করে এবং Agent2Agent (A2A) প্রোটোকল ব্যবহার করে আপনার এজেন্টকে প্রকাশ করেছেন! মুদ্রা এজেন্ট এখন A2A ব্যবহার করে যেকোন ফ্রেমওয়ার্কের অন্যান্য এজেন্টদের সাথে যোগাযোগ করতে উপলব্ধ!

এখানে সম্পূর্ণ কোড ডকুমেন্টেশন একটি লিঙ্ক আছে.

আমরা কভার করেছি কি

  • কিভাবে একটি স্থানীয় MCP সার্ভার তৈরি করবেন
  • ক্লাউড রানে MCP সার্ভার স্থাপন করা হচ্ছে
  • এমসিপি টুল ব্যবহার করে এজেন্ট ডেভেলপমেন্ট কিট দিয়ে কীভাবে এজেন্ট তৈরি করবেন
  • একটি A2A সার্ভার হিসাবে একটি ADK এজেন্টকে কীভাবে প্রকাশ করবেন
  • A2A ক্লায়েন্ট ব্যবহার করে A2A সার্ভার পরীক্ষা করা হচ্ছে

পরিষ্কার করুন

এই ল্যাবে ব্যবহৃত সংস্থানগুলির জন্য আপনার Google ক্লাউড অ্যাকাউন্টে চার্জ এড়াতে, এই পদক্ষেপগুলি অনুসরণ করুন:

  1. Google ক্লাউড কনসোলে, সম্পদ পরিচালনা পৃষ্ঠাতে যান।
  2. প্রকল্প তালিকায়, আপনি যে প্রকল্পটি মুছতে চান সেটি নির্বাচন করুন এবং তারপরে মুছুন ক্লিক করুন।
  3. ডায়ালগে, প্রজেক্ট আইডি টাইপ করুন এবং তারপরে প্রোজেক্ট মুছে ফেলতে শাট ডাউন ক্লিক করুন।