MCP Transport Mechanisms
Model Context Protocol (MCP) supports two primary transport mechanisms for communication between Cline and MCP servers: Standard Input/Output (STDIO) and Server-Sent Events (SSE). Each has distinct characteristics, advantages, and use cases.
STDIO Transport
STDIO transport runs locally on your machine and communicates via standard input/output streams.
How STDIO Transport Works
The client (Cline) spawns an MCP server as a child process
Communication happens through process streams: client writes to server's STDIN, server responds to STDOUT
Each message is delimited by a newline character
Messages are formatted as JSON-RPC 2.0
STDIO Characteristics
Locality: Runs on the same machine as Cline
Performance: Very low latency and overhead (no network stack involved)
Simplicity: Direct process communication without network configuration
Relationship: One-to-one relationship between client and server
Security: Inherently more secure as no network exposure
When to Use STDIO
STDIO transport is ideal for:
Local integrations and tools running on the same machine
Security-sensitive operations
Low-latency requirements
Single-client scenarios (one Cline instance per server)
Command-line tools or IDE extensions
STDIO Implementation Example
SSE Transport
Server-Sent Events (SSE) transport runs on a remote server and communicates over HTTP/HTTPS.
How SSE Transport Works
The client (Cline) connects to the server's SSE endpoint via HTTP GET request
This establishes a persistent connection where the server can push events to the client
For client-to-server communication, the client makes HTTP POST requests to a separate endpoint
Communication happens over two channels:
Event Stream (GET): Server-to-client updates
Message Endpoint (POST): Client-to-server requests
SSE Characteristics
Remote Access: Can be hosted on a different machine from your Cline instance
Scalability: Can handle multiple client connections concurrently
Protocol: Works over standard HTTP (no special protocols needed)
Persistence: Maintains a persistent connection for server-to-client messages
Authentication: Can use standard HTTP authentication mechanisms
When to Use SSE
SSE transport is better for:
Remote access across networks
Multi-client scenarios
Public services
Centralized tools that many users need to access
Integration with web services
SSE Implementation Example
Local vs. Hosted: Deployment Aspects
The choice between STDIO and SSE transports directly impacts how you'll deploy and manage your MCP servers.
STDIO: Local Deployment Model
STDIO servers run locally on the same machine as Cline, which has several important implications:
Installation: The server executable must be installed on each user's machine
Distribution: You need to provide installation packages for different operating systems
Updates: Each instance must be updated separately
Resources: Uses the local machine's CPU, memory, and disk
Access Control: Relies on the local machine's filesystem permissions
Integration: Easy integration with local system resources (files, processes)
Execution: Starts and stops with Cline (child process lifecycle)
Dependencies: Any dependencies must be installed on the user's machine
Practical Example
A local file search tool using STDIO would:
Run on the user's machine
Have direct access to the local filesystem
Start when needed by Cline
Not require network configuration
Need to be installed alongside Cline or via a package manager
SSE: Hosted Deployment Model
SSE servers can be deployed to remote servers and accessed over the network:
Installation: Installed once on a server, accessed by many users
Distribution: Single deployment serves multiple clients
Updates: Centralized updates affect all users immediately
Resources: Uses server resources, not local machine resources
Access Control: Managed through authentication and authorization systems
Integration: More complex integration with user-specific resources
Execution: Runs as an independent service (often continuously)
Dependencies: Managed on the server, not on user machines
Practical Example
A database query tool using SSE would:
Run on a central server
Connect to databases with server-side credentials
Be continuously available for multiple users
Require proper network security configuration
Be deployed using container or cloud technologies
Hybrid Approaches
Some scenarios benefit from a hybrid approach:
STDIO with Network Access: A local STDIO server that acts as a proxy to remote services
SSE with Local Commands: A remote SSE server that can trigger operations on the client machine through callbacks
Gateway Pattern: STDIO servers for local operations that connect to SSE servers for specialized functions
Choosing Between STDIO and SSE
Location
Local machine only
Local or remote
Clients
Single client
Multiple clients
Performance
Lower latency
Higher latency (network overhead)
Setup Complexity
Simpler
More complex (requires HTTP server)
Security
Inherently secure
Requires explicit security measures
Network Access
Not needed
Required
Scalability
Limited to local machine
Can distribute across network
Deployment
Per-user installation
Centralized installation
Updates
Distributed updates
Centralized updates
Resource Usage
Uses client resources
Uses server resources
Dependencies
Client-side dependencies
Server-side dependencies
Configuring Transports in Cline
For detailed information on configuring STDIO and SSE transports in Cline, including examples, see Configuring MCP Servers.
Last updated