Skip to main content

A simple Nacos MCP Server

Project description

mcp-server-nacos: A Nacos MCP server

Overview

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 is for Nacos interaction and automation. This server provides tools to search and read namespace, service and configuration relative information in Nacos Cluster via Large Language Models.

Please note that mcp-server-nacos is currently in early development. The functionality and available tools are subject to change and expansion as we continue to develop and improve the server. And also note that mcp-server-nacos only provide read, search and list operation, not support any write operation for current version. Write operation is planning supported in future versions.

One more note that this mcp-server-nacos required version:

1. Nacos version required upper `3.0.0`, because of depended on the [Nacos Admin API](https://nacos.io/en/swagger/admin/) in 3.x.
2. python version required 3.x, recommend upper `3.13`.

Tools

  1. list_namespaces
    • Retrieves the list of namespaces in the current Nacos cluster.
    • Input:
      • None
    • Returns: list of namespaces in the current Nacos cluster.
  2. list_services
    • This tool retrieves the list of services under a specified namespace. The response format depends on the withInstances parameter:withInstances=true: Returns service details with instances (ServiceDetailInfo objects). withInstances=false: Returns service metadata without instances (ServiceView objects). **NOTE: ** When withInstances=true, The API may cost too much memory and networks, If Only want get instance list with little or one service, Suggest use withInstances=false with List Service Instances.
    • Input:
      • pageNo(number): The current page number, default is 1.
      • pageSize(number): The size of services in each page, default is 100.
      • namespaceId(string, optional): The namespaceId of services, default is public if missing.
      • groupNameParam(string, optional): The groupName pattern of services, default null means all group if missing.
      • serviceNameParam(string, optional): The serviceName pattern of services, default null means all service if missing.
      • ignoreEmptyService(bool, optional): Whether ignore the empty service in result, default is true.
      • withInstances(bool, optional): Whether contain instances under each services in result, recommend and default is false.
    • Returns: list of services under a specified namespace.
  3. get_service
    • This tool retrieves detailed information of a specified service, including metadata and clusters, not including instance list.
    • Input:
      • namespaceId(string, optional): The namespaceId of services, default is public if missing.
      • groupName(string, optional): The groupName pattern of services, default is DEFAULT_GROUP if missing.
      • serviceName(string): The serviceName pattern of services, required.
    • Returns: detailed information of a specified service.
  4. list_service_instances
    • This tool retrieves the list of instances for a specified service.
    • Input:
      • namespaceId(string, optional): The namespaceId of services, default is public if missing.
      • groupName(string, optional): The groupName pattern of services, default is DEFAULT_GROUP if missing.
      • serviceName(string): The serviceName pattern of services, required.
      • clusterName(string, optional): The cluster name of instances in service, optional and default is null means match all cluster.
    • Returns: list of instances for a specified service.
  5. list_service_subscribers
    • This tool retrieves the list of subscribers for a specified service.
    • Input:
      • pageNo(number): The current page number, default is 1.
      • pageSize(number): The size of service subscribers in each page, default is 100.
      • namespaceId(string, optional): The namespaceId of services, default is public if missing.
      • groupName(string, optional): The groupName pattern of services, default is DEFAULT_GROUP if missing.
      • serviceName(string): The serviceName pattern of services, required.
      • aggregation(bool, optional): Whether aggregation from whole cluster.
    • Returns: list of subscribers for a specified service.
  6. list_configs
    • This tool retrieves the list of configurations under a specified namespace.
    • Input:
      • pageNo(number): The current page number, default is 1.
      • pageSize(number): The size of configs in each page, default is 100.
      • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
      • groupName(string, optional): The groupName pattern of configs, default null means all group.
      • dataId(string, optional): The dataId pattern of configs, default null means all dataId.
      • type(string, optional): The type of configs, default null means all type.
      • configTags(string, optional): The tags of configs, default null means all tags.
      • appName(string, optional): The appName of configs, default null means all appName.
      • search(string, optional): The search way of list configs, default is blur, optional value accurate.
    • Returns: list of configurations under a specified namespace.
  7. get_config
    • retrieves the details of the specified configuration.
    • Input:
      • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
      • groupName(string): The groupName of config, Required.
      • dataId(string): The dataId of config, Required.
    • Returns: the details of the specified configuration.
  8. list_config_history
    • This tool retrieves the complete publish history of a configuration.
    • Input:
      • pageNo(number): The current page number, default is 1.
      • pageSize(number): The size of config history records in each page, default is 100.
      • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
      • groupName(string): The groupName of config, Required.
      • dataId(string): The dataId of config, Required.
    • Returns: list of configurations under a specified namespace.
  9. get_config_history
    • retrieves a specific historical change record of a configuration.
    • Input:
      • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
      • groupName(string): The groupName of config, Required.
      • dataId(string): The dataId of config, Required.
      • nid(number): the actual id of config history record, Get from list config history tool, id field.
    • Returns: historical change record of a configuration.
  10. list_config_listeners
  • retrieves the list of listeners subscribed to a specific configuration.
  • Input:
    • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
    • groupName(string): The groupName of config, Required.
    • dataId(string): The dataId of config, Required.
    • aggregation(bool, optional): Whether aggregation from whole cluster.
  • Returns: list of listeners subscribed to a specific configuration.
  1. list_listened_configs
  • retrieves lists the configurations subscribed to by a specific client IP address.
  • Input:
    • namespaceId(string, optional): The namespaceId of configs, default is public if missing.
    • ip(string): The client ip of config listeners, Required.
    • aggregation(bool, optional): Whether aggregation from whole cluster.
  • Returns: lists the configurations subscribed to by a specific client IP address.

Installation

Using uv (recommended)

When using uv no specific installation is needed. We will use uvx to directly run mcp-server-nacos.

Using PIP

Alternatively you can install mcp-server-nacos via pip:

pip install mcp-server-nacos

After installation, you can run it as a script using:

python -m mcp_server_nacos

Configuration

Usage with Claude Desktop

Add this to your claude_desktop_config.json:

Using uvx
"mcpServers": {
  "git": {
    "command": "uvx",
    "args": [
        "nacos-mcp-server",
        "--host",
        "your_nacos_host",
        "--port",
        "your_nacos_main_port, such as 8848",
        "--access_token",
        "your_nacos_access_token, get from `login` api: /nacos/v3/auth/user/login with `username` and `password`"
      ],
  }
}

You may need to put the full path to the uvx executable in the command field. You can get this by running which uvx on MacOS/Linux or where uvx on Windows.

Using pip installation
"mcpServers": {
  "git": {
    "command": "python",
        "args": [
        "-m",
        "nacos-mcp-server",
        "--host",
        "your_nacos_host",
        "--port",
        "your_nacos_main_port, such as 8848",
        "--access_token",
        "your_nacos_access_token, get from `login` api: /nacos/v3/auth/user/login with `username` and `password`"
      ],
  }
}

Development

If you are doing local development, simply follow the steps:

  1. Clone this repo into your local environment.
  2. Modify codes in src/mcp_server_nacos to implement your wanted features.
  3. Test using the Claude desktop app. Add the following to your claude_desktop_config.json:
{
"mcpServers": {
  "mcp-server-nacos": {
    "command": "uv",
    "args": [ 
      "--directory",
      "/<path to mcp-server-nacos>/src/mcp_server_nacos",
      "run",
      "mcp-server-nacos"
    ]
  }
}

License

mcp-server-nacos 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.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nacos_mcp_server-0.1.2.tar.gz (20.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nacos_mcp_server-0.1.2-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file nacos_mcp_server-0.1.2.tar.gz.

File metadata

  • Download URL: nacos_mcp_server-0.1.2.tar.gz
  • Upload date:
  • Size: 20.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for nacos_mcp_server-0.1.2.tar.gz
Algorithm Hash digest
SHA256 f461bbfbae45494e1ebf859fbcce3512f44a2de7caa747dbe58c5e7b397def68
MD5 9342459e80f44092575bae18a9f5d14f
BLAKE2b-256 7ee08d7e0c578a4f61e00414deaccfc49843e073ec8595790d94d4e21dd76be2

See more details on using hashes here.

File details

Details for the file nacos_mcp_server-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for nacos_mcp_server-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6007b3fa2d574201fbf3f61870789f6850afcaafb94524dc22dc4fe4699899b4
MD5 d49bb834ff6f49fa2a542d4e1377d6e0
BLAKE2b-256 5413f76a31e65dd9766dde5dc6e13ab4d8e942cd228207eff8a9fe07f0dcc4f9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page