API Reference
Complete mcp_use API Documentation
API Reference
This section provides comprehensive documentation for the mcp_use API, including all components, methods, their arguments, and when to use different options.
MCPClient
The MCPClient
is the core class for interacting with MCP servers. It handles connection management, session creation, and communication with MCP servers.
Initialization Methods
From Config File
Parameter | Type | Required | Description |
---|---|---|---|
config_path | str | Yes | Path to the JSON configuration file |
From Dictionary
Parameter | Type | Required | Description |
---|---|---|---|
config | dict | Yes | Dictionary containing MCP server configuration |
Core Methods
create_session
Creates a new session with an MCP server.
Parameter | Type | Required | Default | Description |
---|---|---|---|---|
server_name | str | Yes | - | Name of the server as defined in config |
timeout | float | No | 30.0 | Connection timeout in seconds |
retry_count | int | No | 3 | Number of connection retry attempts |
When to use:
- Use a longer
timeout
for servers that take more time to initialize - Increase
retry_count
in unstable network environments - Use specific
server_name
when working with multiple servers in the same config
close_session
Closes a specific session.
Parameter | Type | Required | Description |
---|---|---|---|
session_id | str | Yes | ID of the session to close |
close_all_sessions
Closes all active sessions.
When to use:
- Always call this at the end of your application to clean up resources
- Use when switching between different tasks that require different servers
get_server
Gets a server instance by name.
Parameter | Type | Required | Description |
---|---|---|---|
name | str | Yes | Name of the server as defined in config |
MCPAgent
The MCPAgent
class combines an LLM with an MCPClient to create an intelligent agent capable of using MCP tools.
Initialization
Parameter | Type | Required | Default | Description |
---|---|---|---|---|
llm | BaseLanguageModel | Yes | - | Any LangChain-compatible language model |
client | MCPClient | No | None | The MCPClient instance |
connectors | list[BaseConnector] | No | None | List of connectors if not using client |
server_name | str | No | None | Name of the server to use |
max_steps | int | No | 5 | Maximum number of steps the agent can take |
auto_initialize | bool | No | False | Whether to initialize automatically |
memory_enabled | bool | No | True | Whether to enable memory |
system_prompt | str | No | None | Custom system prompt |
system_prompt_template | str | No | None | Custom system prompt template |
additional_instructions | str | No | None | Additional instructions for the agent |
session_options | dict | No | Additional options for session creation | |
output_parser | OutputParser | No | None | Custom output parser for LLM responses |
When to use different parameters:
-
llm:
- mcp_use supports ANY LLM that is compatible with LangChain
- You can use models from OpenAI, Anthropic, Google, Mistral, Groq, Cohere, or any other provider with a LangChain integration
- You can even use open source models via LlamaCpp, HuggingFace, or other interfaces
- Custom or self-hosted models are also supported as long as they implement LangChain’s interface
-
max_steps:
- Increase for complex tasks that require many interactions
- Decrease for simpler tasks to improve efficiency
- Use higher values (50+) for web browsing or multi-stage tasks
- Use lower values (10-20) for targeted, specific tasks
-
system_prompt / system_prompt_template:
- Use to customize the initial instructions given to the LLM
- Helps shape the agent’s behavior and capabilities
- Use for specialized tasks or custom interaction patterns
-
memory_enabled:
- Enable to maintain conversation history
- Disable for stateless operation or to save on token usage
-
session_options:
- Customize timeout for long-running server operations
- Set retry parameters for unstable connections
Core Methods
run
Runs the agent with a given query.
Parameter | Type | Required | Default | Description |
---|---|---|---|---|
query | str | Yes | - | The query to run |
max_steps | int | No | None | Overrides the instance max_steps |
stop_on_first_result | bool | No | False | Whether to stop at first result |
server_name | str | No | None | Specific server to use |
callbacks | list | No | None | Callback functions for events |
When to use different parameters:
- max_steps: Override the instance default for specific queries
- stop_on_first_result: Use True for simple lookups, False for thorough exploration
- server_name: Specify when using multiple servers for different tasks
- callbacks: Add for monitoring or logging specific runs
reset
Resets the agent state.
When to use:
- Between different tasks to clear context
- When starting a new conversation thread
- When agent gets stuck in a particular strategy
get_history
Gets the agent’s interaction history.
When to use:
- For debugging agent behavior
- When implementing custom logging
- To provide context for follow-up queries
Configuration Details
MCP Server Configuration Schema
Field | Type | Required | Description |
---|---|---|---|
command | string | Yes | The command to start the MCP server |
args | array | No | Arguments to pass to the command |
env | object | No | Environment variables for the server |
timeout | number | No | Connection timeout in seconds |
retry | object | No | Retry configuration |
retry.max_attempts | number | No | Maximum retry attempts |
retry.backoff_factor | number | No | Backoff multiplier between retries |
When to use different options:
-
command & args: Vary based on the specific MCP server implementation
-
env:
- Set environment-specific variables needed by the server
- Override default server settings (ports, directories)
- Set display settings for GUI-based servers
-
timeout:
- Increase for servers with longer startup times
- Lower for simpler servers to fail fast
-
retry configuration:
- Adjust for different network conditions
- Increase max_attempts in unstable environments
- Adjust backoff_factor based on server behavior
Error Handling
mcp_use provides several exception types to handle different error scenarios:
Exception | Description | When It Occurs |
---|---|---|
MCPConnectionError | Connection to MCP server failed | Network issues, server not running |
MCPAuthenticationError | Authentication with server failed | Invalid credentials or tokens |
MCPTimeoutError | Operation timed out | Server takes too long to respond |
MCPServerError | Server returned an error | Internal server error |
MCPClientError | Client-side error | Invalid configuration or parameters |
MCPError | Generic MCP-related error | Any other MCP-related issue |
Handling Strategies:
Advanced Usage
Multi-Server Configuration
Configure and use multiple MCP servers in a single application:
Custom Output Parsing
Implement custom output parsers for specialized MCP servers:
This approach is useful when:
- The MCP server returns structured data that needs special handling
- You need to extract specific information from responses
- You’re integrating with custom or specialized MCP servers