by nacos-group
Provides search, installation, and proxy functionalities for MCP servers, combining Nacos service discovery with optional Compass API support and offering both router and proxy operating modes.
Enables discovery and utilization of MCP servers through powerful search capabilities, automatic installation of stdio or SSE servers, and proxying of these services via HTTP. It operates in two modes: router (default) for recommendation, distribution, and installation, and proxy for converting SSE/stdio MCP servers into streamable HTTP endpoints.
NACOS_ADDR, NACOS_USERNAME, and NACOS_PASSWORD.uvx nacos-mcp-router@latestpip install nacos-mcp-router && python -m nacos_mcp_routerdocker run -i --rm --network host -e NACOS_ADDR=$NACOS_ADDR -e NACOS_USERNAME=$NACOS_USERNAME -e NACOS_PASSWORD=$NACOS_PASSWORD -e TRANSPORT_TYPE=$TRANSPORT_TYPE nacos/nacos-mcp-router:latestserverConfig section.COMPASS_API_BASE, SEARCH_MIN_SIMILARITY, SEARCH_RESULT_LIMIT, TRANSPORT_TYPE, MODE, etc., via environment variables.searchMcpServer("Find MCP servers for NLP", ["nlp","language"]) to retrieve matching servers and their tools.MODE=proxy).search_mcp_server, add_mcp_server, and use_tool for LLM agents.npx).Q: Do I need a Compass API key?
A: No key is required for the default endpoint https://registry.mcphub.io; you can override it with COMPASS_API_BASE.
Q: What transport protocols are supported?
A: stdio, sse, and streamable_http. Set TRANSPORT_TYPE accordingly.
Q: How do I switch to proxy mode?
A: Set MODE=proxy and provide PROXIED_MCP_NAME (the target server registered in Nacos).
Q: Can I limit the number of search results?
A: Yes, using SEARCH_RESULT_LIMIT.
Q: Which environment variables are mandatory?
A: NACOS_PASSWORD is required; NACOS_ADDR and NACOS_USERNAME have defaults.
Nacos is an easy-to-use platform designed for dynamic service discovery and configuration and service management. It helps you to build cloud native applications and microservices platform easily.
This MCP(Model Context Protocol) Server provides tools to search, install, proxy other MCP servers, with advanced search capabilities including vector similarity search and multi-provider result aggregation.
Nacos-MCP-Router has two working modes:
Router mode: The default mode, which recommends, distributes, installs, and proxies the functions of other MCP Servers through the MCP Server, helping users more conveniently utilize MCP Server services.
Proxy mode: Specified by the environment variable MODE=proxy, it can convert SSE and stdio protocol MCP Servers into streamable HTTP protocol MCP Servers through simple configuration.
Nacos-MCP-Router provides powerful search capabilities through multiple providers:
Nacos Provider
Compass Provider
Configure search behavior using environment variables:
# YOUR COMPASS API endpoint (for Outer Provider called Compass Provider)
COMPASS_API_BASE=https://registry.mcphub.io
# Minimum similarity score for results (0.0 to 1.0)
SEARCH_MIN_SIMILARITY=0.5
# Maximum number of results to return
SEARCH_RESULT_LIMIT=10
The search functionality is available through the MCP interface:
// Search for MCP servers
const results = await searchMcpServer(
  "Find MCP servers for natural language processing",
  ["nlp", "language"]
);
Results include:
Tools
search_mcp_server
task_description(string): Task descriptionkey_words(string): Keywords of taskadd_mcp_server
mcp_server_name(string): The name of MCP server.use_tool
mcp_server_name(string): The target MCP server name that LLM wants to call.mcp_tool_name(string): The tool name of target MCP server that LLM wants to call.params(map): The parameters of the MCP tool.Usage
Using uv (recommended)
When using uv no specific installation is needed. We will
use uvx to directly run nacos-mcp-router.
export NACOS_ADDR=127.0.0.1:8848
export NACOS_USERNAME=nacos
export NACOS_PASSWORD=$PASSWORD
uvx nacos-mcp-router@latest
Using PIP
Alternatively you can install nacos-mcp-router via pip:
pip install nacos-mcp-router
After installation, you can run it as a script using(As an example,Nacos is deployed in standalone mode on the local machine):
export NACOS_ADDR=127.0.0.1:8848
export NACOS_USERNAME=nacos
export NACOS_PASSWORD=$PASSWORD
python -m nacos_mcp_router
Using Docker
docker run -i --rm --network host -e NACOS_ADDR=$NACOS_ADDR -e NACOS_USERNAME=$NACOS_USERNAME -e NACOS_PASSWORD=$NACOS_PASSWORD -e TRANSPORT_TYPE=$TRANSPORT_TYPE nacos/nacos-mcp-router:latest
Usage with Cline、Cursor、Claude and other applications
Add this to MCP settings of your application:
{
    "mcpServers":
    {
        "nacos-mcp-router":
        {
            "command": "uvx",
            "args":
            [
                "nacos-mcp-router@latest"
            ],
            "env":
            {
                "NACOS_ADDR": "<NACOS-ADDR>, optional, default is 127.0.0.1:8848",
                "NACOS_USERNAME": "<NACOS-USERNAME>, optional, default is nacos",
                "NACOS_PASSWORD": "<NACOS-PASSWORD>, required"
            }
        }
    }
}
You may need to put the full path to the
uvxexecutable in thecommandfield. You can get this by runningwhich uvxon MacOS/Linux orwhere uvxon Windows.
{
  "mcpServers": {
    "nacos-mcp-router": {
      "command": "docker",
      "args": [
        "run", "-i", "--rm", "--network", "host",  "-e", "NACOS_ADDR=<NACOS-ADDR>", "-e",  "NACOS_USERNAME=<NACOS-USERNAME>", "-e", "NACOS_PASSWORD=<NACOS-PASSWORD>" ,"-e", "TRANSPORT_TYPE=stdio", "nacos/nacos-mcp-router:latest"
      ]
    }
  }
}
The proxy mode supports converting SSE and stdio protocol MCP Servers into streamable HTTP protocol MCP Servers.
Usage
The usage of proxy mode is similar to that of router mode, with slightly different parameters. Docker deployment is recommended.
docker run -i --rm --network host -e NACOS_ADDR=$NACOS_ADDR -e NACOS_USERNAME=$NACOS_USERNAME -e NACOS_PASSWORD=$NACOS_PASSWORD -e TRANSPORT_TYPE=streamable_http -e MODE=proxy -e PROXIED_MCP_NAME=$PROXIED_MCP_NAME  nacos/nacos-mcp-router:latest
| Parameter | Description | Default Value | Required | Remarks | 
|---|---|---|---|---|
| NACOS_ADDR | Nacos server address | 127.0.0.1:8848 | No | the Nacos server address, e.g., 192.168.1.1:8848. Note: Include the port. | 
| NACOS_USERNAME | Nacos username | nacos | No | the Nacos username, e.g., nacos. | 
| NACOS_PASSWORD | Nacos password | - | Yes | the Nacos password, e.g., nacos. | 
| COMPASS_API_BASE | COMPASS API endpoint for enhanced search | https://registry.mcphub.io | No | Override the default COMPASS API endpoint | 
| SEARCH_MIN_SIMILARITY | Minimum similarity score (0.0-1.0) | 0.5 | No | Filter search results by minimum similarity score | 
| SEARCH_RESULT_LIMIT | Maximum number of results to return | 10 | No | Limit the number of search results | 
| NACOS_NAMESPACE | Nacos Namespace | public | No | Nacos namespace, e.g. public | 
| TRANSPORT_TYPE | Transport protocol type | stdio | No | transport protocol type. Options: stdio, sse, streamable_http. | 
| PROXIED_MCP_NAME | Proxied MCP server name | - | No | In proxy mode, specify the MCP server name to be converted. Must be registered in Nacos first. | 
| MODE | Working mode | router | No | Available options: router, proxy. | 
| PORT | Service port when TRANSPORT_TYPE is sse or streamable_http | 8000 | No | |
| ACCESS_KEY_ID | Aliyun ram access key id | - | No | |
| ACCESS_KEY_SECRET | Aliyun ram access key secret | - | No | 
{
  "mcpServers": {
    "nacos-mcp-router": {
      "command": "npx",
      "args": [
        "nacos-mcp-router@latest"
      ],
      "env": {
        "NACOS_ADDR": "<NACOS-ADDR>, optional, default is 127.0.0.1:8848",
        "NACOS_USERNAME": "<NACOS-USERNAME>, optional, default is nacos",
        "NACOS_PASSWORD": "<NACOS-PASSWORD>, required"
      }
    }
  }
}
nacos-mcp-router is licensed under the Apache 2.0 License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the Apache 2.0 License. For more details, please see the LICENSE file in the project repository.
Please log in to share your review and rating for this MCP.
{
  "mcpServers": {
    "nacos-mcp-router": {
      "command": "npx",
      "args": [
        "nacos-mcp-router@latest"
      ],
      "env": {
        "NACOS_ADDR": "<NACOS-ADDR>",
        "NACOS_USERNAME": "<NACOS-USERNAME>",
        "NACOS_PASSWORD": "<NACOS-PASSWORD>",
        "COMPASS_API_BASE": "https://registry.mcphub.io",
        "SEARCH_MIN_SIMILARITY": "0.5",
        "SEARCH_RESULT_LIMIT": "10",
        "NACOS_NAMESPACE": "public",
        "TRANSPORT_TYPE": "stdio",
        "MODE": "router",
        "PORT": "8000"
      }
    }
  }
}claude mcp add nacos-mcp-router npx nacos-mcp-router@latestExplore related MCPs that share similar capabilities and solve comparable challenges
by exa-labs
Provides real-time web search capabilities to AI assistants via a Model Context Protocol server, enabling safe and controlled access to the Exa AI Search API.
by perplexityai
Enables Claude and other MCP‑compatible applications to perform real‑time web searches through the Perplexity (Sonar) API without leaving the MCP ecosystem.
by MicrosoftDocs
Provides semantic search and fetch capabilities for Microsoft official documentation, returning content in markdown format via a lightweight streamable HTTP transport for AI agents and development tools.
by elastic
Enables natural‑language interaction with Elasticsearch indices via the Model Context Protocol, exposing tools for listing indices, fetching mappings, performing searches, running ES|QL queries, and retrieving shard information.
by graphlit
Enables integration between MCP clients and the Graphlit platform, providing ingestion, extraction, retrieval, and RAG capabilities across a wide range of data sources and connectors.
by mamertofabian
Fast cross‑platform file searching leveraging the Everything SDK on Windows, Spotlight on macOS, and locate/plocate on Linux.
by cr7258
Provides Elasticsearch and OpenSearch interaction via Model Context Protocol, enabling document search, index management, cluster monitoring, and alias operations.
by kagisearch
Provides web search and video summarization capabilities through the Model Context Protocol, enabling AI assistants like Claude to perform queries and summarizations.
by liuyoshio
Provides natural‑language search and recommendation for Model Context Protocol servers, delivering rich metadata and real‑time updates.