Run MCP servers
ToolHive makes it easy to run and manage Model Context Protocol (MCP) servers. This guide walks you through installing MCP servers from the registry, using Docker images, or from source packages.
Install from the registry
ToolHive includes a built-in registry of MCP servers that meet a minimum quality standard, allowing you to discover and deploy high-quality tools effortlessly. Simply select one from the list to run it securely with just a few clicks.
Select an MCP server
To install an MCP server (local 
or remote  
 ) from the registry:
- Open the Registry page from the menu bar.
- Browse or search for the MCP server you want to install.
- Click on the desired MCP server to open its details page. Here you can review
more information about the server like its:
- Description
- Available tools
- Tier (community or official)
- Popularity (GitHub stars)
- A link to the GitHub repository for more details and usage documentation
 
- Click the Install server button to start the installation process.
Configure the server
- Local MCP 
- Remote MCP 
Local MCP servers run directly on your machine using your container runtime.
The configuration form is pre-filled with defaults from the registry. Enter the remaining required information and adjust any optional settings as needed:
- 
Server name: A unique name for the MCP server. 
 This defaults to the MCP server's name in the registry. If you want to run multiple instances of the same MCP server, give each instance a unique name.
- 
Group: The group where this server will be added. [Optional] 
 Select an existing group or keep the default. Groups help you organize servers and control client access. See Organize servers with groups for details.
- 
Command arguments (optional): 
 Enter any command-line arguments needed to run the MCP server. These might be needed to pass application-specific parameters to the MCP server. Refer to the MCP server's documentation for details.infoWe've made every effort to include sensible defaults in the registry for a one-click experience, but some servers may require additional command-line arguments to function correctly. 
- 
Storage volumes [Optional]: 
 Map files or folders from your local host to the MCP server. See Mount host files and folders. [Optional]
- 
Secrets and environment variables expected by the server are populated from the registry automatically. Required values are marked with an asterisk (*). - Secrets: Enter a value to create a new secret or select an existing secret to map to the environment variable. Secrets are stored securely and can be used by the MCP server without exposing them in plaintext.
- Environment variables: Enter the value in the input field alongside the variable name. These are typically used for configuration options that do not require sensitive data.
 
- 
Network isolation [Optional]: 
 Enable network isolation to restrict the MCP server's network access. This enhances security by limiting the server's ability to communicate with external networks. See the Network isolation guide for details.
Refer to the MCP server's documentation for the required configuration information, permissions, and authentication details. A link to the GitHub repository is provided on each server's details page.
Start the MCP server
Click Install server to install and start the MCP server. ToolHive downloads the Docker image, creates a container, and starts it with the specified configuration.
Once the server is running, you can see its status on the MCP Servers page. Each server's card includes:
- The server name
- Its status (Running or Stopped) with a toggle button to start or stop it
- A menu (︙) that includes the server's URL for AI clients that need manual
configuration, and options to:
- Open the server's GitHub repository
- View the server's logs
- Remove the server
 
See Manage MCP servers below for more details on server states.
Install a custom MCP server
You're not limited to the MCP servers in the registry. You can run remote MCP servers by providing a URL, or your own local custom MCP servers using Docker images or source packages.
Configure the server
- Custom local MCP 
- Custom remote MCP 
On the MCP Servers page, click Add an MCP server, then choose Add custom local server in the drop-down menu. Or if this is your first MCP server, on the introductory screen.
In the Custom MCP server dialog, choose Docker image or Package manager.
From a Docker image
Select the Docker image option. This allows you to run any MCP server that is available as a Docker image in a remote registry or locally on your system.
On the configuration form, enter:
- 
A unique name for the MCP server. [Required] 
- 
Group: The group where this server will be added. [Optional] 
 Select an existing group or keep the default. Groups help you organize servers and control client access. See Organize servers with groups for details.
- 
The transport protocol that the MCP server uses. [Required] 
 ToolHive supports standard input/output (stdio), server-sent events (SSE), and Streamable HTTP. The protocol must match what the MCP server supports.
- 
The target port to expose from the container (SSE or Streamable HTTP transports only). [Optional] 
 If the MCP server uses a specific port, enter it here. If not specified, ToolHive will use a random port that is exposed to the container with theMCP_PORTandFASTMCP_PORTenvironment variables.
- 
The Docker image name and tag (e.g., my-mcp-server:latest). [Required]
 You can use any valid Docker image, including those hosted on Docker Hub or other registries.
- 
Command-line arguments needed to run the MCP server. [Optional] 
 These are specific to the MCP server and might include transport options or application-specific parameters. Refer to the MCP server's documentation for details.
- 
Any secrets or environment variables required by the MCP server. [Optional] 
 These might include API tokens, configuration options, or other sensitive data.- Secrets are mapped to an environment variable. Enter the variable name and select an existing secret or enter a value to create a new one.
- For non-sensitive environment variables, enter the name and value directly.
 
- 
Storage volumes [Optional]: 
 Map files or folders from your local host to the MCP server. See Mount host files and folders. [Optional]
- 
Network isolation [Optional]: 
 Enable network isolation to restrict the MCP server's network access. This enhances security by limiting the server's ability to communicate with external networks. See the Network isolation guide for details.
Click Install server to create and start the MCP server container.
From a source package
Select the Package manager option. This allows you to run an MCP server from a source package.
ToolHive downloads the MCP server's source package and builds a Docker image on-the-fly. The following package formats are supported:
- Node.js-based MCP servers using npm
- Python-based MCP servers available on PyPI, using the uvpackage manager
- Go-based MCP servers available on GitHub
On the configuration form, enter:
- 
A unique name for the MCP server. [Required] 
- 
Group: The group where this server will be added. [Optional] 
 Select an existing group or keep the default. Groups help you organize servers and control client access. See Organize servers with groups for details.
- 
The transport protocol that the MCP server uses. [Required] 
 ToolHive supports standard input/output (stdio), server-sent events (SSE), and Streamable HTTP. The protocol must match what the MCP server supports.
- 
The target port to expose from the container (SSE or Streamable HTTP transports only). [Optional] 
 If the MCP server uses a specific port, enter it here. If not specified, ToolHive will use a random port that is exposed to the container with theMCP_PORTandFASTMCP_PORTenvironment variables.
- 
The package protocol ( npx,uvx, orgo). [Required]
- 
The name of the package to run. [Required] 
- 
Command-line arguments needed to run the MCP server. [Optional] 
 These are specific to the MCP server and might include transport options or application-specific parameters. Refer to the MCP server's documentation for details.
- 
Any secrets or environment variables required by the MCP server. [Optional] 
 These might include API tokens, configuration options, or other sensitive data.- Secrets are mapped to an environment variable. Enter the variable name and select an existing secret or enter a value to create a new one.
- For non-sensitive environment variables, enter the name and value directly.
 
- 
Storage volumes [Optional]: 
 Map files or folders from your local host to the MCP server. See Mount host files and folders. [Optional]
- 
Network isolation [Optional]: 
 Enable network isolation to restrict the MCP server's network access. This enhances security by limiting the server's ability to communicate with external networks. See the Network isolation guide for details.
Click Install server to create and start the MCP server container.
Mount host files and folders
Some MCP servers need access to files on your machine. You can mount host paths directly in the UI.
- In the server Install / Configure dialog, scroll to Storage volumes.
- Use the first row to create your mount:
- Host path — choose a file or folder on your computer.
- Container path — where it should appear inside the server (for example,
/data).
- By default, mounts are in read-write mode. If you want your volume mount to be Read-only, select the "Read-only access" option from the drop-down.
 
- If you need additional mounts, click Add a volume and repeat.
- Click Install server to start the server with your volume(s).
This applies to both registry-installed servers and custom servers (Docker image or source package).
Manage MCP servers
On the MCP Servers page, you can manage your installed MCP servers:
- Start/Stop: Use the toggle button to start or stop the MCP server. When you stop a server, it remains in the list but is no longer running. ToolHive removes the server from connected AI clients while stopped.
- Copy URL: Click the menu (︙) on the server card and select the Copy icon (⧉) to copy the MCP server's URL to your clipboard. This URL is used by AI clients to connect to the MCP server.
- Edit configuration: Click the menu (︙) on the server card and select Edit configuration to open a dialog where you can modify the server's settings, such as command arguments, environment variables, secrets, storage volumes, and network isolation. The dialog is pre-filled with your existing configuration, so you only need to change the specific settings you want to update.
- View logs: Click the menu (︙) on the server card and select View logs to see the server's output.
- Copy server to a group: Click the menu (︙) on the server card and select Copy server to a group to duplicate the server configuration to a different group. See Organize servers with groups for details.
- Remove server: Click the menu (︙) on the server card and select Remove server to stop and remove the MCP server from ToolHive. This deletes the container and any associated configuration, so use with caution.
When you quit the application, ToolHive prompts you to stop all running MCP servers. The running servers are recorded and ToolHive restarts them automatically the next time you launch the application.
Next steps
- Connect ToolHive to AI clients like GitHub Copilot or Cursor using the client configuration guide.
- Learn more about secrets management to securely manage API tokens and other sensitive data.
- Test your MCP servers using the playground to validate functionality and behavior with different models.