Skip to main content
ClaudeWave

STRING MCP server

MCP ServersOfficial Registry5 stars2 forksPythonMITUpdated today
Install in Claude Code / Claude Desktop
Method: pip / Python · -r
Claude Code CLI
claude mcp add string-mcp -- python -m -r
claude_desktop_config.json (Claude Desktop)
{
  "mcpServers": {
    "string-mcp": {
      "command": "python",
      "args": ["-m", "-r"]
    }
  }
}
1. Run the command above in your terminal (Claude Code), or paste the JSON config into claude_desktop_config.json (Claude Desktop).
2. Replace any <placeholder> values with your API keys or paths.
3. Restart Claude. The MCP server and its tools appear automatically.
💡 Install first: pip install -r

1 items in this repository

Use when answering questions with STRING database MCP tools for protein-protein interactions, interaction partners, network images, interactive STRING links, evidence pages, functional enrichment, PPI enrichment, functional annotations, proteins associated with terms, homologs, sequence search, species lookup, or STRING limitations.

Install
Use cases

MCP Servers overview

# STRING MCP Server

Exposes [STRING database](https://string-db.org) functionality as a **Model Context Protocol (MCP)** server.  

This implementation allows AI agents and other MCP-compatible clients to access STRING data through a structured and self-describing interface.

It is built on top of the STRING API but adapted specifically for model-based use, with emphasis on conciseness and context efficiency. The server controls the amount and type of data so that responses stay within the reasoning limits of large language models. It also adapts the structure and adds metadata to support more consistent parsing and interpretation by agentic systems.

The server is also available as a hosted remote MCP endpoint at [https://mcp.string-db.org](https://mcp.string-db.org).

For a live demonstration of MCP capabilities, see [STRING Chat](https://string-db.org/cgi/chat).

For reproducible workflows and large-scale integration, use the [STRING API](https://string-db.org/cgi/help?subpage=api).

For agentic STRING workflows, use the optional Agent Skill at [skills/string-database/SKILL.md](skills/string-database/SKILL.md).

## Features

- Resolve protein identifiers to STRING metadata
- Retrieve interaction networks
- Cluster and visualize interaction networks
- Perform homology lookups across species
- Access evidence links for protein–protein interactions
- Run functional enrichment analysis (including enrichment plots)
- Get curated functional annotations for proteins
- Query proteins by function or disease (GO, KEGG, Reactome, DISEASES etc.)

---

## Requirements

- **Python** ≥ 3.10  
- Dependencies (see `requirements.txt`):
  - `fastmcp==2.10.6`
  - `httpx==0.28.1`
  - `pydantic==2.11.7`

> **Note:** If the server crashes on startup, it is very likely due to an incompatible **FastMCP** version.

---

## Configuration

The server reads settings from `config/server.config` (JSON). Example:

```json
{
  "base_url": "https://string-db.org",
  "server_port": 57416,
  "verbosity": "low"
}
```

## Installation

```bash
git clone https://github.com/meringlab/string-mcp.git
cd string-mcp
pip install -r requirements.txt
```

## Running 

```
python server.py
```

## Testing

   ```bash
   curl -v -H "Accept: text/event-stream" http://localhost:[port]/mcp
   ```

You should see a `200 OK` response with `content-type: text/event-stream`. 

**Note:** HTTP requests sent with default headers will trigger `anyio.ClosedResourceError` and `406 Not Acceptable`. This is expected behavior for the MCP streaming protocol and does not indicate a problem.

## Docker

1. Ensure you have a `config/server.config` file (copy from `config/server.config.example` if needed):
   ```bash
   cp config/server.config.example config/server.config
   ```

2. Build the image:
   ```bash
   docker build -t string-mcp .
   ```

3. Run the container:
   
   **Linux/macOS:**
   ```bash
   docker run -p 57416:57416 -v $(pwd)/config:/app/config:ro string-mcp
   ```
   
   **Windows PowerShell:**
   ```powershell
   docker run -p 57416:57416 -v ${PWD}/config:/app/config:ro string-mcp
   ```
   
   **Windows Command Prompt:**
   ```cmd
   docker run -p 57416:57416 -v %cd%/config:/app/config:ro string-mcp
   ```

   To run in detached mode:
   ```bash
   # Linux/macOS
   docker run -d -p 57416:57416 -v $(pwd)/config:/app/config:ro --name string-mcp-server string-mcp
   
   # Windows PowerShell
   docker run -d -p 57416:57416 -v ${PWD}/config:/app/config:ro --name string-mcp-server string-mcp
   ```

   The `-v` flag mounts your local config directory so you can customize settings without rebuilding the image.
   
   **Note:** If you don't need to modify the config, you can omit the volume mount and the container will use the default config from the image.

4. Stop the container (if running in detached mode):
   ```bash
   docker stop string-mcp-server
   docker rm string-mcp-server
   ```

**Note:** The Docker container will use the configuration from `config/server.config`. If this file doesn't exist, the container will copy from `server.config.example` on first run.


## License / Citation

The STRING MCP server source code is released under the [MIT License](https://opensource.org/licenses/MIT).  
Associated data and outputs are released under the [CC BY 4.0 License](https://creativecommons.org/licenses/by/4.0/).  
You are free to use, share, and modify the code with proper attribution.

If you use this code or data in your work, please also cite the latest [STRING manuscript](https://string-db.org/cgi/about?footer_active_subpage=references).

What people ask about string-mcp

What is meringlab/string-mcp?

+

meringlab/string-mcp is mcp servers for the Claude AI ecosystem. STRING MCP server It has 5 GitHub stars and was last updated today.

How do I install string-mcp?

+

You can install string-mcp by cloning the repository (https://github.com/meringlab/string-mcp) or following the README instructions on GitHub. ClaudeWave also provides quick install blocks on this page.

Is meringlab/string-mcp safe to use?

+

meringlab/string-mcp has not been audited yet by our security agent. Review the original repository on GitHub before using it in production.

Who maintains meringlab/string-mcp?

+

meringlab/string-mcp is maintained by meringlab. The last recorded GitHub activity is from today, with 0 open issues.

Are there alternatives to string-mcp?

+

Yes. On ClaudeWave you can browse similar mcp servers at /categories/mcp, sorted by popularity or recent activity.

Deploy string-mcp to your cloud

Ship this repo to production in minutes. Each platform spins up its own environment with editable env vars.

Maintain this repo? Add a badge to your README

Drop the badge into your GitHub README to show it's tracked on ClaudeWave. Each badge links back to this page and reflects the live Trust Score.

Featured on ClaudeWave: meringlab/string-mcp
[![Featured on ClaudeWave](https://claudewave.com/api/badge/meringlab-string-mcp)](https://claudewave.com/repo/meringlab-string-mcp)
<a href="https://claudewave.com/repo/meringlab-string-mcp"><img src="https://claudewave.com/api/badge/meringlab-string-mcp" alt="Featured on ClaudeWave: meringlab/string-mcp" width="320" height="64" /></a>

More MCP Servers

string-mcp alternatives