Create a custom MCP registry
Overview
ToolHive includes a built-in registry of MCP servers with verified configurations that meet a minimum quality standard.
But you can also create your own custom registry to include the MCP servers that are relevant to your organization or specific use cases. This allows you to curate a list of servers that meet your specific needs.
Why create a custom registry?
Creating a custom registry allows you to:
- Curate a list of MCP servers tailored to your organization's needs
- Include private or internal servers not listed in the public registry
- Pre-configure server settings for easier deployment
- Ensure all servers meet your organization's quality and security standards
Create your first custom registry
In this tutorial, you'll create a custom MCP registry for ToolHive and configure it to use your own curated list of MCP servers. By the end, you'll have a working custom registry that you can extend with your organization's specific MCP servers.
What you'll build
You'll create a JSON registry file containing a simple MCP server entry, configure ToolHive to use your custom registry, and verify it works by listing and running servers from your registry.
Prerequisites
Before you start, make sure you have:
- The ToolHive UI or CLI installed and working on your system
- Basic familiarity with JSON format
- A text editor for creating the registry file
Step 1: Create the registry file
First, create a new directory for your custom registry and navigate to it:
mkdir my-custom-registry
cd my-custom-registry
Create a new file called registry.json and add the following content:
{
  "$schema": "https://raw.githubusercontent.com/stacklok/toolhive/main/pkg/registry/data/schema.json",
  "version": "1.0.0",
  "last_updated": "2025-08-15T10:00:00Z",
  "servers": {
    "my-fetch": {
      "description": "A custom web content fetching MCP server for our organization",
      "image": "ghcr.io/stackloklabs/gofetch/server:latest",
      "status": "Active",
      "tier": "Community",
      "transport": "streamable-http",
      "args": ["--user-agent", "Mozilla/5.0 (compatible;MyOrgFetchBot/1.0)"],
      "tags": ["web", "fetch", "content"],
      "tools": ["fetch"],
      "permissions": {
        "network": {
          "outbound": {
            "allow_host": [".example.com", "api.mycompany.com"],
            "allow_port": [80, 443]
          }
        }
      }
    }
  },
  "groups": [
    {
      "name": "dev-toolkit",
      "description": "Essential MCP servers for development workflows",
      "servers": {
        "fetch-tool": {
          "description": "A web content fetching MCP server for development",
          "image": "ghcr.io/stackloklabs/gofetch/server:latest",
          "status": "Active",
          "tier": "Community",
          "transport": "streamable-http",
          "args": ["--user-agent", "Mozilla/5.0 (compatible;DevBot/1.0)"],
          "tags": ["web", "fetch", "dev"],
          "tools": ["fetch"],
          "permissions": {
            "network": {
              "outbound": {
                "allow_host": [".github.com", ".stackoverflow.com"],
                "allow_port": [80, 443]
              }
            }
          }
        }
      }
    }
  ]
}
This registry contains two types of server configurations:
- A standalone MCP server called my-fetchin the top-levelserverssection
- A group called dev-toolkitcontaining afetch-toolserver
The dev-toolkit group demonstrates how you can organize related servers
together. When you run this group later, you'll be able to start multiple
servers as a single unit—perfect for development workflows or team-specific
toolsets. Notice how the fetch-tool server has a different user agent and
network permissions than my-fetch, showing how you can customize servers
within groups for specific purposes.
Your server configurations include everything ToolHive needs to run them:
- A description explaining its purpose
- The container image to use
- Required metadata like status and tier
- A list of tools it provides
- Command-line arguments for customization
- Network permissions for security
Registry groups are currently supported in the CLI. UI support for browsing and managing registry groups may not be immediately available in all versions.
Step 2: Configure ToolHive to use your registry
Configure ToolHive to use your custom registry.
- ToolHive UI
- CLI
- Open the ToolHive application
- Navigate to Settings → Registry
- Select the Local Registry option
- Enter the full path to your registry.jsonfile (for example:/Users/<YOUR_NAME>/my-custom-registry/registry.json)
- Click Save to apply the configuration
The UI will validate the registry file and confirm it's been set successfully.
Set the registry file using the full path:
thv config set-registry /Users/<YOUR_NAME>/my-custom-registry/registry.json
Verify the configuration was applied:
thv config get-registry
You should see the path to your registry file displayed.
Step 3: Test your custom registry
Verify your custom registry is working.
- ToolHive UI
- CLI
- Navigate to the Registry page from the menu bar
- You should see your my-fetchserver displayed alongside any other servers in your custom registry
- Click on the server to view its details, including description, tools, and configuration options
List the servers in your custom registry:
thv registry list
You should see your my-fetch server listed. Get detailed information about it:
thv registry info my-fetch
This displays the server's configuration, tools, and permissions as defined in your registry.
Step 4: Run a server from your registry
Finally, run the MCP server from your custom registry.
- ToolHive UI
- CLI
- On the Registry page, click on your my-fetchserver
- Click the Install server button
- Configure any required settings (the defaults from your registry will be pre-populated)
- Click Install server to start the MCP server
- Navigate to the MCP Servers page to see your running server and manage it
The server will appear in your MCP servers list, where you can start, stop, view logs, and manage it like any other MCP server.
thv run my-fetch
The server should start successfully, demonstrating that your custom registry is working correctly.
Next, run the dev-toolkit group:
thv group run dev-toolkit
This starts all servers in the dev-toolkit group (in this case, just the
fetch-tool server).
Step 5: Add more servers (optional)
You can extend your registry by adding more servers to the servers object. For
example, add a second server (note this is just an example, it will not function
if you try to run it):
{
  "$schema": "https://raw.githubusercontent.com/stacklok/toolhive/main/pkg/registry/data/schema.json",
  "version": "1.0.0",
  "last_updated": "2025-08-15T10:00:00Z",
  "servers": {
    "my-fetch": {
      // ... existing server configuration
    },
    "company-tools": {
      "description": "Internal company tools and utilities MCP server",
      "image": "registry.company.com/mcp/company-tools:v1.2.0",
      "status": "Active",
      "tier": "Community",
      "transport": "stdio",
      "tools": ["get_employee_info", "create_ticket", "check_inventory"],
      "tags": ["internal", "company", "tools"],
      "env_vars": [
        {
          "name": "COMPANY_API_KEY",
          "description": "API key for accessing company internal services",
          "required": true,
          "secret": true
        }
      ]
    }
  }
}
After updating the file, the new server is immediately available for ToolHive CLI commands. For the UI, navigate to the registry settings and click Save to see the new server listed.
Production considerations
While this tutorial uses a local file for simplicity, in production environments you should:
- Host your registry on a secure HTTP server
- Use version control to track changes to your registry
- Implement proper access controls to prevent unauthorized modifications
- Set up automated validation to ensure registry entries follow the schema
- Regularly update the registry with new servers and remove deprecated ones
For production use, configure ToolHive to use a remote registry URL:
thv config set-registry https://registry.example.com/mcp-registry.json
What you've learned
You've successfully:
- Created a custom MCP registry following the JSON schema
- Configured ToolHive to use your custom registry
- Added MCP servers with proper metadata and permissions
- Created groups to organize related servers
- Tested your registry by listing and running both individual servers and groups
You can now maintain your own curated list of MCP servers and groups tailored to your organization's needs, organized into logical groups for different teams or workflows. The registry can include both public servers from container registries and private servers hosted within your organization.
Next steps
- Explore the full schema reference to understand all available configuration options
- Learn about custom permissions for fine-grained security control
- Set up secrets management for servers requiring API keys
Cleanup: Revert to the default registry
If you want to switch back to using ToolHive's built-in registry after completing this tutorial, you can easily revert your configuration.
- ToolHive UI
- CLI
To revert to the default registry through the UI:
- Navigate to Settings → Registry
- Select the Default Registry option
- Click Save to apply the configuration
The UI will confirm that you're now using the built-in ToolHive registry.
To revert to the default registry using the CLI:
thv config unset-registry
Verify that you're back to using the default registry:
thv config get-registry
You should see a message indicating that the built-in registry is being used.
After reverting, all registry commands
(thv registry list,
thv registry info,
thv search) will use ToolHive's built-in
registry instead of your custom one.