(এই পাঠের ভিডিও দেখতে উপরের ছবিটি ক্লিক করুন)
এই পাঠটি MCP কমিউনিটির সাথে কীভাবে যুক্ত হওয়া যায়, MCP ইকোসিস্টেমে কিভাবে অবদান রাখা যায়, এবং সহযোগিতামূলক উন্নয়নের জন্য সেরা অনুশীলনগুলি অনুসরণ করার উপর কেন্দ্রীভূত। ওপেন সোর্স MCP প্রকল্পগুলিতে অংশগ্রহণের পদ্ধতি বোঝা যারা এই প্রযুক্তির ভবিষ্যত আকৃতির জন্য আগ্রহী তাদের জন্য অপরিহার্য।
এই পাঠ শেষ করার পর, আপনি সক্ষম হবেন:
- MCP কমিউনিটি এবং ইকোসিস্টেমের গঠন বুঝতে
- MCP কমিউনিটি ফোরাম এবং আলোচনাগুলোতে কার্যকরভাবে অংশগ্রহণ করতে
- MCP ওপেন-সোর্স রেপোজিটোরিগুলিতে অবদান রাখতে
- কাস্টম MCP টুলস এবং সার্ভার তৈরি ও শেয়ার করতে
- MCP উন্নয়ন এবং সহযোগিতার সেরা অনুশীলন অনুসরণ করতে
- MCP উন্নয়নের জন্য কমিউনিটি রিসোর্স এবং ফ্রেমওয়ার্ক আবিষ্কার করতে
MCP ইকোসিস্টেম বিভিন্ন উপাদান এবং অংশগ্রহণকারীদের নিয়ে গঠিত, যারা একসাথে প্রোটোকল উন্নত করে।
- কোর প্রোটোকল রক্ষণা করে যারা: অফিসিয়াল Model Context Protocol GitHub organization MCP এর মূল স্পেসিফিকেশন এবং রেফারেন্স ইমপ্লিমেন্টেশন রক্ষণাবেক্ষণ করে
- টুল ডেভেলপারস: ব্যক্তিগত ও দল যারা MCP টুলস এবং সার্ভার তৈরি করে
- ইন্টিগ্রেশন প্রদানকারী: যারা MCP তাদের পণ্য এবং পরিষেবায় সংযুক্ত করে
- এন্ড ইউজার: ডেভেলপার এবং প্রতিষ্ঠান যারা MCP ব্যবহার করে তাদের অ্যাপ্লিকেশনগুলোতে
- অবদানকারীরা: কমিউনিটির সদস্যরা যারা কোড, ডকুমেন্টেশন বা অন্যান্য রিসোর্সে অবদান রাখে
- MCP GitHub Organization
- MCP ডকুমেন্টেশন
- MCP স্পেসিফিকেশন
- GitHub Discussions
- MCP উদাহরণ ও সার্ভার রেপোজিটরি
- MCP ক্লায়েন্টস - MCP ইন্টিগ্রেশন সাপোর্ট করা ক্লায়েন্টদের তালিকা
- কমিউনিটি MCP সার্ভারস - কমিউনিটি-উন্নত MCP সার্ভারের বর্ধমান তালিকা
- অসাধারণ MCP সার্ভারস - নির্বাচিত MCP সার্ভারের তালিকা
- PulseMCP - MCP রিসোর্স আবিষ্কারের জন্য কমিউনিটি হাব ও নিউজলেটার
- ডিসকর্ড সার্ভার - MCP ডেভেলপারদের সাথে সংযোগ
- ভাষা-নির্দিষ্ট SDK সম্পাদনাগুলি
- ব্লগ পোস্ট এবং টিউটোরিয়াল
MCP ইকোসিস্টেম বিভিন্ন ধরনের অবদানের স্বাগত জানায়:
-
কোড অবদান:
- কোর প্রোটোকল উন্নয়ন
- বাগ ফিক্স
- টুল এবং সার্ভার ইমপ্লিমেন্টেশন
- বিভিন্ন ভাষায় ক্লায়েন্ট/সার্ভার লাইব্রেরি
-
ডকুমেন্টেশন:
- বিদ্যমান ডকুমেন্টেশন উন্নত করা
- টিউটোরিয়াল এবং গাইড তৈরি করা
- ডকুমেন্টেশন অনুবাদ করা
- উদাহরণ এবং নমুনা অ্যাপ্লিকেশন তৈরি করা
-
কমিউনিটি সাপোর্ট:
- ফোরাম এবং আলোচনায় প্রশ্নের উত্তর দেওয়া
- টেস্টিং এবং সমস্যা রিপোর্ট করা
- কমিউনিটি ইভেন্ট সংগঠিত করা
- নতুন অবদানকারীদের মেন্টরিং করা
কোর MCP প্রোটোকল বা অফিসিয়াল ইমপ্লিমেন্টেশনে অবদান রাখতে, অফিসিয়াল অবদান নির্দেশিকা থেকে এই নীতিগুলো অনুসরণ করুন:
-
সহজতা এবং সামান্যবাদ: MCP স্পেসিফিকেশন নতুন ধারণা যোগ করার জন্য উচ্চ মান বজায় রাখে। স্পেসিফিকেশন থেকে কিছু বাদ দেয়া সহজের থেকে নতুন যোগ করা সহজ।
-
কংক্রিট পদ্ধতি: স্পেসিফিকেশন পরিবর্তনগুলি নির্দিষ্ট বাস্তবায়ন চ্যালেঞ্জের উপর ভিত্তি করে হওয়া উচিত, কল্পনাশীল ধারণার উপর নয়।
-
প্রস্তাবনার ধাপসমূহ:
- সংজ্ঞায়িত: সমস্যা ক্ষেত্র অন্বেষণ করুন, যাচাই করুন অন্য MCP ব্যবহারকারীরাও একই সমস্যা সম্মুখীন হয় কিনা
- প্রোটোটাইপ: একটি উদাহরণ সমাধান তৈরি করুন এবং এর ব্যবহারিক প্রয়োগ প্রদর্শন করুন
- লিখুন: প্রোটোটাইপের উপর ভিত্তি করে একটি স্পেসিফিকেশন প্রস্তাবনা লিখুন
# রিপোজিটরি ফর্ক করুন
git clone https://github.com/YOUR-USERNAME/modelcontextprotocol.git
cd modelcontextprotocol
# নির্ভরতাগুলি ইনস্টল করুন
npm install
# স্কিমা পরিবর্তনের জন্য, স্কিমা যাচাই করুন এবং schema.json তৈরি করুন:
npm run check:schema:ts
npm run generate:schema
# ডকুমেন্টেশন পরিবর্তনের জন্য
npm run check:docs
npm run format
# ডকুমেন্টেশন স্থানীয়ভাবে প্রিভিউ করুন (ঐচ্ছিক):
npm run serve:docs// টাইপস্ক্রিপ্ট-এসডিকে-তে বাগ সহ মূল কোড
export function validateResource(resource: unknown): resource is MCPResource {
if (!resource || typeof resource !== 'object') {
return false;
}
// বাগ: বৈশিষ্ট্য যাচাই উপলব্ধ নেই
// বর্তমান বাস্তবায়ন:
const hasName = 'name' in resource;
const hasSchema = 'schema' in resource;
return hasName && hasSchema;
}
// একটি অবদানে স্থির বাস্তবায়ন
export function validateResource(resource: unknown): resource is MCPResource {
if (!resource || typeof resource !== 'object') {
return false;
}
// উন্নত যাচাই
const hasName = 'name' in resource && typeof (resource as MCPResource).name === 'string';
const hasSchema = 'schema' in resource && typeof (resource as MCPResource).schema === 'object';
const hasDescription = !('description' in resource) || typeof (resource as MCPResource).description === 'string';
return hasName && hasSchema && hasDescription;
}# উদাহরণ অবদান: MCP স্ট্যান্ডার্ড লাইব্রেরির জন্য একটি CSV ডেটা প্রক্রিয়াকরণ টুল
from mcp_tools import Tool, ToolRequest, ToolResponse, ToolExecutionException
import pandas as pd
import io
import json
from typing import Dict, Any, List, Optional
class CsvProcessingTool(Tool):
"""
Tool for processing and analyzing CSV data.
This tool allows models to extract information from CSV files,
run basic analysis, and convert data between formats.
"""
def get_name(self):
return "csvProcessor"
def get_description(self):
return "Processes and analyzes CSV data"
def get_schema(self):
return {
"type": "object",
"properties": {
"csvData": {
"type": "string",
"description": "CSV data as a string"
},
"csvUrl": {
"type": "string",
"description": "URL to a CSV file (alternative to csvData)"
},
"operation": {
"type": "string",
"enum": ["summary", "filter", "transform", "convert"],
"description": "Operation to perform on the CSV data"
},
"filterColumn": {
"type": "string",
"description": "Column to filter by (for filter operation)"
},
"filterValue": {
"type": "string",
"description": "Value to filter for (for filter operation)"
},
"outputFormat": {
"type": "string",
"enum": ["json", "csv", "markdown"],
"default": "json",
"description": "Output format for the processed data"
}
},
"oneOf": [
{"required": ["csvData", "operation"]},
{"required": ["csvUrl", "operation"]}
]
}
async def execute_async(self, request: ToolRequest) -> ToolResponse:
try:
# প্যারামিটার বের করা
operation = request.parameters.get("operation")
output_format = request.parameters.get("outputFormat", "json")
# সরাসরি ডেটা বা URL থেকে CSV ডেটা পান
df = await self._get_dataframe(request)
# অনুরোধকৃত অপারেশনের ভিত্তিতে প্রক্রিয়াজাত করুন
result = {}
if operation == "summary":
result = self._generate_summary(df)
elif operation == "filter":
column = request.parameters.get("filterColumn")
value = request.parameters.get("filterValue")
if not column:
raise ToolExecutionException("filterColumn is required for filter operation")
result = self._filter_data(df, column, value)
elif operation == "transform":
result = self._transform_data(df, request.parameters)
elif operation == "convert":
result = self._convert_format(df, output_format)
else:
raise ToolExecutionException(f"Unknown operation: {operation}")
return ToolResponse(result=result)
except Exception as e:
raise ToolExecutionException(f"CSV processing failed: {str(e)}")
async def _get_dataframe(self, request: ToolRequest) -> pd.DataFrame:
"""Gets a pandas DataFrame from either CSV data or URL"""
if "csvData" in request.parameters:
csv_data = request.parameters.get("csvData")
return pd.read_csv(io.StringIO(csv_data))
elif "csvUrl" in request.parameters:
csv_url = request.parameters.get("csvUrl")
return pd.read_csv(csv_url)
else:
raise ToolExecutionException("Either csvData or csvUrl must be provided")
def _generate_summary(self, df: pd.DataFrame) -> Dict[str, Any]:
"""Generates a summary of the CSV data"""
return {
"columns": df.columns.tolist(),
"rowCount": len(df),
"columnCount": len(df.columns),
"numericColumns": df.select_dtypes(include=['number']).columns.tolist(),
"categoricalColumns": df.select_dtypes(include=['object']).columns.tolist(),
"sampleRows": json.loads(df.head(5).to_json(orient="records")),
"statistics": json.loads(df.describe().to_json())
}
def _filter_data(self, df: pd.DataFrame, column: str, value: str) -> Dict[str, Any]:
"""Filters the DataFrame by a column value"""
if column not in df.columns:
raise ToolExecutionException(f"Column '{column}' not found")
filtered_df = df[df[column].astype(str).str.contains(value)]
return {
"originalRowCount": len(df),
"filteredRowCount": len(filtered_df),
"data": json.loads(filtered_df.to_json(orient="records"))
}
def _transform_data(self, df: pd.DataFrame, params: Dict[str, Any]) -> Dict[str, Any]:
"""Transforms the data based on parameters"""
# বাস্তবায়নে বিভিন্ন রূপান্তর অন্তর্ভুক্ত থাকবে
return {
"status": "success",
"message": "Transformation applied"
}
def _convert_format(self, df: pd.DataFrame, format: str) -> Dict[str, Any]:
"""Converts the DataFrame to different formats"""
if format == "json":
return {
"data": json.loads(df.to_json(orient="records")),
"format": "json"
}
elif format == "csv":
return {
"data": df.to_csv(index=False),
"format": "csv"
}
elif format == "markdown":
return {
"data": df.to_markdown(),
"format": "markdown"
}
else:
raise ToolExecutionException(f"Unsupported output format: {format}")MCP প্রকল্পে সফল অবদান রাখতে:
- ছোট থেকে শুরু করুন: ডকুমেন্টেশন, বাগ ফিক্স, অথবা ছোট উন্নতি দিয়ে শুরু করুন
- স্টাইল গাইড অনুসরণ করুন: প্রকল্পের কোডিং স্টাইল এবং নিয়ম অনুসরণ করুন
- টেস্ট লিখুন: আপনার কোড অবদানের জন্য ইউনিট টেস্ট অন্তর্ভুক্ত করুন
- কাজ ডকুমেন্ট করুন: নতুন বৈশিষ্ট্য বা পরিবর্তনের জন্য সুস্পষ্ট ডকুমেন্টেশন যোগ করুন
- লক্ষ্যভিত্তিক PR জমা দিন: পুল রিকোয়েস্ট একক সমস্যা বা বৈশিষ্ট্যের উপর কেন্দ্রীভূত রাখুন
- ফিডব্যাকের সাথে যুক্ত থাকুন: আপনার অবদানের ফিডব্যাকে প্রতিক্রিয়াশীল হোন
# রিপোজিটরি ক্লোন করুন
git clone https://github.com/modelcontextprotocol/typescript-sdk.git
cd typescript-sdk
# আপনার অবদানের জন্য একটি নতুন শাখা তৈরি করুন
git checkout -b feature/my-contribution
# আপনার পরিবর্তনগুলি করুন
# ...
# পরীক্ষা চালান যাতে আপনার পরিবর্তনগুলি বিদ্যমান কার্যকারিতা নষ্ট না করে
npm test
# একটি বর্ণনামূলক বার্তার সাথে আপনার পরিবর্তনগুলি কমিট করুন
git commit -am "Fix validation in resource handler"
# আপনার শাখাটি আপনার ফর্কে পুশ করুন
git push origin feature/my-contribution
# আপনার শাখা থেকে মূল রিপোজিটরিতে একটি পুল রিকোয়েস্ট তৈরি করুন
# তারপর প্রতিক্রিয়ার সাথে যুক্ত হন এবং আপনার পিআর প্রয়োজন অনুযায়ী পুনরাবৃত্তি করুনMCP ইকোসিস্টেমে অবদান রাখার সবচেয়ে মূল্যবান উপায়গুলোর মধ্যে একটি হলো কাস্টম MCP সার্ভার তৈরি এবং শেয়ার করা। কমিউনিটি ইতোমধ্যেই বিভিন্ন পরিষেবা এবং ব্যবহারের জন্য শত শত সার্ভার তৈরি করেছে।
কিছু ফ্রেমওয়ার্ক উপলব্ধ যা MCP সার্ভার উন্নয়নকে সহজ করে তোলে:
-
অফিসিয়াল SDKs (MCP স্পেসিফিকেশন 2025-11-25 অনুযায়ী):
-
কমিউনিটি ফ্রেমওয়ার্কস:
- MCP-Framework - টাইপস্ক্রিপ্টে MCP সার্ভারগুলি বিএলে ও দ্রুত তৈরি করুন
- MCP Declarative Java SDK - অ্যানোটেশন-চালিত MCP সার্ভার জাভা ব্যবহার করে
- Quarkus MCP Server SDK - MCP সার্ভারের জন্য জাভা ফ্রেমওয়ার্ক
- Next.js MCP Server Template - MCP সার্ভারের জন্য স্টার্টার Next.js প্রকল্প
// Create a new .NET library project
// dotnet new classlib -n McpFinanceTools
using Microsoft.Mcp.Tools;
using System.Threading.Tasks;
using System.Net.Http;
using System.Text.Json;
namespace McpFinanceTools
{
// Stock quote tool
public class StockQuoteTool : IMcpTool
{
private readonly HttpClient _httpClient;
public StockQuoteTool(HttpClient httpClient = null)
{
_httpClient = httpClient ?? new HttpClient();
}
public string Name => "stockQuote";
public string Description => "Gets current stock quotes for specified symbols";
public object GetSchema()
{
return new {
type = "object",
properties = new {
symbol = new {
type = "string",
description = "Stock symbol (e.g., MSFT, AAPL)"
},
includeHistory = new {
type = "boolean",
description = "Whether to include historical data",
default = false
}
},
required = new[] { "symbol" }
};
}
public async Task<ToolResponse> ExecuteAsync(ToolRequest request)
{
// Extract parameters
string symbol = request.Parameters.GetProperty("symbol").GetString();
bool includeHistory = false;
if (request.Parameters.TryGetProperty("includeHistory", out var historyProp))
{
includeHistory = historyProp.GetBoolean();
}
// Call external API (example)
var quoteResult = await GetStockQuoteAsync(symbol);
// Add historical data if requested
if (includeHistory)
{
var historyData = await GetStockHistoryAsync(symbol);
quoteResult.Add("history", historyData);
}
// Return formatted result
return new ToolResponse {
Result = JsonSerializer.SerializeToElement(quoteResult)
};
}
private async Task<Dictionary<string, object>> GetStockQuoteAsync(string symbol)
{
// Implementation would call a real stock API
// This is a simplified example
return new Dictionary<string, object>
{
["symbol"] = symbol,
["price"] = 123.45,
["change"] = 2.5,
["percentChange"] = 1.2,
["lastUpdated"] = DateTime.UtcNow
};
}
private async Task<object> GetStockHistoryAsync(string symbol)
{
// Implementation would get historical data
// Simplified example
return new[]
{
new { date = DateTime.Now.AddDays(-7).Date, price = 120.25 },
new { date = DateTime.Now.AddDays(-6).Date, price = 122.50 },
new { date = DateTime.Now.AddDays(-5).Date, price = 121.75 }
// More historical data...
};
}
}
}
// Create package and publish to NuGet
// dotnet pack -c Release
// dotnet nuget push bin/Release/McpFinanceTools.1.0.0.nupkg -s https://api.nuget.org/v3/index.json -k YOUR_API_KEY// একটি শেয়ারযোগ্য MCP টুল প্যাকেজের জন্য pom.xml কনফিগারেশন
<!--
<project>
<groupId>com.example</groupId>
<artifactId>mcp-weather-tools</artifactId>
<version>1.0.0</version>
<dependencies>
<dependency>
<groupId>com.mcp</groupId>
<artifactId>mcp-server</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
<distributionManagement>
<repository>
<id>github</id>
<name>GitHub Packages</name>
<url>https://maven.pkg.github.com/username/mcp-weather-tools</url>
</repository>
</distributionManagement>
</project>
-->
package com.example.mcp.weather;
import com.mcp.tools.Tool;
import com.mcp.tools.ToolRequest;
import com.mcp.tools.ToolResponse;
import com.mcp.tools.ToolExecutionException;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.net.URI;
import java.util.HashMap;
import java.util.Map;
public class WeatherForecastTool implements Tool {
private final HttpClient httpClient;
private final String apiKey;
public WeatherForecastTool(String apiKey) {
this.httpClient = HttpClient.newHttpClient();
this.apiKey = apiKey;
}
@Override
public String getName() {
return "weatherForecast";
}
@Override
public String getDescription() {
return "Gets weather forecast for a specified location";
}
@Override
public Object getSchema() {
Map<String, Object> schema = new HashMap<>();
// স্কিমা সংজ্ঞা...
return schema;
}
@Override
public ToolResponse execute(ToolRequest request) {
try {
String location = request.getParameters().get("location").asText();
int days = request.getParameters().has("days") ?
request.getParameters().get("days").asInt() : 3;
// আবহাওয়া API কল করুন
Map<String, Object> forecast = getForecast(location, days);
// উত্তর তৈরি করুন
return new ToolResponse.Builder()
.setResult(forecast)
.build();
} catch (Exception ex) {
throw new ToolExecutionException("Weather forecast failed: " + ex.getMessage(), ex);
}
}
private Map<String, Object> getForecast(String location, int days) {
// বাস্তবায়ন আবহাওয়া API কল করবে
// সরলীকৃত উদাহরণ
Map<String, Object> result = new HashMap<>();
// পূর্বাভাস তথ্য যুক্ত করুন...
return result;
}
}
// Maven ব্যবহার করে তৈরি এবং প্রকাশ করুন
// mvn clean package
// mvn deploy# PyPI প্যাকেজের ডিরেক্টরি কাঠামো:
# mcp_nlp_tools/
# ├── LICENSE
# ├── README.md
# ├── setup.py
# ├── mcp_nlp_tools/
# │ ├── __init__.py
# │ ├── sentiment_tool.py
# │ └── translation_tool.py
# উদাহরণ setup.py
"""
from setuptools import setup, find_packages
setup(
name="mcp_nlp_tools",
version="0.1.0",
packages=find_packages(),
install_requires=[
"mcp_server>=1.0.0",
"transformers>=4.0.0",
"torch>=1.8.0"
],
author="Your Name",
author_email="your.email@example.com",
description="MCP tools for natural language processing tasks",
long_description=open("README.md").read(),
long_description_content_type="text/markdown",
url="https://github.com/username/mcp_nlp_tools",
classifiers=[
"Programming Language :: Python :: 3",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
],
python_requires=">=3.8",
)
"""
# উদাহরণ NLP টুল বাস্তবায়ন (sentiment_tool.py)
from mcp_tools import Tool, ToolRequest, ToolResponse, ToolExecutionException
from transformers import pipeline
import torch
class SentimentAnalysisTool(Tool):
"""MCP tool for sentiment analysis of text"""
def __init__(self, model_name="distilbert-base-uncased-finetuned-sst-2-english"):
# সেন্টিমেন্ট বিশ্লেষণ মডেল লোড করুন
self.sentiment_analyzer = pipeline("sentiment-analysis", model=model_name)
def get_name(self):
return "sentimentAnalysis"
def get_description(self):
return "Analyzes the sentiment of text, classifying it as positive or negative"
def get_schema(self):
return {
"type": "object",
"properties": {
"text": {
"type": "string",
"description": "The text to analyze for sentiment"
},
"includeScore": {
"type": "boolean",
"description": "Whether to include confidence scores",
"default": True
}
},
"required": ["text"]
}
async def execute_async(self, request: ToolRequest) -> ToolResponse:
try:
# প্যারামিটারগুলি বের করুন
text = request.parameters.get("text")
include_score = request.parameters.get("includeScore", True)
# সেন্টিমেন্ট বিশ্লেষণ করুন
sentiment_result = self.sentiment_analyzer(text)[0]
# ফলাফল ফরম্যাট করুন
result = {
"sentiment": sentiment_result["label"],
"text": text
}
if include_score:
result["score"] = sentiment_result["score"]
# ফলাফল ফেরত দিন
return ToolResponse(result=result)
except Exception as e:
raise ToolExecutionException(f"Sentiment analysis failed: {str(e)}")
# প্রকাশ করার জন্য:
# python setup.py sdist bdist_wheel
# python -m twine upload dist/*যখন কমিউনিটির সাথে MCP টুলস শেয়ার করবেন:
-
সম্পূর্ণ ডকুমেন্টেশন:
- উদ্দেশ্য, ব্যবহার, এবং উদাহরণ ডকুমেন্ট করুন
- প্যারামিটার এবং রিটার্ন মান ব্যাখ্যা করুন
- কোন বাহ্যিক নির্ভরতাগুলো আছে ডকুমেন্ট করুন
-
ত্রুটি পরিচালনা:
- দৃঢ় ত্রুটি পরিচালনা বাস্তবায়ন করুন
- উপকারী ত্রুটি বার্তা দিন
- প্রান্তিক পরিস্থিতিসমূহ সুন্দরভাবে হ্যান্ডেল করুন
-
পারফরমেন্স বিবেচনা:
- গতি এবং রিসোর্স ব্যবহারের জন্য অপ্টিমাইজ করুন
- প্রয়োজনে ক্যাশিং ব্যবহার করুন
- স্কেলেবিলিটি বিবেচনা করুন
-
সিকিউরিটি:
- নিরাপদ API কী এবং প্রমাণীকরণ ব্যবহার করুন
- ইনপুট যাচাই ও স্যানিটাইজ করুন
- বাহ্যিক API কলের জন্য রেট লিমিটেশন বাস্তবায়ন করুন
-
টেস্টিং:
- বিস্তৃত টেস্ট কভারেজ অন্তর্ভুক্ত করুন
- বিভিন্ন ইনপুট টাইপ এবং প্রান্তিক কেসে পরীক্ষা করুন
- টেস্ট প্রক্রিয়া ডকুমেন্ট করুন
কার্যকর সহযোগিতা একটি সফল MCP ইকোসিস্টেমের চাবিকাঠি।
- GitHub Issues এবং Discussions
- Microsoft Tech Community
- Discord এবং Slack চ্যানেলসমূহ
- Stack Overflow (ট্যাগ:
model-context-protocolবাmcp)
MCP অবদান পর্যালোচনার সময়:
- স্পষ্টতা: কোডটি কি স্পষ্ট এবং ভাল ডকুমেন্টেড?
- সঠিকতা: এটি প্রত্যাশা অনুযায়ী কাজ করে কি?
- সঙ্গতি: প্রকল্পের নিয়ম অনুসরণ করে কি?
- সম্পূর্ণতা: টেস্ট এবং ডকুমেন্টেশন অন্তর্ভুক্ত আছে কি?
- নিরাপত্তা: কোনো নিরাপত্তা উদ্বেগ আছে কি?
MCP এর জন্য উন্নয়ন করার সময়:
- প্রোটোকল ভার্সনিং: আপনার টুল যে MCP প্রোটোকল ভার্সন সাপোর্ট করে তা মেনে চলুন
- ক্লায়েন্ট সামঞ্জস্য: পিছনে সামঞ্জস্য বিবেচনা করুন
- সার্ভার সামঞ্জস্য: সার্ভার ইমপ্লিমেন্টেশনের নির্দেশিকা অনুসরণ করুন
- ব্রেকিং চেঞ্জ: কোনো ব্রেকিং পরিবর্তন স্পষ্টভাবে ডকুমেন্ট করুন
একটি গুরুত্বপূর্ণ কমিউনিটি অবদান হতে পারে MCP টুলসের জন্য একটি পাবলিক রেজিস্ট্রি উন্নয়ন।
# একটি কমিউনিটি টুল রেজিস্ট্রি API-এর উদাহরণ স্কিমা
from fastapi import FastAPI, HTTPException, Depends
from pydantic import BaseModel, Field, HttpUrl
from typing import List, Optional
import datetime
import uuid
# টুল রেজিস্ট্রির মডেলসমূহ
class ToolSchema(BaseModel):
"""JSON Schema for a tool"""
type: str
properties: dict
required: List[str] = []
class ToolRegistration(BaseModel):
"""Information for registering a tool"""
name: str = Field(..., description="Unique name for the tool")
description: str = Field(..., description="Description of what the tool does")
version: str = Field(..., description="Semantic version of the tool")
schema: ToolSchema = Field(..., description="JSON Schema for tool parameters")
author: str = Field(..., description="Author of the tool")
repository: Optional[HttpUrl] = Field(None, description="Repository URL")
documentation: Optional[HttpUrl] = Field(None, description="Documentation URL")
package: Optional[HttpUrl] = Field(None, description="Package URL")
tags: List[str] = Field(default_factory=list, description="Tags for categorization")
examples: List[dict] = Field(default_factory=list, description="Example usage")
class Tool(ToolRegistration):
"""Tool with registry metadata"""
id: uuid.UUID = Field(default_factory=uuid.uuid4)
created_at: datetime.datetime = Field(default_factory=datetime.datetime.now)
updated_at: datetime.datetime = Field(default_factory=datetime.datetime.now)
downloads: int = Field(default=0)
rating: float = Field(default=0.0)
ratings_count: int = Field(default=0)
# রেজিস্ট্রির জন্য FastAPI অ্যাপ্লিকেশন
app = FastAPI(title="MCP Tool Registry")
# এই উদাহরণের জন্য ইন-মেমরি ডেটাবেস
tools_db = {}
@app.post("/tools", response_model=Tool)
async def register_tool(tool: ToolRegistration):
"""Register a new tool in the registry"""
if tool.name in tools_db:
raise HTTPException(status_code=400, detail=f"Tool '{tool.name}' already exists")
new_tool = Tool(**tool.dict())
tools_db[tool.name] = new_tool
return new_tool
@app.get("/tools", response_model=List[Tool])
async def list_tools(tag: Optional[str] = None):
"""List all registered tools, optionally filtered by tag"""
if tag:
return [tool for tool in tools_db.values() if tag in tool.tags]
return list(tools_db.values())
@app.get("/tools/{tool_name}", response_model=Tool)
async def get_tool(tool_name: str):
"""Get information about a specific tool"""
if tool_name not in tools_db:
raise HTTPException(status_code=404, detail=f"Tool '{tool_name}' not found")
return tools_db[tool_name]
@app.delete("/tools/{tool_name}")
async def delete_tool(tool_name: str):
"""Delete a tool from the registry"""
if tool_name not in tools_db:
raise HTTPException(status_code=404, detail=f"Tool '{tool_name}' not found")
del tools_db[tool_name]
return {"message": f"Tool '{tool_name}' deleted"}- MCP কমিউনিটি বৈচিত্র্যময় এবং বিভিন্ন ধরনের অবদানের স্বাগত জানায়
- MCP তে অবদান রাখা কোর প্রোটোকল উন্নয়ন থেকে কাস্টম টুলস পর্যন্ত হতে পারে
- অবদান নির্দেশিকা অনুসরণ করলে আপনার পিআর গ্রহণের সম্ভাবনা বাড়ে
- MCP টুলস তৈরি এবং শেয়ার করা ইকোসিস্টেম উন্নত করার গুরুত্বপূর্ণ উপায়
- MCP এর বৃদ্ধির জন্য কমিউনিটি সহযোগিতা অপরিহার্য
- MCP ইকোসিস্টেমের এমন একটি এলাকায় চিহ্নিত করুন যেখানে আপনার দক্ষতা ও আগ্রহ অনুযায়ী অবদান রাখতে পারেন
- MCP রেপোসিটরি Fork করুন এবং একটি লোকাল ডেভেলপমেন্ট পরিবেশ সেটআপ করুন
- একটি ছোট উন্নতি, বাগ ফিক্স বা টুল তৈরি করুন যা কমিউনিটির উপকারে আসবে
- আপনার অবদান যথাযথ টেস্ট এবং ডকুমেন্টেশনের মাধ্যমে ডকুমেন্ট করুন
- সঠিক রেপোজিটরিতে একটি পুল রিকোয়েস্ট জমা দিন
পরবর্তী: প্রাথমিক গ্রহণ থেকে শিক্ষা
দায়িত্ব অস্বীকার:
এই নথিটি AI অনুবাদ সেবা Co-op Translator ব্যবহার করে অনূদিত হয়েছে। যদিও আমরা যথাযথতার জন্য চেষ্টা পাই, অনুগ্রহ করে মনে রাখবেন যে স্বয়ংক্রিয় অনুবাদগুলিতে ত্রুটি বা ভুল থাকতে পারে। মূল ভাষায় থাকা মূল নথিটিই বৈধ এবং কর্তৃপক্ষের উৎস হিসাবে বিবেচিত হওয়া উচিত। গুরুত্বপূর্ণ তথ্যের জন্য পেশাদার মানব অনুবাদের পরামর্শ দেওয়া হয়। এই অনুবাদের ব্যবহারে সৃষ্ট কোনও ভুল বোঝাবুঝি বা ভুল ব্যাখ্যার জন্য আমরা দায়ী নই।
