MCP Hub
Back to servers

IDA Pro Multi-Session

A multi-session MCP server for IDA Pro that enables concurrent binary analysis, malware research, and vulnerability discovery across multiple isolated processes.

Stars
3
Tools
36
Updated
Jan 4, 2026
Validated
Jan 11, 2026

IDA MCP Server 使用说明

支持多文件、多会话并行分析,切记切记切记!mcp连接之后获取到的工具数量是77个!

image-20251229204640370

image-20251229204647844

支持平台

  • ✅ Windows (10/11)
  • ✅ macOS (12+)
  • ✅ Linux (Ubuntu 20.04+, Debian 11+)

快速开始

1. 环境要求

组件WindowsmacOSLinux
Python3.11+3.11+3.11+
IDA Pro9.2+9.2+9.2+
uvpip install uvpipx install uvcurl -LsSf https://astral.sh/uv/install.sh | shbrew install uvcurl -LsSf https://astral.sh/uv/install.sh | sh

2. 安装步骤

Windows

# 安装 uv
pip install uv

# 进入项目目录
cd ida-pro-mcp

# 安装依赖
uv sync

macOS

# 方式一:使用官方脚本安装 uv
curl -LsSf https://astral.sh/uv/install.sh | sh

# 方式二:使用 Homebrew
brew install uv

# 进入项目目录
cd ida-pro-mcp

# 安装依赖
uv sync

Linux

# 使用官方脚本安装 uv
curl -LsSf https://astral.sh/uv/install.sh | sh

# 进入项目目录
cd ida-pro-mcp

# 安装依赖
uv sync

3. 配置文件(推荐)

编辑根目录 config.toml,相对路径相对于该文件解析:

port = 8746                  # MCP 主端口
base_session_port = 10000    # 会话起始端口
analyze_dir = "analyze"      # 预加载的 PE/ELF/MachO 目录
ida_dir = ""                 # 可选,IDA 安装路径;留空则使用环境变量 IDADIR
uv = "uv"                    # uv 可执行文件
skip_port_check = false      # 跳过端口检查
no_preload = false           # 不预载文件,空启动
mcp_dir = "ida-pro-mcp"      # ida-pro-mcp 项目路径

各平台 IDA 路径配置示例

# Windows
ida_dir = "C:/Program Files/IDA Pro 9.2"

# macOS
ida_dir = "/Applications/IDA Pro 9.2/ida.app/Contents/MacOS"

# Linux
ida_dir = "/opt/ida-9.2"

覆盖优先级:CLI 参数 > config.toml > 内置默认


4. 使用方式

方式一:跨平台一键启动(推荐)

基于 config.toml 的配置,自动扫描 analyze/ 下的二进制文件并启动:

# Windows / macOS / Linux 通用
python start.py
自定义参数
# Windows
python start.py --port 9000 --base-session-port 12000 --analyze-dir ./analyze --ida-dir "C:/Program Files/IDA Pro 9.2"

# macOS(注意路径中的空格需要转义或引号)
python start.py --port 9000 --ida-dir "/Applications/IDA Pro 9.2/ida.app/Contents/MacOS"

# Linux
python start.py --port 9000 --ida-dir "/opt/ida-9.2"

# 跳过端口检查(端口被占用但仍要启动)
python start.py --skip-port-check

# 空启动(不预载文件,适合手动 session_create)
python start.py --no-preload
参数说明
参数说明
--port主服务器端口
--base-session-port会话起始端口
--analyze-dir待分析文件夹
--ida-dirIDA 安装路径(设置 IDADIR 环境变量)
--skip-port-check跳过端口占用检查
--no-preload不预载文件,空启动
--config指定配置文件路径(默认 config.toml

方式二:手动创建会话

  1. 运行 python start.py --no-preload 启动空服务器
  2. 通过 MCP 调用 session_create 创建分析会话

MCP 配置

Claude Desktop

配置文件位置:

平台配置文件路径
Windows%APPDATA%\Claude\claude_desktop_config.json
macOS~/Library/Application Support/Claude/claude_desktop_config.json
Linux~/.config/Claude/claude_desktop_config.json

配置内容:

{
  "mcpServers": {
    "ida-mcp": {
      "transport": {
        "type": "http",
        "url": "http://127.0.0.1:8746/mcp"
      }
    }
  }
}

Cherry Studio

{
  "mcpServers": {
    "ida-mcp": {
      "name": "IDA MCP 服务器",
      "baseUrl": "http://127.0.0.1:8746/mcp",
      "type": "http"
    }
  }
}

可用工具

会话管理 (6 个)

工具说明
session_create创建新的分析会话
session_list列出所有会话
session_switch切换活动会话
session_active获取当前活动会话
session_close关闭会话
session_status获取会话管理器状态

分析工具 (71 个)

详细工具列表请查看 AVAILABLE_TOOLS.md

类别工具数量示例
Core11idb_meta, lookup_funcs, list_funcs, imports, strings
Analysis8decompile, disasm, xrefs_to, callees, callers
Search6find_bytes, find_insns, search, basic_blocks
Export4export_funcs, callgraph, xref_matrix
Memory8get_bytes, get_u8/16/32/64, patch
Types6structs, struct_info, infer_types
Debug22dbg_start, dbg_step_into, dbg_regs
Python1py_eval

使用示例

创建会话并分析

1. session_list - 查看所有会话
2. session_switch - 切换到目标会话
3. lookup_funcs - 查找 main 函数
4. decompile - 反编译 main 函数

参数示例

// 查找函数
{"name": "lookup_funcs", "arguments": {"queries": "main"}}

// 反编译
{"name": "decompile", "arguments": {"addrs": ["0x140001440"]}}

// 列出函数
{"name": "list_funcs", "arguments": {"queries": {"count": 10, "offset": 0}}}

故障排除

端口被占用

Windows

# 查看端口占用
netstat -ano | findstr ":8746"

# 终止进程
taskkill /F /PID <进程ID>

macOS / Linux

# 查看端口占用
lsof -i :8746

# 终止进程
kill -9 <PID>

# 或使用一条命令
lsof -ti :8746 | xargs kill -9

IDB 文件被锁定

删除 analyze/ 文件夹中的 .id0, .id1, .id2, .i64 等文件,重新分析。

会话创建失败

  1. 检查 IDA 路径是否正确
  2. 确认 IDA 版本 >= 9.2
  3. 查看服务器日志输出
  4. 确认 Python 版本 >= 3.11

macOS 特定问题

# 如果遇到权限问题
chmod +x start.py

# 如果 uv 命令找不到
# 方式一:添加到 PATH
export PATH="$HOME/.cargo/bin:$PATH"

# 方式二:使用完整路径
~/Downloads/ida-pro-mcp/idb/python.exe -m uv sync

Linux 特定问题

# 如果缺少依赖
sudo apt install python3-dev build-essential

# 如果遇到 Python 找不到的问题
which python3
python3 --version

目录结构

IDA-MCP-Release/
├── analyze/               # 放待分析的二进制文件
│   ├── *.exe             # Windows PE 文件
│   ├── *.elf / *_elf     # Linux ELF 文件
│   └── *.bin / *_macho   # macOS MachO 文件
├── ida-pro-mcp/          # MCP 服务器核心
│   ├── .venv/           # 虚拟环境
│   └── src/
├── start.py              # 跨平台一键启动脚本
├── config.toml           # 配置文件
├── AVAILABLE_TOOLS.md    # 完整工具列表
└── claude_desktop_config.json

技术信息

配置项
主服务器端口8746
会话端口范围10000+
协议MCP over HTTP (JSON-RPC 2.0)
最大并发会话5
会话超时3600 秒
支持的文件格式PE (exe/dll), ELF, MachO

更新日志

v2.0.0 (2025-12-30)

  • ✅ 修复工具加载问题(现在正确显示 77 个工具)
  • ✅ 修复会话进程生命周期(使用 blocking 模式)
  • ✅ 所有 71 个分析工具测试通过
  • ✅ 添加跨平台支持(Windows/macOS/Linux)
  • ✅ 改进错误处理和日志输出

许可证

本项目基于 MIT 许可证开源。

Reviews

No reviews yet

Sign in to write a review