精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器 原創

發布于 2025-5-19 08:26
瀏覽
0收藏

你是否遇到過這樣的情況:你希望聊天機器人使用一個工具回答問題?雖然這聽起來有些復雜,但現在,MCP(模型上下文協議)提供外部工具中的方法,不僅讓LLM能夠輕松調用工具,還可以基于不同應用場景使用工具。本文將深入探討使用 FastAPI 完成Web 應用轉換過程,該應用程序由 MCP 服務器提供支持,使用 FastAPI-MCP。

FastAPI 與 MCP

FastAPI 是由Python提供的工具,幫助用戶構建API 應用從而協助完成Web 應用程序的開發。由于其使用方便、上手快,深受業內人士的歡迎。如果將 FastAPI 視為智能服務員,來接受你的訂單(HTTP 請求),前往廚房(數據庫/服務器),然后響應訂單(輸出),最后展示給你。FastAPI是構建 Web 后端、移動應用程序服務等的強大工具。

MCP 是 Anthropic 提供的一種使模型與外部數據源和工具通信的開放標準協議。這里我們將 MCP 視為特定任務提供的工具包,并使用 MCP 來創建響應的服務器,從而提供任務所需要的工具服務。

這些工具服務可以賦予LLM更廣泛的能力。這就是 FastAPI 與 MCP 集成的價值和意義。??FastAPI?? 負責處理不同來源的工具服務,而 MCP 負責處理 LLM 的上下文。通過使用 FastAPI 與 MCP 服務器,我們可以訪問部署在 Web 上的工具,并將其用作 LLM 工具,使 LLM 更有效地完成任務。

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

如上圖所示, MCP 服務器連接到API 端點。這個 API 端點可以是FastAPI 端點,也可以是互聯網上的第三方 API 服務。

FastAPI-MCP 是什么?

FastAPI-MCP 是一個工具,它可以將任何 FastAPI 應用程序轉換為像 ??ChatGPT?? 或 Claude的 LLM 工具,讓用戶可以輕松理解和使用。通過使用 FastAPI-MCP,可以將你的 FastAPI 端點包裝起來,成為LLM 的 AI 生態系統中即插即用的工具。?

什么 API 可以使用 FastAPI-MCP 轉換為 MCP?

使用 FastAPI-MCP,任何 FastAPI 端點都可以轉換為 LLMs 的 MCP 工具。這些端點應包括:

  • GET 端點:轉換為 MCP 資源。?
  • POST、PUT、DELETE 端點:轉換為 MCP 工具。?
  • 自定義實用功能:可作為額外的 MCP 工具添加。?

FastAPI-MCP會自動發現并將API端點轉換為 MCP。同時會保留API 的模式以及文檔。

使用 FastAPI-MCP 進行實際操作

讓我們看一個簡單的示例,演示如何將 FastAPI 端點轉換為 MCP 服務器。首先,我們將創建一個 FastAPI 端點,然后開始將其轉換為使用 fastapi-mcp 的 MCP 服務器。

配置 FastAPI

安裝依賴項。

通過安裝所需的依賴項使你的系統兼容。

pip install fastapi fastapi_mcp uvicorn mcp-proxy

導入所需的依賴項

創建一個名為 '??main.py??' 的新文件,然后在其中導入以下依賴項。

from fastapi import FastAPI, HTTPException, Query
import httpx
from fastapi_mcp import FastApiMCP

定義 FastAPI 應用程序

讓我們定義一個名為“Weather Updates API”的 FastAPI 應用程序。

app = FastAPI(title="Weather Updates API")

定義路由和函數

接著,為應用程序定義路由,也就是將端點與函數進行一一對應。這里,使用 ??weather.gov?? API(免費)制作天氣應用,不需要任何 API 密鑰。只需要使用正確的緯度和經度值訪問如下URL即可, ??https://api.weather.gov/points/{lat},{lon}??。?

于是,定義了get_weather 函數,它將以州名或代碼作為參數,然后在 CITY_COORDINATES 字典中找到相應的坐標,然后使用這些坐標訪問基本 URL。

# Predefined latitude and longitude for major cities (for simplicity)
# In a production app, you could use a geocoding service like Nominatim or Google Geocoding API
CITY_COORDINATES = {
   "Los Angeles": {"lat": 34.0522, "lon": -118.2437},
   "San Francisco": {"lat": 37.7749, "lon": -122.4194},
   "San Diego": {"lat": 32.7157, "lon": -117.1611},
   "New York": {"lat": 40.7128, "lon": -74.0060},
   "Chicago": {"lat": 41.8781, "lon": -87.6298},
   # Add more cities as needed
}


@app.get("/weather")
async def get_weather(
   stateCode: str = Query(..., description="State code (e.g., 'CA' for California)"),
   city: str = Query(..., description="City name (e.g., 'Los Angeles')")
):
   """
   Retrieve today's weather from the National Weather Service API based on city and state
   """
   # Get coordinates (latitude, longitude) for the given city
   if city not in CITY_COORDINATES:
       raise HTTPException(
           status_code=404,
           detail=f"City '{city}' not found in predefined list. Please use another city."
       )
  
   coordinates = CITY_COORDINATES[city]
   lat, lon = coordinates["lat"], coordinates["lon"]
  
   # URL for the NWS API Gridpoints endpoint
   base_url = f"https://api.weather.gov/points/{lat},{lon}"
  
   try:
       async with httpx.AsyncClient() as client:
           # First, get the gridpoint information for the given location
           gridpoint_response = await client.get(base_url)
           gridpoint_response.raise_for_status()
           gridpoint_data = gridpoint_response.json()
          
           # Retrieve the forecast data using the gridpoint information
           forecast_url = gridpoint_data["properties"]["forecast"]
           forecast_response = await client.get(forecast_url)
           forecast_response.raise_for_status()
           forecast_data = forecast_response.json()


           # Returning today's forecast
           today_weather = forecast_data["properties"]["periods"][0]
           return {
               "city": city,
               "state": stateCode,
               "date": today_weather["startTime"],
               "temperature": today_weather["temperature"],
               "temperatureUnit": today_weather["temperatureUnit"],
               "forecast": today_weather["detailedForecast"],
           }
  
   except httpx.HTTPStatusError as e:
       raise HTTPException(
           status_code=e.response.status_code,
           detail=f"NWS API error: {e.response.text}"
       )
   except Exception as e:
       raise HTTPException(
           status_code=500,
           detail=f"Internal server error: {str(e)}"
       )

設置 MCP 服務器

然后,讓我們使用 fastapi-mcp 庫將這個 FastAPI 應用程序轉換為 MCP。這個過程非常簡單,我們只需要添加幾行代碼,fastapi-mcp 就會自動將端點轉換為 MCP 工具,并輕松檢測其模式和文檔。

mcp = FastApiMCP(
   app,
   name="Weather Updates API",
   description="API for retrieving today's weather from weather.gov",
)
mcp.mount() 

啟動應用程序

在 ??Python?? 文件的末尾添加以下內容。

if __name__ == "__main__":
   import uvicorn
   uvicorn.run(app, host="0.0.0.0", port=8000)

然后,轉到終端并運行 ??main.py?? 文件。

python main.py 

現在,FastAPI 應用程序在本地主機上成功啟動。

配置Cursor

讓我們配置 Cursor IDE 測試MCP 服務器。

1. 從這里下載,鏈接:??https://www.cursor.com/downloads??。

2. 安裝Cursor,注冊并進入主屏幕

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

3. 現在轉到標題工具欄中的文件,然后點擊首選項 ,再點擊光標設置 。

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

4. 從光標設置中,單擊 MCP。

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

5. 在 MCP 選項卡上,單擊添加新全局 MCP 服務器 。它將打開一個 mcp.json 文件。將以下代碼粘貼到其中并保存文件。

{
   "mcpServers": {
     "National Park Service": {
         "command": "mcp-proxy",
         "args": ["http://127.0.0.1:8000/mcp"]
     }
   }
}

6. 在光標設置處,你應該看到以下內容:

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

如果你在屏幕上看到這個,這意味著你的服務器已成功運行并連接到 ??Cursor IDE??。如果顯示一些錯誤,請嘗試使用右上角的 重新啟動 按鈕。?

我們已成功在 Cursor IDE 中設置了 MCP 服務器?,F在,讓我們測試服務器。

測試 MCP 服務器

經過上面的操作,MCP 服務器可以檢索天氣更新了。只需向 Cursor IDE 詢問任何位置的天氣更新,它將使用 MCP 服務器為我們獲取該信息。

輸入查詢:“ 請告訴我今天圣地亞哥的天氣如何 ”

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

Query: "New York weather?"

FastAPI-MCP 架構實踐: 使用FastAPI一鍵轉化MCP服務器-AI.x社區

從輸出中看到MCP 服務器運行良好。只需要詢問天氣詳情,它將自行決定是否使用 MCP 服務器。在第二個輸出中,我們模糊地詢問“紐約天氣?”它能夠根據我們之前的提示意識到查詢的上下文,并使用適當的 MCP 工具來回答。

結論

MCP 允許 ??LLMs?? 通過訪問外部工具來增強其回答能力,而 FastAPI 則提供了一種簡單的方法。本文中,我們使用 fastapi-mcp 庫結合了這兩種技術。利用這個庫,我們可以將任何 API 轉換為 MCP 服務器,這將幫助 LLMs 和 AI 代理從 API 中獲取最新信息。不需要為每個新任務定義自定義工具。MCP 與 FastAPI 將自動處理一切。MCP 的引入帶來了 LLMs 領域的革命,現在,FastAPI 與 MCP 搭配正在改變 LLMs 訪問這些工具的方式。?

譯者介紹

崔皓,51CTO社區編輯,資深架構師,擁有18年的軟件開發和架構經驗,10年分布式架構經驗。

原文標題:??How to Convert Any FastAPI App into MCP Server using FastAPI-MCP???,作者:Harsh Mishra

?著作權歸作者所有,如需轉載,請注明出處,否則將追究法律責任
已于2025-5-19 08:27:02修改
收藏
回復
舉報
回復
相關推薦
成人av毛片| 国产又大又黄又粗| 亚洲一级大片| 欧美日韩另类字幕中文| 日韩欧美一区二区视频在线播放 | 91精品观看| 亚洲成人精品久久| 亚洲欧美在线精品| 99爱在线观看| 亚洲视频你懂的| 久久国产一区二区| 国产毛片在线视频| 丝袜美腿高跟呻吟高潮一区| 久久亚洲精品中文字幕冲田杏梨| 在线观看国产网站| 疯狂欧洲av久久成人av电影 | 欧美日韩黄色一级片| 在线看免费av| 久久嫩草精品久久久精品一| 91免费在线视频| 国产精品久久久久久久久久精爆| 永久91嫩草亚洲精品人人| 亚洲欧美日韩爽爽影院| 丰满人妻一区二区三区53视频| 最近在线中文字幕| 亚洲资源在线观看| 中文字幕一区二区三区乱码| 日韩在线免费播放| 成人动漫一区二区在线| 国产欧美日韩高清| 九九精品免费视频| 亚洲二区免费| 日韩在线观看免费av| 粉嫩av蜜桃av蜜臀av| 白白在线精品| 欧美一区二区三区影视| 国产又粗又长又大的视频| 91美女精品| 一区二区久久久久| 婷婷视频在线播放| 成人影院免费观看| 久久久亚洲精品石原莉奈| 国产一区二区三区高清视频| 国产极品999| 国产一区二区三区观看| 国产欧美精品在线播放| 亚洲一区在线观| 免费成人在线观看| 国产精品 欧美在线| 久久久久久久久黄色| 国产精品久久久久久模特| 色综合久久88色综合天天看泰| 国内毛片毛片毛片毛片毛片| 欧美亚洲在线日韩| 中文字幕日韩av电影| 人妻少妇无码精品视频区| 杨幂一区二区三区免费看视频| 日韩av中文字幕在线免费观看| 日韩精品视频一区二区| 国产成人一二片| 亚洲成人黄色网址| 中文字幕影片免费在线观看| 久久av国产紧身裤| 国产婷婷成人久久av免费高清| 亚洲人人夜夜澡人人爽| 九九视频精品全部免费播放| 亚洲香蕉伊综合在人在线视看| 三级网站在线免费观看| 日韩电影在线视频| 久久夜色撩人精品| 国产精品成人av久久| 在线亚洲欧美| 国产成人鲁鲁免费视频a| 正在播放亚洲精品| 精品一区二区三区欧美| 91在线在线观看| 日韩在线视频第一页| 26uuu亚洲综合色欧美| 日本精品一区二区| 免费看美女视频在线网站| 亚洲精品欧美综合四区| 亚洲人精品午夜射精日韩| xxx欧美xxx| 欧美精选午夜久久久乱码6080| 三日本三级少妇三级99| 激情视频极品美女日韩| 亚洲人高潮女人毛茸茸| 天天色天天综合| 亚洲大胆视频| 国产精品欧美激情| 亚洲va欧美va| 国产视频一区在线播放| 免费看污污视频| 老司机深夜福利在线观看| 欧洲生活片亚洲生活在线观看| 182午夜视频| 老汉色老汉首页av亚洲| 色爱av美腿丝袜综合粉嫩av | 黄色av日韩| 日本一区二区三区四区视频| 国产免费一区二区三区最新不卡| 成人午夜视频免费看| 日韩久久不卡| a级大胆欧美人体大胆666| 在线观看免费视频综合| 香蕉视频免费网站| 日韩精品午夜| 91a在线视频| 国产成人久久精品77777综合| 久久久蜜臀国产一区二区| 99久re热视频精品98| 蜜臀国产一区| 精品国产3级a| 日韩欧美综合视频| 首页亚洲欧美制服丝腿| 国产精品福利视频| 日本www在线观看| 疯狂做受xxxx高潮欧美日本 | 无码人妻熟妇av又粗又大| 国产一区二区美女| 亚洲图片都市激情| 另类专区亚洲| 日韩av一区二区在线| 一级黄色片日本| 日本美女一区二区三区视频| 久久99精品国产一区二区三区| 91国内在线| 欧美精品视频www在线观看| 加勒比一区二区| 国产精品普通话对白| 国产精品二区在线| 成人影院在线观看| 欧美精品日韩一本| 四虎影视一区二区| 日韩成人一级大片| 欧美午夜视频在线| 老色鬼在线视频| 日韩精品视频在线观看网址| 久久精品国产亚洲av麻豆色欲| 国模大尺度一区二区三区| 亚洲精品影院| 日本欧美一区| 中文字幕日韩av电影| 日韩xxx视频| 国产欧美一区二区三区鸳鸯浴 | 亚洲天堂av在线免费| 欧美激情黑白配| 91麻豆精品在线观看| 日韩av黄色网址| 中国av一区| 国产精品96久久久久久又黄又硬| 免费毛片在线| 欧美性极品少妇| 国产精品视频在| 另类调教123区 | 国产偷久久久精品专区| 91探花在线观看| 亚洲精品国产成人| 日日摸天天添天天添破| 国产视频不卡一区| 日韩av卡一卡二| 亚洲成人精品| 成人午夜电影在线播放| sm在线播放| 亚洲欧美日韩精品久久亚洲区 | 亚洲精品中文字幕乱码三区不卡| 看片一区二区| 欧美超级免费视 在线| 亚洲国产福利视频| 岛国精品视频在线播放| 国产伦理片在线观看| 久久超碰97中文字幕| 欧美美女黄色网| 亚欧日韩另类中文欧美| 国产精选久久久久久| av片在线观看免费| 日韩成人激情在线| 国产情侣免费视频| 亚洲激情在线激情| 美女又爽又黄视频毛茸茸| 日日摸夜夜添夜夜添国产精品| 亚洲一区三区| 丁香一区二区| 国产精品久久久久久久久久久新郎| 免费高清完整在线观看| 精品国产精品网麻豆系列| 亚洲天堂五月天| 亚洲你懂的在线视频| 亚洲久久久久久| 韩国视频一区二区| 男人揉女人奶房视频60分| 97国产成人高清在线观看| 大波视频国产精品久久| 日韩电影网站| 欧美激情精品久久久| 极品白浆推特女神在线观看| 777xxx欧美| 亚洲熟妇无码乱子av电影| 中文字幕一区二区三区四区| 成年人网站免费看| 国产另类ts人妖一区二区| 激情网站五月天| 国产综合激情| 中文字幕免费在线不卡| 网红女主播少妇精品视频| 91久久精品国产91性色| 成人免费看视频网站| 九九久久久久99精品| 懂色av中文在线| 亚洲国产中文字幕在线观看| 国产一区二区三区黄片| 狠狠干狠狠久久| 激情五月少妇a| 国产精品色呦呦| 蜜臀av一区二区三区有限公司| 国产成人精品免费| 午夜免费福利视频在线观看| 香蕉精品999视频一区二区 | 欧美老熟妇一区二区三区| 国产亚洲制服色| 日本国产在线视频| 国精品**一区二区三区在线蜜桃| 成人黄色片视频| 亚洲国产片色| 国产高清不卡无码视频| 国产精品伦理久久久久久| 日本一区二区在线| 一区三区在线欧| 精品国产一区二区三区久久久久久| 国产精品2区| 国产欧美一区二区三区视频 | 91精品国产福利在线观看| 国产三级精品三级在线观看| 天天综合天天做天天综合| 欧美日韩激情在线观看| 亚洲欧美一区二区在线观看| 黄色三级生活片| 国产亚洲一本大道中文在线| 乐播av一区二区三区| 久久精品亚洲国产奇米99| 成人午夜剧场视频网站| 国产亚洲一二三区| 国产真人做爰视频免费| 国产日韩精品一区二区三区在线| 久久丫精品国产亚洲av不卡 | 日本高清一二三区| 亚洲私人影院在线观看| 成人免费视频国产免费观看| 亚洲桃色在线一区| 青青草原免费观看| 亚洲国产精品久久不卡毛片| 久久综合久久鬼| 午夜av电影一区| 国产成人在线视频观看| 欧美网站在线观看| 国产女主播喷水视频在线观看 | 国产精品啊啊啊| 国产日本在线播放| 国产亚洲激情| 国产精品无码一本二本三本色| 日韩vs国产vs欧美| 天堂av8在线| 国产福利不卡视频| 黄色国产在线视频| 久久久综合视频| www.99re6| 亚洲国产日日夜夜| 女人十八岁毛片| 色综合久久综合网| 亚洲一区二区天堂| 亚洲精品一区二区精华| 亚洲av毛片成人精品| 亚洲乱亚洲乱妇无码| 高清毛片在线看| 色综合久久88色综合天天看泰| 成av人片在线观看www| 国产999精品久久久| 国产精品第一| 高清视频一区| 欧美日本成人| 91精品国产毛片武则天| 亚洲少妇在线| www.com黄色片| 国产成人精品免费视频网站| 中文字幕在线观看的网站| 国产精品卡一卡二| 精品视频一区二区在线观看| 色网综合在线观看| 99久久精品日本一区二区免费| 亚洲国产精品成人av| а天堂8中文最新版在线官网| 九九精品在线播放| 国产另类xxxxhd高清| av免费观看久久| 国产在视频线精品视频www666| 无码人妻精品一区二区三区99v| 国产日韩专区| 中文字幕55页| 国产欧美日韩中文久久| 国产成年人免费视频| 欧美少妇一区二区| 天天干天天做天天操| 久久九九免费视频| 成人短视频app| 国产精品乱码视频| 欧美va久久久噜噜噜久久| 俄罗斯av网站| 国产盗摄女厕一区二区三区| 免费看91的网站| 婷婷一区二区三区| 99精品在线看| 日韩综合视频在线观看| 悠悠资源网亚洲青| 91免费观看| 久久精品高清| 日本熟妇人妻中出| 99久久精品一区二区| 草视频在线观看| 色八戒一区二区三区| 手机av免费在线观看| 久久精品国产久精国产思思| 丝袜美腿一区| 国产一区精品在线| 欧美欧美天天天天操| 黄色手机在线视频| 国产丝袜欧美中文另类| 国产视频1区2区| 日韩风俗一区 二区| 里番在线播放| 5566av亚洲| 自由日本语亚洲人高潮| 岛国毛片在线播放| 国产精品色哟哟| 午夜视频网站在线观看| 亚洲人成啪啪网站| 厕沟全景美女厕沟精品| 国产亚洲精品自在久久| 欧美久久99| 中文在线字幕观看| 一区二区三区波多野结衣在线观看| 国产裸体永久免费无遮挡| 日韩在线观看免费| 欧美成人免费全部网站| 在线观看日韩片| 国产在线国偷精品免费看| 日本黄色录像视频| 91麻豆精品国产91久久久久久久久| 欧美尤物美女在线| 成人网在线视频| 欧美一区国产在线| 妖精视频在线观看| 亚洲图片自拍偷拍| 婷婷开心激情网| 青青久久aⅴ北条麻妃| 免费av一区| 在线视频日韩一区| 国产精品毛片无遮挡高清| 最近中文字幕在线视频| 这里只有精品丝袜| 99综合久久| wwwwww欧美| 91在线精品一区二区| 国语对白永久免费| 中文字幕日韩专区| 久久中文字幕一区二区| 大伊香蕉精品视频在线| 97精品电影院| 制服丝袜在线一区| 欧美另类xxx| 欧美日韩夜夜| 国产又猛又黄的视频| 中文字幕五月欧美| 亚洲第一页视频| 55夜色66夜色国产精品视频| 精品视频亚洲| 性鲍视频在线观看| 五月激情综合网| av大全在线免费看| 成人动漫在线视频| 午夜一级久久| 神马久久精品综合| 亚洲国产日韩一区| www.久久.com| 男人天堂av片| 国产目拍亚洲精品99久久精品| 国产青青草视频| 97婷婷涩涩精品一区| 俺要去色综合狠狠| www.欧美com| 欧美性受xxxx黑人xyx| 欧美一卡二卡| 亚洲精品国产精品久久| 成人毛片老司机大片| 中文字幕一区二区三区人妻四季| 欧美大秀在线观看| 欧美一区电影| 亚洲视频在线播放免费| 欧美二区乱c少妇| 欧美黄色网页| 奇米777四色影视在线看|