New in version: 2.2.0
As your MCP applications grow, you might want to organize your tools, resources, and prompts into logical modules or reuse existing server components. FlashMCP supports composition through two methods:
import_server
: For a one-time copy of components with prefixing (static composition).mount
: For creating a live link where the main server delegates requests to the subserver (dynamic composition).
Why Compose Servers?
- Modularity: Break down large applications into smaller, focused servers (e.g., a
WeatherServer
, aDatabaseServer
, aCalendarServer
). - Reusability: Create common utility servers (e.g., a
TextProcessingServer
) and mount them wherever needed. - Teamwork: Different teams can work on separate FlashMCP servers that are later combined.
- Organization: Keep related functionality grouped together logically.
Importing vs Mounting
The choice of importing or mounting depends on your use case and requirements.Feature | Importing | Mounting |
---|---|---|
Method | FlashMCP.import_server() | FlashMCP.mount() |
Composition Type | One-time copy (static) | Live link (dynamic) |
Updates | Changes to subserver NOT reflected | Changes to subserver immediately reflected |
Best For | Bundling finalized components | Modular runtime composition |
Proxy Servers
FlashMCP supports MCP proxying, which allows you to mirror a local or remote server in a local FlashMCP instance. Proxies are fully compatible with both importing and mounting.New in version: 2.3.6
You can also create proxies from configuration dictionaries that follow the MCPConfig schema, which is useful for quickly connecting to one or more remote servers. See the Proxy Servers documentation for details on configuration-based proxying. Note that MCPConfig follows an emerging standard and its format may evolve over time.
Importing (Static Composition)
Theimport_server()
method copies all components (tools, resources, templates, prompts) from one FlashMCP
instance (the subserver) into another (the main server). A prefix
is added to avoid naming conflicts.
How Importing Works
When you callawait main_mcp.import_server(prefix, subserver)
:
- Tools: All tools from
subserver
are added tomain_mcp
with names prefixed using{prefix}_
.subserver.tool(name="my_tool")
becomesmain_mcp.tool(name="{prefix}_my_tool")
.
- Resources: All resources are added with URIs prefixed in the format
protocol://{prefix}/path
.subserver.resource(uri="data://info")
becomesmain_mcp.resource(uri="data://{prefix}/info")
.
- Resource Templates: Templates are prefixed similarly to resources.
subserver.resource(uri="data://{id}")
becomesmain_mcp.resource(uri="data://{prefix}/{id}")
.
- Prompts: All prompts are added with names prefixed using
{prefix}_
.subserver.prompt(name="my_prompt")
becomesmain_mcp.prompt(name="{prefix}_my_prompt")
.
import_server
performs a one-time copy of components. Changes made to the subserver
after importing will not be reflected in main_mcp
. The subserver
’s lifespan
context is also not executed by the main server.
Mounting (Live Linking)
Themount()
method creates a live link between the main_mcp
server and the subserver
. Instead of copying components, requests for components matching the prefix
are delegated to the subserver
at runtime.
How Mounting Works
When mounting is configured:- Live Link: The parent server establishes a connection to the mounted server.
- Dynamic Updates: Changes to the mounted server are immediately reflected when accessed through the parent.
- Prefixed Access: The parent server uses prefixes to route requests to the mounted server.
- Delegation: Requests for components matching the prefix are delegated to the mounted server at runtime.
import_server
for naming tools, resources, templates, and prompts.
Direct vs. Proxy Mounting
New in version: 2.2.7
FlashMCP supports two mounting modes:
- Direct Mounting (default): The parent server directly accesses the mounted server’s objects in memory.
- No client lifecycle events occur on the mounted server
- The mounted server’s lifespan context is not executed
- Communication is handled through direct method calls
- Proxy Mounting: The parent server treats the mounted server as a separate entity and communicates with it through a client interface.
- Full client lifecycle events occur on the mounted server
- The mounted server’s lifespan is executed when a client connects
- Communication happens via an in-memory Client transport
as_proxy
parameter.
Interaction with Proxy Servers
When usingFlashMCP.as_proxy()
to create a proxy server, mounting that server will always use proxy mounting:
Resource Prefix Formats
New in version: 2.4.0
When mounting or importing servers, resource URIs are usually prefixed to avoid naming conflicts. FlashMCP supports two different formats for resource prefixes: