An open API service indexing awesome lists of open source software.

https://github.com/benhaotang/mcp-serverman

a cli/mcp server tool for managing mcp server json config file with version control, profiles and multi-client support
https://github.com/benhaotang/mcp-serverman

claude mcp mcp-server

Last synced: 6 months ago
JSON representation

a cli/mcp server tool for managing mcp server json config file with version control, profiles and multi-client support

Awesome Lists containing this project

README

          

# mcp-serverman: A MCP Server Configuration Manager

[![PyPI - Version](https://img.shields.io/pypi/v/mcp-serverman)](https://pypi.org/project/mcp-serverman/) [![PyPI - Downloads](https://img.shields.io/pypi/dm/mcp-serverman)](https://pypi.org/project/mcp-serverman/) ![](https://badge.mcpx.dev 'MCP') ![](https://badge.mcpx.dev?type=server&features=tools 'MCP server with features') ![PyPI - License](https://img.shields.io/pypi/l/mcp-serverman)

A command-line tool to manage Claude MCP servers configuration with version control and profiling. Now also has a companion mcp server to let llms config for you.

> [!IMPORTANT]
> I always recommend making a manual backup of the mcp configuration before making any changes. Although I tried to cover some error handling in the code, it is definitely not inclusive.

## :floppy_disk:Installation

```bash
pip install mcp-serverman
```
or from GitHub for the latest debug version:
```bash
pip install git+https://github.com/benhaotang/mcp-serverman.git
```
Should be available on Windows, Linux(tested) and MacOS. If the path for a certain platform is wrong, open an issue.

## :computer: Cli usage

After installation, you can use the `mcp-serverman` command directly in terminal:

```bash
# Display help message
mcp-serverman
# Initialize Client configuration(one time and must be done before using other commands, since 0.1.9)
mcp-serverman client init
# List servers
mcp-serverman list
mcp-serverman list --enabled
# Enable/disable/remove server/server version
mcp-serverman enable
mcp-serverman disable
mcp-serverman remove
# Version control
mcp-serverman save --comment
mcp-serverman change --version
# Preset/Profile management
mcp-serverman preset save
mcp-serverman preset load
mcp-serverman preset delete
# Multiple client support(since 0.1.9)
mcp-serverman client list
mcp-serverman client add --name "Display Name" --path "/path/to/config.json" --key "mcpServers" [--default]
mcp-serverman client remove
mcp-serverman client modify --default
mcp-serverman client copy --from --to --merge
# Register companion mcp server to let Claude/LLM manage for you(since 0.2.1)
mcp-serverman companion [--client ]
```

For detailed usage instructions, see the [manual](https://github.com/benhaotang/mcp-serverman/blob/main/Manual.md).

## :robot: Install as a mcp server

```
# Install companion (since 0.2.1)
mcp-serverman companion [--client ]
```

Example:
- What mcp servers do I have?
- Disable xxx, xxx server for me.

![image](https://github.com/user-attachments/assets/e660aa11-73af-421b-9d3b-8dbf78de9a85)

## :wrench:Development

To install the package in development mode, clone the repository and run:

```bash
pip install -e .
```

## :checkered_flag:Roadmap

- [x] Add support for other MCP-Clients, e.g. [Cline](https://github.com/cline/cline) and [MCP-Bridge](https://github.com/SecretiveShell/MCP-Bridge) (since 0.1.9)
- [x] Update the code to be more modular and easier to maintain (since v0.2.0)
- [x] Added our own mcp-server to let Claude/LLM manage for you (since 0.2.1)
- [ ] Better error handling tests
- ~~Integration with other MCP server install tools, e.g. Smithery, or with predefined installation templates (should iron out safety issues first)~~ We have so many mcp marketplaces now, just use [mcp-installer](https://github.com/anaisbetts/mcp-installer) package and instruct the model to install it for you.
- ~~Maybe a Web UI via Flask?~~

## License

MIT License [(LICENSE)](https://github.com/benhaotang/mcp-serverman/blob/main/LICENSE)