ROS 2 MCP Server

ROS 2 MCP Server

A Model Context Protocol server for ROS 2, enabling AI assistants to introspect and interact with ROS 2 systems.

Category
Visit Server

README

ROS 2 MCP Server

A Model Context Protocol (MCP) server for ROS 2, enabling AI assistants like GitHub Copilot to introspect and interact with ROS 2 systems.

License: MIT Python 3.8+

Features

The ROS 2 MCP Server provides 30+ tools for comprehensive ROS 2 system interaction:

  • Node Management: List and inspect running nodes
  • Topic Operations: List, echo, publish, and get topic information
  • Service Operations: List services, inspect types, and call services
  • Parameter Management: List, get, and set node parameters
  • Action Operations: List actions, get info, and send goals
  • Bag Operations: Record, play, and inspect bag files
  • Interface Inspection: List and show message/service/action definitions
  • Package Management: List packages, executables, and manifests
  • Launch Operations: List and execute launch files with parameters
  • Lifecycle Management: Control lifecycle nodes and transitions
  • Diagnostics: Run system health checks with ros2 doctor

Installation

Quick Install

git clone https://github.com/ranch-hand-robotics/rde-mcp-ros-2.git
cd rde-mcp-ros-2
./install.sh

For detailed installation instructions including platform-specific configuration, see INSTALLATION.md.

Requirements

  • ROS 2: Humble, Iron, Jazzy, or later
  • Python: 3.8 or later
  • Operating System: Linux (Ubuntu recommended), macOS, or Windows with WSL2

Installation

Option 1: Install from Source (Development)

# Clone the repository
git clone https://github.com/ranch-hand-robotics/rde-mcp-ros-2.git
cd rde-mcp-ros-2

# Install in editable mode
pip install -e .

Option 2: Install from GitHub (Coming Soon)

# Install via copilot CLI (planned)
gh copilot plugin install ranch-hand-robotics/rde-mcp-ros-2

ROS 2 Environment Setup

The server requires ROS 2 to be sourced in your environment. Add to your ~/.bashrc:

# Replace 'humble' with your ROS 2 distro
source /opt/ros/humble/setup.bash

Or source it before running:

source /opt/ros/<distro>/setup.bash
rde-mcp-ros2

Usage

Configuring Your AI Assistant

The MCP server uses stdio (standard input/output) transport, which means it's launched automatically by your AI tool when needed. No need to start a separate server!

The server works with:

Quick config for VS Code (.vscode/mcp.json):

{
  "servers": {
    "ros2": {
      "command": "rde-mcp-ros2",
      "args": []
    }
  }
}

The server will be automatically started by the AI assistant when you ask ROS 2 questions!

Optional: Running in SSE Mode

If you need to run the server as a standalone HTTP server (for remote access or debugging):

# Start in SSE mode
rde-mcp-ros2 --transport sse --port 3002

# Or use the wrapper
./run-server.sh --transport sse

Then configure your client to use SSE:

{
  "servers": {
    "ros2": {
      "type": "sse",
      "url": "http://localhost:3002/sse"
    }
  }
}

Example Interactions

Once configured, ask your AI assistant:

  • "What ROS 2 nodes are currently running?"
  • "Show me the topics being published"
  • "What's the current value of the /robot/speed parameter?"
  • "Call the /reset_simulation service"
  • "Record a bag file of all sensor topics for 30 seconds"
  • "What packages are installed in my ROS 2 workspace?"

For more detailed examples, see examples/USAGE_EXAMPLES.md.

Documentation

Development

Setting Up Development Environment

# Clone and enter directory
git clone https://github.com/ranch-hand-robotics/rde-mcp-ros-2.git
cd rde-mcp-ros-2

# Install with dev dependencies
pip install -e ".[dev]"

# Run tests (when available)
pytest

# Format code
black src/
ruff check src/

Debugging

Use SSE mode for easier debugging:

  1. Run the server directly:
source /opt/ros/<distro>/setup.bash
python src/rde_mcp_ros2/server.py
  1. Configure VS Code to connect via SSE (see .vscode/mcp.json above)

  2. Watch logs in the terminal where the server is running

Project Structure

rde-mcp-ros-2/
├── src/
│   └── rde_mcp_ros2/
│       ├── __init__.py
│       └── server.py          # Main MCP server implementation
├── pyproject.toml             # Package configuration
├── requirements.txt           # Python dependencies
├── README.md
└── LICENSE

Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Credits

Developed by Ranch Hand Robotics

Links

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured