Yamcs MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Yamcs MCP Serverlist the current alarms in the simulator instance"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Yamcs MCP Server
A comprehensive Model Context Protocol (MCP) server for Yamcs (Yet Another Mission Control System) that exposes Yamcs capabilities as standardized MCP tools and resources.
Overview
The Yamcs MCP Server enables AI assistants to interact with mission control systems through natural language by providing a bridge between MCP-compatible clients and Yamcs instances. It implements the MCP protocol using FastMCP 2.x with a modular component architecture.
Features
Mission Database (MDB): Access to parameters, commands, algorithms, and space systems
TM/TC Processing: Real-time telemetry monitoring and command execution
Link Management: Monitor and control data links
Object Storage: Manage buckets and objects in Yamcs storage
Instance Management: Control Yamcs instances and services
Alarm Management: Monitor and acknowledge alarms with summary statistics
Installation
Prerequisites
Python 3.12 or higher
Yamcs server instance (local or remote)
uv package manager (recommended) or pip
Using uv (recommended)
# Clone the repository
git clone https://github.com/PaulMRamirez/yamcs-mcp-server.git
cd yamcs-mcp-server
# Install dependencies
uv sync
# Run the server
uv run yamcs-mcpUsing pip
# Clone the repository
git clone https://github.com/PaulMRamirez/yamcs-mcp-server.git
cd yamcs-mcp-server
# Create virtual environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install the package
pip install -e .
# Run the server
yamcs-mcpRunning Yamcs
You'll need a running Yamcs instance. The easiest way is using Docker:
docker run -d --name yamcs -p 8090:8090 yamcs/example-simulationThis will start Yamcs with a simulator instance that includes example telemetry data.
Configuration
The server can be configured using environment variables or a .env file:
# Yamcs connection settings
YAMCS_URL=http://localhost:8090
YAMCS_INSTANCE=simulator
YAMCS_USERNAME=admin
YAMCS_PASSWORD=password
# Server toggles
YAMCS_ENABLE_MDB=true
YAMCS_ENABLE_PROCESSOR=true
YAMCS_ENABLE_LINKS=true
YAMCS_ENABLE_STORAGE=true
YAMCS_ENABLE_INSTANCES=true
YAMCS_ENABLE_ALARMS=true
YAMCS_ENABLE_COMMANDS=true
# Server settings
MCP_TRANSPORT=stdio
MCP_HOST=127.0.0.1
MCP_PORT=8000Usage
With Claude Desktop
Add the server to your Claude Desktop configuration:
{
"mcp-servers": {
"yamcs": {
"command": "uv",
"args": ["--directory", "/path/to/yamcs-mcp-server", "run", "yamcs-mcp"],
"env": {
"YAMCS_URL": "http://localhost:8090",
"YAMCS_INSTANCE": "simulator"
}
}
}
}Important:
Replace
/path/to/yamcs-mcp-serverwith the actual path to your yamcs-mcp-server directoryThe
--directoryargument is required for uv to find the correct projectIf
uvis not in your PATH, use the full path to uv (e.g.,/Users/PaulMRamirez/.local/bin/uv)
Available Tools
The server exposes numerous tools organized by server:
MDB Tools
mdb_list_parameters- List available parametersmdb_describe_parameter- Get parameter detailsmdb_list_commands- List available commandsmdb_describe_command- Get command detailsmdb_list_space_systems- List space systemsmdb_describe_space_system- Get space system details
Processor Tools
processors_list_processors- List available processorsprocessors_describe_processor- Get processor detailsprocessors_delete_processor- Delete a processorprocessors_issue_command- Issue a commandprocessors_subscribe_parameters- Subscribe to parameter updates
Link Tools
links_list_links- List all data linkslinks_describe_link- Get detailed link informationlinks_enable_link- Enable a data linklinks_disable_link- Disable a data link
Instance Tools
instances_list_instances- List Yamcs instancesinstances_describe_instance- Get instance detailsinstances_start_instance- Start an instanceinstances_stop_instance- Stop an instance
Storage Tools
storage_list_buckets- List storage bucketsstorage_list_objects- List objects in a bucketstorage_upload_object- Upload an objectstorage_download_object- Download an object
Alarm Tools
alarms_list_alarms- List active alarms with summary countsalarms_describe_alarm- Get detailed alarm informationalarms_acknowledge_alarm- Acknowledge an alarmalarms_shelve_alarm- Temporarily shelve an alarmalarms_unshelve_alarm- Unshelve an alarmalarms_clear_alarm- Clear an alarmalarms_read_log- Read alarm history
Command Tools
commands_list_commands- List available commands for executioncommands_describe_command- Get detailed command informationcommands_run_command- Execute a command (supports dry-run)commands_read_log- Read command execution history
Available Resources
The server also provides read-only resources:
mdb://parameters- List all parametersprocessors://list- List all processors with detailslinks://status- Show status of all linksinstances://list- List all instances with detailsalarms://list- Show active alarms summary
Development
Setting up the development environment
# Install development dependencies
uv sync --all-extras
# Install pre-commit hooks
pre-commit install
# Run tests
uv run pytest
# Run linting
uv run ruff check .
# Run type checking
uv run mypy src/Testing
Run the test suite:
# Run all tests
uv run pytest
# Run with coverage
uv run pytest --cov=yamcs_mcp --cov-report=html
# Run specific test file
uv run pytest tests/test_server.py
# Run with verbose output
uv run pytest -vTesting Without a Yamcs Server
The server can run in demo mode without connecting to a real Yamcs server:
# Run in demo mode (will show a warning about connection failure but continue)
uv run python -m yamcs_mcp.server
# Or use the demo script
uv run python run_demo.pyProject Structure
yamcs-mcp-server/
├── src/
│ └── yamcs_mcp/
│ ├── server.py # Main server entry point
│ ├── servers/ # MCP servers
│ │ ├── base_server.py # Base class for all servers
│ │ ├── mdb.py # Mission Database
│ │ ├── processors.py # TM/TC Processing
│ │ ├── links.py # Link management
│ │ ├── storage.py # Object storage
│ │ ├── instances.py # Instance management
│ │ └── alarms.py # Alarm management
│ ├── client.py # Yamcs client management
│ ├── config.py # Configuration
│ └── types.py # Type definitions
├── tests/ # Test suite
├── scripts/ # Test scripts
└── CLAUDE.md # AI assistant guidanceTroubleshooting
Common Issues
"Input validation error" when executing commands
Problem: Getting errors like '{"voltage_num": 1}' is not valid under any of the given schemas
Solution: The commands/run_command tool now accepts both formats. The server will automatically parse JSON strings to objects.
Both formats are now supported:
✅ Args as object (preferred):
{
"command": "/YSS/SIMULATOR/SWITCH_VOLTAGE_OFF",
"args": {"voltage_num": 1}
}✅ Args as JSON string (automatically parsed):
{
"command": "/YSS/SIMULATOR/SWITCH_VOLTAGE_OFF",
"args": "{\"voltage_num\": 1}"
}✅ Command without arguments:
{
"command": "/TSE/simulator/get_identification"
}✅ Multiple arguments:
{
"command": "/YSS/SIMULATOR/SET_HEATER",
"args": {
"heater_id": 2,
"temperature": 25.5,
"duration": 300
}
}Connection to Yamcs fails
Problem: Server can't connect to Yamcs at startup
Solution:
Ensure Yamcs is running:
docker ps | grep yamcsCheck the URL is correct:
curl http://localhost:8090/apiThe server will continue in demo mode even if Yamcs is unavailable
Enum serialization errors
Problem: Errors about unable to serialize enum types
Solution: This has been fixed in the latest version. Update to the latest version of the server.
Contributing
Contributions are welcome! Please read our Contributing Guidelines before submitting pull requests.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/PaulMRamirez/yamcs-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server