尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

vscode集成MCP Server

vscode集成MCP Server
📅 发布时间:2026/6/19 19:58:19
本文介绍如何在 VS Code 中集成自行开发的 MCP (Model Context Protocol) Server

前言

本文介绍如何在 VS Code 中集成自行开发的 MCP (Model Context Protocol) Server。通过配置 .vscode/mcp.json 文件,可以将自定义的 MCP Server 注册到 VS Code 的 GitHub Copilot 中,从而让 AI 助手能够调用用户开发的工具函数。整个过程包括:编写 MCP Server 代码、配置服务器启动参数、启动服务并测试调用。

注意,Copilot不是必须的,只是vscode 官方对copilot集成更好,其它第三方的模型也能使用MCP Server。

使用Copilot

  1. 编写数学工具的mcp server. math.py
from fastmcp import FastMCP
from typing import TypeAlias, Union
from datetime import datetimemcp = FastMCP("math")Number: TypeAlias = Union[int, float]@mcp.tool()
def add(a: Number, b: Number) -> Number:"""Add two numbersArgs:a (Number): The first numberb (Number): The second numberReturns:Number: The sum of a and b"""return a + b@mcp.tool()
def subtract(a: Number, b: Number) -> Number:"""Subtract two numbersArgs:a (Number): The first numberb (Number): The second numberReturns:Number: The difference of a and b"""return a - b@mcp.tool()
def multiply(a: Number, b: Number) -> Number:"""Multiply two numbersArgs:a (Number): The first numberb (Number): The second numberReturns:Number: The product of a and b"""return a * b@mcp.tool()
def divide(a: Number, b: Number) -> Number:"""Divide two numbersArgs:a (Number): The numeratorb (Number): The denominatorReturns:Number: The quotient of a and bRaises:ValueError: If b is zero"""if b == 0:raise ValueError("Cannot divide by zero")return a / b@mcp.tool()
def is_greater_than(a: Number, b: Number) -> bool:"""Check if a is greater than bArgs:a (Number): The first numberb (Number): The second numberReturns:bool: True if a is greater than b, False otherwise"""return a > b@mcp.tool()
async def get_weather(city: str) -> str:  """Get weather for a given city.Args:city (str): The city nameReturns:str: A string describing the weather in the given city"""return f"It's always sunny in {city}!"@mcp.tool()
async def get_current_datetime() -> str:"""Get current date and time.Returns:str: The current date and time in YYYY-MM-DD HH:MM:SS %z format"""return datetime.now().strftime("%Y-%m-%d %H:%M:%S %z")if __name__ == "__main__":# mcp.run(transport="http", host="localhost", port=8001, show_banner=False)mcp.run(transport="stdio", show_banner=False)
  1. 创建.vscode/mcp.json
{"servers": {"math": {"command": "uv","args": ["--directory","/home/rainux/Documents/workspace/py-dev/mcp-local","run","math.py"]}}
}
  1. 在mcp.json文件中会显示一个启动的图标,点击启动。
  2. 在copilot 聊天窗口中,右下角有一个"配置工具"的图标,点击后在弹出的菜单中可以看到一个math server.
  3. 提问测试。如果没调用到mcp tool,可以尝试按Ctrl + Shift + P,输入Reload Window 来重新加载窗口,或者在mcp.json文件中重启mcp server,或者重启vscode.

非Copilot, 以通义灵码为例

在通义灵码的聊天窗口中按提示添加MCP Server 的配置,在手动添加的配置文件中填写如下内容。保存后通义灵码会自动启动MCP Server,然后测试能否调用MCP Tool即可。

{"mcpServers": {"math": {"type": "stdio","command": "uv","args": ["--directory","/home/rainux/Documents/workspace/py-dev/mcp-local","run","math.py"],"env": {"ROOT_DIR": "/home/rainux/Documents/workspace/py-dev/mcp-local"}}}
}

参考

  • VS Code 官方文档 - Use MCP servers in VS Code

本文来自博客园,作者:花酒锄作田,转载请注明原文链接:https://www.cnblogs.com/XY-Heruo/p/19219392

相关新闻

  • 框架架构设计师备考第41天——软件可靠性建模、管理与设计​
  • 奇怪的问题(们)
  • 基于多模态AI技术的传统行业智能化升级路径研究——以开源AI大模型、AI智能名片与S2B2C商城小程序为例 - 实践

最新新闻

  • 从零到一:Jetlinks物联网平台服务器部署实战与避坑指南
  • (转)一次ANSYS EM 2023R1 “Request name electronics_desktop does not exist in the licensing pool.“的离谱解决记录
  • 面试被问“你的缺点是什么”,90%的应届生都答错了!(附满分话术)
  • Spring Cloud Alibaba 最佳实践:基于 Spring Boot 4.0 的完整微服务示例项目
  • 三步掌握AI斗地主:如何用DouZero智能助手提升你的游戏胜率
  • 2026山东大学项目实训个人博客(六)

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号