
DICOM MCP Server
A server for managing contextual data in DICOM tools, supporting medical imaging and machine learning workflows.
What is DICOM MCP Server?
DICOM MCP Server is a server designed for managing contextual data in DICOM tools, facilitating medical imaging and machine learning workflows.
How to use DICOM MCP Server?
To use the DICOM MCP Server, install the required dependencies, set up the server using either traditional or MCP installation methods, and run the server using the provided commands.
Key features of DICOM MCP Server?
- Supports DICOM connectivity testing.
- Allows configuration of DICOM nodes through a YAML file.
- Provides tools for performing C-ECHO operations.
Use cases of DICOM MCP Server?
- Testing DICOM connectivity in medical imaging systems.
- Managing DICOM nodes for machine learning applications.
- Facilitating communication between different DICOM-compliant systems.
FAQ from DICOM MCP Server?
- What is required to run the DICOM MCP Server?
You need to install the UV package and have Python available in your system PATH.
- How do I troubleshoot common errors?
Ensure UV is installed correctly and check your Python environment settings if you encounter errors.
DICOM MCP Server
A Model Context Protocol (MCP) server for DICOM connectivity testing.
Prerequisites
- Install UV (required):
Make surepip install uv
uv
is available in your system PATH as it's required for Claude to properly execute the server.
Installation
There are two ways to set up the server:
1. Traditional Setup
Install the required dependencies:
uv pip install mcp[cli]
2. MCP Installation (Recommended)
To use this server with Claude's Model Context Protocol:
mcp install server.py
This will register the server with Claude for DICOM operations.
Running the Server
Direct Execution
uv run server.py
Through Claude
Once installed via MCP, the server will be automatically managed by Claude when needed.
The server will start on 0.0.0.0:8080 by default.
Node Configuration
The server uses a nodes.yaml
file to store DICOM node configurations. This allows you to:
- List all configured DICOM nodes
- Perform C-ECHO operations using node names instead of explicit AE titles, IPs, and ports
- Use different local AE titles for C-ECHO operations
nodes.yaml Format
nodes:
# Example node configuration
main_pacs:
ae_title: DESTINATION
ip: 192.168.1.100
port: 104
description: "Main hospital PACS system"
local_ae_titles:
- name: default
ae_title: MCP_DICOM
description: "Default AE title for MCP DICOM server"
- name: pacs_gateway
ae_title: PACS_GATEWAY
description: "PACS Gateway AE title"
Troubleshooting
If you encounter the "spawn uv ENOENT" error, it typically means one of the following:
- UV is not installed or not in your PATH
- The Python executable cannot be found by the MCP client
Solutions:
-
Make sure UV is properly installed and in your PATH:
which uv # Should show the path to UV
-
Ensure you're using a Python environment that's accessible to the system:
- If using a virtual environment, make sure it's activated
- Check that Python is in your PATH
-
Try running the server with explicit UV path:
/full/path/to/uv run server.py
-
Add more debugging by checking the stderr output in the logs
Usage
The server provides several DICOM tools that can be used through the MCP interface:
List DICOM Nodes
List all configured DICOM nodes from the nodes.yaml file:
list_dicom_nodes()
C-ECHO by Node Name
Perform a C-ECHO operation using a node name from the configuration:
dicom_cecho_by_name(node_name="main_pacs", local_ae_name="default")
Direct C-ECHO
Perform a C-ECHO operation with explicit parameters:
dicom_cecho(remote_ae_title="REMOTE_AE", ip="192.168.1.100", port=104, local_ae_title="MCP_DICOM")