当前位置: 首页 > article >正文

在 Visual Studio Code (VSCode) 中配置 MCP(Model Context Protocol)

前提条件

  1. 安装 VSCode:确保已安装最新版本的 VSCode(建议使用 1.99 或以上版本,支持 MCP)。
  2. 安装 GitHub Copilot 扩展:MCP 通常与 GitHub Copilot 的代理模式(Agent Mode)结合使用,确保已安装并登录 GitHub Copilot。
  3. 启用 MCP 支持:在 VSCode 设置中,确保 chat.mcp.enabled 已启用(默认启用)。
  4. 安装必要工具:根据 MCP Server 的运行需求,可能需要安装 Node.js、Python 或 Docker 等工具。

配置 MCP Server 的步骤

  1. 选择配置方式

VSCode 提供了三种方式来添加 MCP Server:

  • 工作区设置:通过在工作区创建 .vscode/mcp.json 文件配置,适合团队共享。
  • 用户设置:通过 VSCode 的用户设置(settings.json)配置,适用于所有工作区。
  • 自动发现:启用自动发现功能,检测其他工具(如 Claude Desktop)中定义的 MCP Server。

以下以最常用的 工作区设置 为例,介绍如何配置。


  1. 创建 .vscode/mcp.json 文件

  2. 打开工作区

    • 在 VSCode 中打开你的项目文件夹(工作区)。
  3. 创建配置文件

    • 在工作区根目录下创建 .vscode 文件夹(如果不存在)。
    • 在 .vscode 文件夹中创建 mcp.json 文件。
  4. 添加 MCP Server 配置

    • 编辑 mcp.json,添加 MCP Server 的配置。以下是一个示例配置,用于添加 Perplexity MCP Server:

json

{"inputs": [{"type": "promptString","id": "api-key","description": "Perplexity API Key","password": true}],"servers": {"perplexity": {"type": "stdio","command": "npx","args": ["-y", "@modelcontextprotocol/server-perplexity"],"env": {"PERPLEXITY_API_KEY": "${input:api-key}"}}}
}

说明

  • inputs:定义启动服务器时需要输入的变量(如 API 密钥),VSCode 会在首次启动时提示输入,并安全存储。
  • servers:定义 MCP Server 的配置。
    • type:连接类型,通常为 stdio(标准输入/输出)或 sse(服务器发送事件)。
    • command:运行服务器的命令(如 npx、docker 或自定义命令)。
    • args:命令的参数,指定要运行的 MCP Server 包。
    • env:环境变量,用于传递 API 密钥等敏感信息。

注意

  • 确保 command 和 args 指向的 MCP Server 包已正确安装(通过 npm install -g 或本地安装)。
  • 仅使用来自可信来源的 MCP Server,因为它们可能在你的机器上运行任意代码。

  1. 通过命令面板添加 MCP Server

如果你不想手动编辑 mcp.json,可以使用 VSCode 的命令面板:

  1. 打开命令面板:
    • 按 Ctrl+Shift+P(或 Cmd+Shift+P on Mac)。
  2. 输入并选择 MCP: Add Server。
  3. 选择 MCP Server 类型(如 Perplexity、GitHub 等)。
  4. 提供服务器信息(如命令、参数、环境变量)。
  5. 选择存储位置:
    • Workspace Settings:将配置添加到 .vscode/mcp.json。
    • User Settings:将配置添加到全局 settings.json。
  6. 保存后,VSCode 会自动应用配置。

  1. 配置用户设置(全局)

如果你希望 MCP Server 在所有工作区生效,可以编辑用户设置:

  1. 打开 VSCode 设置:
    • 按 Ctrl+,(或 Cmd+, on Mac)打开设置界面。
    • 或者通过命令面板运行 Preferences: Open Settings (JSON)。
  2. 编辑 settings.json,添加以下内容:

json

{"mcp": {"servers": {"my-mcp-server": {"type": "stdio","command": "npx","args": ["-y", "@modelcontextprotocol/server-example"]}}}
}
  1. 保存后,配置将应用于所有工作区。

  1. 验证和使用 MCP Server

  2. 检查服务器状态

    • 运行命令 MCP: List Servers(通过命令面板)。
    • 查看已配置的服务器列表,确认服务器状态(绿色小灯表示运行正常)。
  3. 使用代理模式

    • 确保 GitHub Copilot 的代理模式已启用(在设置中启用 chat.agent.enabled)。
    • 打开聊天视图,选择 Agent 模式。
    • 输入任务,代理会自动调用 MCP Server 提供的工具(如文件操作、API 调用等)。
  4. 管理工具

    • 在聊天视图中点击“工具”图标,启用或禁用特定工具。
    • 使用 # 引用特定工具,如 #github 调用 GitHub MCP Server 的工具。

  1. 针对 Windows 的额外注意事项

在 Windows 系统中,某些 MCP Server 配置可能需要调整:

  • 命令修改:将 command 从 npx 改为 cmd,并在 args 中添加 /c 和 npx。示例:

json

{"mcpServers": {"sequential-thinking": {"command": "cmd","args": ["/c", "npx", "-y", "@modelcontextprotocol/server-sequential-thinking"]}}
}
  • 环境变量:确保环境变量(如 APPDATA)正确设置。例如:

json

{"mcpServers": {"sequential-thinking": {"command": "cmd","args": ["/c", "set APPDATA=C:\\Users\\YourUsername\\AppData\\Roaming&&", "npx", "-y", "@modelcontextprotocol/server-sequential-thinking"]}}
}
  • 安装依赖:确保 Node.js 已安装,并通过 npm install -g 安装所需的 MCP Server 包。

  1. 故障排查
  • 服务器未运行
    • 检查聊天视图中的错误通知,点击“显示输出”查看日志。
    • 运行 MCP: List Servers,选择服务器并查看输出日志。
  • 命令失败
    • 确认 command 和 args 正确,尝试在终端手动运行命令以调试。
    • 确保所需工具(如 npx、docker)已安装。
  • 连接问题
    • 如果使用 sse 连接,检查服务器 URL 是否正确且端口未被占用。
  • 配置错误
    • 使用 VSCode 的 IntelliSense 检查 mcp.json 的语法错误。
    • 参考官方配置格式文档:https://code.visualstudio.com/docs/editor/mcp

  1. 示例:配置 GitHub MCP Server

以下是一个配置 GitHub MCP Server 的示例:

  1. 获取 GitHub 个人访问令牌:
    • 登录 GitHub,进入 Settings > Developer settings > Personal access tokens > Fine-grained tokens。
    • 创建令牌,设置必要的权限(如访问仓库)。
    • 复制生成的令牌。
  2. 配置 mcp.json:

json

{"mcpServers": {"github": {"command": "cmd","args": ["/c", "npx", "-y", "@modelcontextprotocol/server-github"],"env": {"GITHUB_PERSONAL_ACCESS_TOKEN": "your_token_here"}}}
}
  1. 保存并验证:
    • 运行 MCP: List Servers,确保 GitHub 服务器显示为绿色。
    • 在代理模式下输入 #github list repositories,测试服务器功能。

推荐的 MCP Server

以下是一些常用的 MCP Server,供参考:

  • @modelcontextprotocol/server-filesystem:提供文件系统操作工具。
  • @modelcontextprotocol/server-github:管理 GitHub 仓库、拉取请求等。
  • @modelcontextprotocol/server-perplexity:集成 Perplexity AI 搜索功能。
  • @executeautomation/playwright-mcp-server:支持浏览器自动化。

探索更多服务器:https://github.com/modelcontextprotocol


注意事项

  • 安全性:仅从可信来源安装 MCP Server,审查配置和代码,避免泄露敏感信息。
  • 性能:MCP Server 可能占用系统资源,建议根据需要选择工具。
  • 更新:MCP 生态系统正在快速发展,定期检查 VSCode 和 MCP Server 的更新。

相关文章:

在 Visual Studio Code (VSCode) 中配置 MCP(Model Context Protocol)

前提条件 安装 VSCode:确保已安装最新版本的 VSCode(建议使用 1.99 或以上版本,支持 MCP)。安装 GitHub Copilot 扩展:MCP 通常与 GitHub Copilot 的代理模式(Agent Mode)结合使用,…...

图像锐化调整

一、背景介绍 之前找多尺度做对比度增强时候,发现了一些锐化相关算法,正好本来也要整理锐化,这里就直接顺手对之前做过的锐化大概整理了下,方便后续用的时候直接抓了。 这里整理的锐化主要是两块:一个是参考论文&#…...

我设计的一个安全的 web 系统用户密码管理流程

作为一名有多年经验的前端,在刚开始学习web后端的时候,就对如何设计一个安全的 web 系统用户密码管理流程有很多疑问。之前自己也实践过几种方法,但一直觉得不是十分安全。 我们知道,用户在注册或登录界面填写的密码是明文的&…...

Vue.js---计算属性computed和lazy

4.6 计算属性computed和lazy 懒执行的effect:一般的effect一下子就执行了,但是懒加载effect是等需要的时候才会执行 这时我们通过在options中添加lazy属性来达到目的 function effect (fn , options {}) {const effectFn () > {// 调用clearup函数…...

找客户的app

找客户的 app 在竞争激烈的商业环境中,找客户的 APP 成为企业拓展业务的利器。 微拓客 APP,集智能获客、营销素材、客户管理于一体。支持关键词、附近客源等多方式采集,覆盖 300 行业;一键采集客源,一键导出到通讯录…...

HarmonyOS学习

个人简介 👨‍💻‍个人主页: 魔术师 📖学习方向: 主攻前端方向,正逐渐往全栈发展 🚴个人状态: 研发工程师,现效力于政务服务网事业 🇨🇳人生格言&…...

​​金融合规革命:​​R²AIN SUITE 如何重塑银行业务智能​

一、市场发展背景与核心驱动因素​ 信息过载​:单家银行年均新增监管文件大量增加,人工解读效率极低。 客户体验升级​:高净值客户期待“724小时专业级响应”,但客户经理难以实时掌握数百款产品动态。 风险防控​:传…...

Spring 框架核心机制深度解析【AI模型互搏生成】

Spring 框架核心机制深度解析(玩转开源代码) 一、Bean 生命周期全流程剖析 1.1 核心生命周期阶段 以下是 Spring Bean 生命周期核心阶段的配图,结合实际流程图示清晰展现每一步执行顺序及扩展点挂载位置。 🧬Spring Bean 生命周…...

Linux信号的保存

Linux系统中信号的保存涉及内核为每个进程维护的数据结构,确保信号在产生后、处理前被正确记录和管理。以下是详细的解释: 1. 信号的基本概念 信号(Signal):用于通知进程发生了特定事件的异步通知机制,如…...

论文阅读:Self-Collaboration Code Generation via ChatGPT

地址:Self-Collaboration Code Generation via ChatGPT 摘要 尽管大型语言模型(LLMs)在代码生成能力方面表现出色,但在处理复杂任务时仍存在挑战。在现实软件开发中,人类通常通过团队协作来应对复杂任务,…...

2025年PMP 学习十五 第10章 项目资源管理

2025年PMP 学习十五 第10章 项目资源管理 序号过程过程组1规划沟通管理规划2管理沟通执行3监控沟通监控 项目沟通管理包括为确保项目的信 息及时且恰当地规划、收集、生成、发布、存储、检索、管理、控制、监 警和最终处理所需的过程; 项目经理绝大多数时间都用于与…...

如何使用易路iBuilder智能体平台快速安全深入实现AI HR【实用帖】

随着企业组织经营对降本、增效、提质的需求日益迫切,越来越多企业启动人力资源数智化转型战略。而在AI战略实际推进过程中,企业组织往往在选型、搭建、使用、管控等问题上面临困惑: 如何快速、低成本接入AI能力,实现人力资源管理…...

高效管理嵌套Git仓库:三合一脚本解决方案

背景介绍 在大型软件开发项目中,我们经常会遇到Git仓库嵌套的情况(即一个Git仓库中包含其他Git子仓库)。传统的手动管理方式效率低下,容易出错。本文将介绍三个精心设计的Shell脚本,帮助开发者高效扫描、克隆和更新嵌套Git仓库。 脚本功能解析 1. clone_dep_repo.sh - …...

免费实用的远程办公方案​

假如你需要快速检索出远程电脑文件并下载? 假如你需要访问远程电脑的共享文件夹? 假如你需要访问远程电脑的USB设备,例如软件加密狗、调试器、固件烧录器、U盘等? 本篇文章能够解决以上痛点。 这个方案非常实用,也很…...

【springboot项目服务假死、内存溢出问题排查】

问题现象:springboot服务A刚启动时正常,但运行几个小时后就会接口请求无响应,但服务器网络、磁盘I/O和CPU都没有出现爆满的情况,且A服务日志没有异常报错。 线上SpringBoot假死现象 SpringBoot应用会出现无法访问的情况。具体的表…...

Java 线程状态详解:从创建到销毁的完整旅途

前言 在 Java 多线程编程中,线程的状态管理是理解并发逻辑的核心。本文将用通俗的语言和代码示例,解析线程的6种状态及其转换条件,助你彻底掌握线程的生命周期。 一、线程的6种状态 状态含义NEW线程对象已创建,但未启动&#xf…...

操作系统|| 虚拟内存页置换算法

题目 写一个程序来实现 FIFO 和 LRU 页置换算法。首先,产生一个随机的页面引用序列,页面数从 0~9。将这个序列应用到每个算法并记录发生的页错误的次数。实现这个算法时要将页帧的数量设为可变。假设使用请求调页。可以参考所示的抽象类。 抽象类&…...

Maven 项目构建时编译错误问题排查与解决

1. 问题描述 Maven 项目执行命令 mvn clean package 时出现编译错误&#xff0c;如下图所示 2. 问题分析 由于是源码编译错误&#xff0c;于是通过查看项目 pom.xml 文件&#xff0c;得到项目源码使用的 Java 版本为 21 <project xmlns"http://maven.apache.org/P…...

5 Celery多节点部署

一、多节点部署架构设计 1.1 典型生产环境拓扑 #mermaid-svg-NjPQBLvUUsBc24uk {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-NjPQBLvUUsBc24uk .error-icon{fill:#552222;}#mermaid-svg-NjPQBLvUUsBc24uk .error…...

FPGA:Lattice的FPGA产品线以及器件选型建议

本文将详细介绍Lattice Semiconductor的FPGA产品线&#xff0c;帮助你了解各系列的特点和适用场景&#xff0c;以便更好地进行选型。Lattice以低功耗、小尺寸和高性能为核心&#xff0c;产品覆盖低中端市场&#xff0c;广泛应用于通信、计算、工业、汽车、消费电子、嵌入式视觉…...

安全生产调度管理系统的核心功能模块

安全生产调度管理系统是运用现代信息技术构建的智能化管理平台&#xff0c;旨在实现生产安全风险的全面管控和应急资源的优化调度。该系统通过整合物联网、大数据、人工智能等前沿技术&#xff0c;建立起覆盖风险监测、预警预测、指挥调度、决策支持的全链条安全管理体系。 一…...

R语言学习--Day03--数据清洗技巧

在一般情况下&#xff0c;我们都是在数据分析的需求前提下去选择使用R语言。而实际上&#xff0c;数据分析里&#xff0c;百分之八十的工作&#xff0c;都是在数据清洗。并不只是我们平时会提到的异常值处理或者是整合格式&#xff0c;更多会涉及到将各种各样的数据整合&#x…...

Linux进程信号(一)之信号的入门

文章目录 信号入门1. 生活角度的信号2. 技术应用角度的信号3. 注意4. 信号概念5.用kill -l命令可以察看系统定义的信号列表6. 信号处理常见方式 信号入门 1. 生活角度的信号 你在网上买了很多件商品&#xff0c;再等待不同商品快递的到来。但即便快递没有到来&#xff0c;你也…...

基于springboot+vue的机场乘客服务系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7数据库工具&#xff1a;Navicat12开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;Maven3.3.9 系统展示 用户管理 航班信…...

基于SpringBoot的房屋租赁管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

redis数据结构-11(了解 Redis 持久性选项:RDB 和 AOF)

了解 Redis 持久性选项&#xff1a;RDB 和 AOF Redis 提供了多个持久性选项&#xff0c;以确保数据持久性并防止在服务器发生故障或重启时丢失数据。了解这些选项对于为您的特定使用案例选择正确的策略、平衡性能和数据安全至关重要。本章节将深入探讨 Redis 中的两种主要持久…...

STM32外设AD/DA-基础及CubeMX配置

STM32外设AD/DA-基础及CubeMX配置 一&#xff0c;什么是AD/DA二&#xff0c;基础概念1&#xff0c;模拟 vs 数字2&#xff0c;AD转换1&#xff0c;分辨率 (Resolution)2&#xff0c;参考电压 (Reference Voltage, Vref)3&#xff0c;采样率 (Sampling Rate) 3&#xff0c;DA转换…...

React Native简介

React Native 是由 Meta&#xff08;原 Facebook&#xff09;开源的跨平台移动应用开发框架&#xff0c;基于 React 和 JavaScript&#xff0c;允许开发者使用同一套代码库构建 iOS 和 Android 原生应用。通过 JavaScript 调用原生组件实现高性能渲染。 跨平台开发 共享 80%-9…...

微服务如何实现服务的高并发

高并发的常见指标 响应时间吞吐量每秒查询率QPS并发用户数 高并发是分布式系统架构设计必须的考虑因素 具体实现方案粗略分两种&#xff1a; 垂直扩展 ‌硬件升级方向‌ 处理器&#xff1a;增加CPU核数&#xff08;如升级至32核以上&#xff09;或采用更高主频的CPU存储设备…...

GCC 使用说明

参数 -fPIC ppc_85xx-gcc -shared -fPIC liberr.c -o liberr.so -fPIC 作用于编译阶段&#xff0c;告诉编译器产生与位置无关代码(Position-Independent Code)&#xff0c; 则产生的代码中&#xff0c;没有绝对地址&#xff0c;全部使用相对地址&#xff0c;故而代码可以被加…...