必看!MCP 實現原理,小白也能懂

不知道大家有沒有發(fā)現?對于添加到 MCP 服務市場的成千上萬個 MCP 服務(而且這個數字每天還在增加),我們可以不寫一行代碼,輕松實現調用,但背后的原因究竟是啥呢?

MCP 雖然用起來很方便,但搞不懂背后的實現原理,總感覺這個知識點還沒完全掌握,所以接下來,我們一起來看它的實現原理。
從某個 MCP 的調用說起
在調用某個 MCP 服務的時候,只需要在 json 配置文件中添加一段 MCP 服務廠商提供的 json 信息就可以實現服務調用了。
例如要調用百度地圖提供的 8 大核心功能:地理編碼、逆地理編碼、地點檢索、路線規(guī)劃、天氣查詢、IP 定位等功能時,我們只需要添加以下 json 就能輕松調用了:
{
"mcpServers": {
"baidu-map": {
"command": "npx",
"args": [
"-y",
"@baidumap/mcp-server-baidu-map"
],
"env": {
"BAIDU_MAP_API_KEY": "xxx"
}
}
}
}執(zhí)行結果如下:

要搞明白調用的實現原理,我們需要先從 json 配置文件說起,以上配置文件是 nodejs 的調用命令,其中“npx”是 “npm execute package” 的縮寫,它的主要功能是運行一個包中的可執(zhí)行文件,而無需先將其全局安裝或添加到項目的依賴中,此時我們使用傳統(tǒng)的 npm 使用方式,將百度提供的依賴下載到本地:

源碼分析
我們查看其源碼就可以發(fā)現:

其主要文件 dist/index.js 的核心源碼如下:
// 啟動一個 stdio 服務器
async function runServer() {
const transport = new StdioServerTransport();
await server.connect(transport);
console.error("Baidu Map MCP Server running on stdio");
}
// 查詢天氣的工具實現
async function handleWeather(districtId, location) {
const url = new URL("https://api.map.baidu.com/weather/v1/");
url.searchParams.append("data_type", "all");
url.searchParams.append("coordtype", "bd09ll");
url.searchParams.append("ak", BAIDU_MAP_API_KEY);
url.searchParams.append("from", "node_mcp");
if (location) {
url.searchParams.append("location", location);
}
if (districtId) {
url.searchParams.append("district_id", districtId);
}
const response = await fetch(url.toString());
const data = await response.json();
if (data.status !== 0) {
return {
content: [{
type: "text",
text: `Weather searth failed: ${data.message || data.status}`
}],
isError: true
};
}
return {
content: [{
type: "text",
text: JSON.stringify({
location: data.result.location,
now: data.result.now,
forecasts: data.result.forecasts,
forecast_hours: data.result.forecast_hours,
indexes: data.result.indexes,
alerts: data.result.alerts,
}, null, 2)
}],
isError: false
};
}從以上源碼我們可以大致看出,百度作為 MCP 服務提供商,幫我們做了以下這些事:
- 啟動 stdio 服務端,等待 MCP 客戶端連接。
- 當檢測到客戶端的通訊請求之后,它通過 HTTP 協(xié)議請求自己服務器的信息,再將返回結果以 stdio 方式發(fā)送給 MCP 客戶端。
到這里,我們就搞明白了,之所以 MCP 使用比較簡單,原因是每家 MCP 服務廠商,幫我們實現了服務的具體調用。
并且他們遵循了 MCP 通訊協(xié)議,因此我們只需要使用 MCP Client 簡單調用就可以實現某個功能了,它的具體執(zhí)行流程如下:

小結
MCP 只使用調用簡單是每家 MCP 廠商幫我們實現了服務調用的細節(jié),并且遵循了 MCP 協(xié)議,開啟了 stdio 本地線程通訊的服務,讓我們可以輕松的通過 MCP 客戶端進行調用了。所以,你能自己實現一個 MCP 帶 UI 的客戶端嗎?
































