filesystem-mcp

filesystem-mcp

一个基于 TypeScript 的 MCP 服务器,实现了一个简单的笔记系统,允许用户通过 URI 和工具创建、访问和生成文本笔记的摘要。

Category
访问服务器

Tools

chmod_items

Change permissions mode for multiple specified files/directories (POSIX-style).

chown_items

Change owner (UID) and group (GID) for multiple specified files/directories.

move_items

Move or rename multiple specified files/directories.

copy_items

Copy multiple specified files/directories.

search_files

Search for a regex pattern within files in a specified directory (read-only).

list_files

List files/directories. Can optionally include stats and list recursively.

stat_items

Get detailed status information for multiple specified paths.

read_content

Read content from multiple specified files.

write_content

Write or append content to multiple specified files (creating directories if needed).

delete_items

Delete multiple specified files or directories.

create_directories

Create multiple specified directories (including intermediate ones).

replace_content

Replace content within files across multiple specified paths.

README

文件系统 MCP 服务器 (@sylphlab/filesystem-mcp)

npm version Docker Pulls

<!-- Add other badges like License, Build Status if applicable --> <a href="https://glama.ai/mcp/servers/@sylphlab/filesystem-mcp"> <img width="380" height="200" src="https://glama.ai/mcp/servers/@sylphlab/filesystem-mcp/badge" /> </a>

使您的 AI 代理(如 Cline/Claude)能够安全、高效且节省 token 地访问您的项目文件。 这个 Node.js 服务器实现了 模型上下文协议 (MCP),提供了一套强大的文件系统工具,可以在定义的项目根目录下安全运行。

安装

有几种方法可以使用文件系统 MCP 服务器:

1. 推荐:通过 MCP 主机配置使用 npx (或 bunx)

最简单的方法是通过 npxbunx,直接在您的 MCP 主机环境(例如,Roo/Cline 的 mcp_settings.json)中配置。这确保您始终使用 npm 上的最新版本,而无需本地安装或 Docker。

示例 (npx):

{
  "mcpServers": {
    "filesystem-mcp": {
      "command": "npx",
      "args": ["@sylphlab/filesystem-mcp"],
      "name": "Filesystem (npx)"
    }
  }
}

示例 (bunx):

{
  "mcpServers": {
    "filesystem-mcp": {
      "command": "bunx",
      "args": ["@sylphlab/filesystem-mcp"],
      "name": "Filesystem (bunx)"
    }
  }
}

重要提示: 服务器使用其自身的当前工作目录 (cwd) 作为项目根目录。确保您的 MCP 主机(例如 Cline/VSCode)配置为使用 cwd 设置为您的活动项目根目录来启动命令。

2. Docker

使用官方 Docker 镜像用于容器化环境。

示例 MCP 主机配置:

{
  "mcpServers": {
    "filesystem-mcp": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-v",
        "/path/to/your/project:/app", // 将您的项目挂载到 /app
        "sylphlab/filesystem-mcp:latest"
      ],
      "name": "Filesystem (Docker)"
    }
  }
}

请记住将 /path/to/your/project 替换为正确的绝对路径。

3. 本地构建(用于开发)

  1. 克隆:git clone https://github.com/sylphlab/filesystem-mcp.git
  2. 安装:cd filesystem-mcp && pnpm install (现在使用 pnpm)
  3. 构建:pnpm run build
  4. 配置 MCP 主机:
    {
      "mcpServers": {
        "filesystem-mcp": {
          "command": "node",
          "args": ["/path/to/cloned/repo/filesystem-mcp/dist/index.js"], // 更新后的构建目录
          "name": "Filesystem (Local Build)"
        }
      }
    }
    
    注意: 从您希望作为项目根目录的目录启动 node 命令。

快速开始

在您的 MCP 主机中配置服务器后(请参阅安装),您的 AI 代理可以立即开始使用文件系统工具。

示例代理交互(概念):

Agent: <use_mcp_tool>
         <server_name>filesystem-mcp</server_name>
         <tool_name>read_content</tool_name>
         <arguments>{"paths": ["src/index.ts"]}</arguments>
       </use_mcp_tool>

Server Response: (Content of src/index.ts)

为什么选择这个项目?

  • 🛡️ 安全且方便的项目根目录焦点: 操作仅限于项目根目录(启动时的 cwd)。
  • ⚡ 优化和整合的工具: 批量操作减少了 AI 服务器的往返次数,从而节省了 token 和延迟。 批量处理中每个项目的可靠结果。
  • 🚀 易于集成: 通过 npx/bunx 快速设置。
  • 🐳 容器化选项: 可作为 Docker 镜像使用。
  • 🔧 全面的功能: 涵盖广泛的文件系统任务。
  • ✅ 强大的验证: 使用 Zod 模式进行参数验证。

性能优势

(占位符:在此处添加基准测试结果和比较,展示优于替代方法(如单个 shell 命令)的优势。)

  • 批量操作: 与单个操作相比,显著降低了开销。
  • 直接 API 使用: 比为每个命令生成 shell 进程更有效。
  • (可用时添加特定基准数据)

特性

该服务器为您的 AI 代理配备了强大而高效的文件系统工具包:

  • 📁 浏览和检查 (list_files, stat_items): 列出文件/目录(递归,统计信息),获取多个项目的详细状态。
  • 📄 读取和写入内容 (read_content, write_content): 读取/写入/追加多个文件,创建父目录。
  • ✏️ 精确编辑和搜索 (edit_file, search_files, replace_content): 在多个文件中进行外科手术式编辑(插入、替换、删除),并保留缩进和差异输出; 使用上下文进行正则表达式搜索; 多文件搜索/替换。
  • 🏗️ 管理目录 (create_directories): 创建多个目录,包括中间父目录。
  • 🗑️ 安全删除 (delete_items): 递归删除多个文件/目录。
  • ↔️ 移动和复制 (move_items, copy_items): 移动/重命名/复制多个文件/目录。
  • 🔒 控制权限 (chmod_items, chown_items): 更改多个项目的 POSIX 权限和所有权。

主要优势: 所有接受多个路径/操作的工具都会单独处理每个项目,并返回详细的状态报告。

设计理念

(占位符:解释核心设计原则。)

  • 安全第一: 优先防止访问项目根目录之外的内容。
  • 效率: 最大程度地减少 AI 交互的通信开销和 token 使用量。
  • 健壮性: 为批量操作提供详细的结果和错误报告。
  • 简单性: 通过 MCP 提供清晰一致的 API。
  • 标准合规性: 严格遵守模型上下文协议。

与其他解决方案的比较

(占位符:客观地与其他替代方案进行比较。)

特性/方面 文件系统 MCP 服务器 单个 Shell 命令(通过代理) 其他自定义脚本
安全性 高(根目录限制) 低(代理需要 shell 访问权限) 可变
效率(Token) 高(批量处理) 低(每个操作一个命令) 可变
延迟 低(直接 API) 高(Shell 启动开销) 可变
批量操作 是(大多数工具) 可能
错误报告 详细(每个项目) 基本(stdout/stderr 解析) 可变
设置 简单(npx/Docker) 需要安全的 shell 设置 自定义

未来计划

(占位符:列出即将推出的功能或改进。)

  • 探索文件监视功能。
  • 研究对超大文件的流式传输支持。
  • 提高特定操作的性能。
  • list_files 添加更高级的过滤选项。

文档

(占位符:添加指向完整文档网站的链接,一旦可用。)

完整的文档,包括详细的 API 参考和示例,将在以下位置提供:[文档站点链接]

贡献

欢迎贡献! 请在 GitHub 存储库 上打开一个 issue 或提交一个 pull request。

许可证

本项目根据 MIT 许可证 发布。


开发

  1. 克隆:git clone https://github.com/sylphlab/filesystem-mcp.git
  2. 安装:cd filesystem-mcp && pnpm install
  3. 构建:pnpm run build (将 TypeScript 编译为 dist/)
  4. 监视:pnpm run dev (可选,保存时重新编译)

发布(通过 GitHub Actions)

此存储库使用 GitHub Actions (.github/workflows/publish.yml) 在版本标签 (v*.*.*) 推送到 main 分支时,自动将软件包发布到 npm 并构建/推送 Docker 镜像到 Docker Hub。 需要在 GitHub 存储库设置中配置 NPM_TOKENDOCKERHUB_USERNAMEDOCKERHUB_TOKEN 密钥。

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选