Connection Types
Understanding the different connection types for MCP servers
Connection Types for MCP Servers
MCP servers can communicate with clients using different connection protocols, each with its own advantages and use cases. This guide explains the three primary connection types supported by mcp_use:
Standard Input/Output (STDIO)
STDIO connections run the MCP server as a child process and communicate through standard input and output streams.
Characteristics:
- Local Operation: The server runs as a child process on the same machine
- Simplicity: Easy to set up with minimal configuration
- Security: No network exposure, ideal for sensitive operations
- Performance: Low latency for local operations
Configuration Example:
HTTP Connections
HTTP connections communicate with MCP servers over standard HTTP/HTTPS protocols.
Characteristics:
- RESTful Architecture: Follows familiar HTTP request/response patterns
- Statelessness: Each request is independent
- Compatibility: Works well with existing web infrastructure
- Firewall-Friendly: Uses standard ports that are typically open
Configuration Example:
WebSocket (WS) Connections
WebSocket connections provide a persistent, bidirectional communication channel between the client and server.
Characteristics:
- Real-time Communication: Low-latency bidirectional data flow
- Persistent Connection: Maintains connection state
- Efficiency: Lower overhead for multiple interactions
- Event-Driven: Well-suited for streaming and event-based operations
Configuration Example:
Choosing the Right Connection Type
The choice of connection type depends on your specific use case:
-
STDIO: Best for local development, testing, and enhanced security scenarios where network exposure is a concern
-
HTTP: Ideal for stateless operations, simple integrations, and when working with existing HTTP infrastructure
-
WebSocket: Preferred for real-time applications, streaming data, and scenarios requiring persistent connections
When configuring your mcp_use environment, you can specify the connection type in your configuration file as shown in the examples above.
Using Connection Types
Connection types are automatically inferred from your configuration file based on the parameters provided:
For example:
- If your configuration includes
command
andargs
, a STDIO connection will be used - If your configuration has a
url
starting withhttp://
orhttps://
, an HTTP connection will be used - If your configuration has a
url
starting withws://
orwss://
, a WebSocket connection will be used
This automatic inference simplifies the configuration process and ensures the appropriate connection type is used without requiring explicit specification.
For more details on connection configuration, see the Configuration Guide.