Interface for MCP (Model Context Protocol) servers via CLI. Use when you need to interact with external tools, APIs, or data sources through MCP servers.
Access MCP servers through the command line. MCP enables interaction with external systems like GitHub, filesystems, databases, and APIs.
| Command | Output |
|---|---|
mcp-cli |
List all servers and tools |
mcp-cli info <server> |
Show server tools and parameters |
mcp-cli info <server> <tool> |
Get tool JSON schema |
mcp-cli grep "<pattern>" |
Search tools by name |
mcp-cli call <server> <tool> |
Call tool (reads JSON from stdin if no args) |
mcp-cli call <server> <tool> '<json>' |
Call tool with arguments |
Both formats work: <server> <tool> or <server>/<tool>
mcp-cli → see available serversmcp-cli info <server> → see tools with parametersmcp-cli info <server> <tool> → get full JSON schemamcp-cli call <server> <tool> '<json>' → run with arguments# List all servers
mcp-cli
# With descriptions
mcp-cli -d
# See server tools
mcp-cli info filesystem
# Get tool schema (both formats work)
mcp-cli info filesystem read_file
mcp-cli info filesystem/read_file
# Call tool
mcp-cli call filesystem read_file '{"path": "./README.md"}'
# Pipe from stdin (no '-' needed!)
cat args.json | mcp-cli call filesystem read_file
# Search for tools
mcp-cli grep "*file*"
# Extract text from result
mcp-cli call filesystem read_file '{"path": "./file"}' | jq -r '.content[0].text'
# Chain: search files → read first match
mcp-cli call filesystem search_files '{"path": ".", "pattern": "*.md"}' \
| jq -r '.content[0].text | split("\n")[0]' \
| xargs -I {} mcp-cli call filesystem read_file '{"path": "{}"}'
# Loop: process multiple files
mcp-cli call filesystem list_directory '{"path": "./src"}' \
| jq -r '.content[0].text | split("\n")[]' \
| while read f; do mcp-cli call filesystem read_file "{\"path\": \"$f\"}"; done
# Conditional: check before reading
mcp-cli call filesystem list_directory '{"path": "."}' \
| jq -e '.content[0].text | contains("README")' \
&& mcp-cli call filesystem read_file '{"path": "./README.md"}'
# Multi-server aggregation
{
mcp-cli call github search_repositories '{"query": "mcp", "per_page": 3}'
mcp-cli call filesystem list_directory '{"path": "."}'
} | jq -s '.'
# Save to file
mcp-cli call github get_file_contents '{"owner": "x", "repo": "y", "path": "z"}' \
| jq -r '.content[0].text' > output.txt
jq tips: -r raw output, -e exit 1 if false, -s slurp multiple inputs
| Flag | Purpose |
|---|---|
-d |
Include descriptions |
-c <path> |
Specify config file |
| Wrong Command | Error | Fix |
|---|---|---|
mcp-cli server tool |
AMBIGUOUS_COMMAND | Use call server tool or info server tool |
mcp-cli run server tool |
UNKNOWN_SUBCOMMAND | Use call instead of run |
mcp-cli list |
UNKNOWN_SUBCOMMAND | Use info instead of list |
mcp-cli call server |
MISSING_ARGUMENT | Add tool name |
mcp-cli call server tool {bad} |
INVALID_JSON | Use valid JSON with quotes |
0: Success1: Client error (bad args, missing config)2: Server error (tool failed)3: Network error