| Crates.io | pmcp |
| lib.rs | pmcp |
| version | 1.9.4 |
| created_at | 2025-07-26 02:02:07.422984+00 |
| updated_at | 2026-01-07 16:34:59.243829+00 |
| description | High-quality Rust SDK for Model Context Protocol (MCP) with full TypeScript SDK compatibility |
| homepage | https://github.com/paiml/pmcp |
| repository | https://github.com/paiml/pmcp |
| max_upload_size | |
| id | 1768625 |
| size | 18,002,862 |
Production-grade Rust implementation of the Model Context Protocol (MCP) - 16x faster than TypeScript, built with Toyota Way quality principles
PMCP is a complete MCP ecosystem for Rust, providing everything you need to build, test, and deploy production-grade MCP servers:
Why PMCP?
unwrap() in production codeChoose your path based on experience and preference:
Build production-ready MCP servers with AI assistance in minutes:
Prerequisites:
# Install Rust
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
rustup update
# Install cargo-pmcp
cargo install cargo-pmcp
Install Claude Code AI Agent:
# Install the mcp-developer subagent (user-level - works across all projects)
curl -fsSL https://raw.githubusercontent.com/paiml/rust-mcp-sdk/main/ai-agents/claude-code/mcp-developer.md \
-o ~/.claude/agents/mcp-developer.md
# Restart Claude Code
Build your server:
You: "Create a weather forecast MCP server with tools for getting current conditions and 5-day forecasts"
Claude Code: [Invokes mcp-developer subagent]
I'll create a production-ready weather MCP server using cargo-pmcp.
$ cargo pmcp new weather-mcp-workspace
$ cd weather-mcp-workspace
$ cargo pmcp add server weather --template minimal
[Implements type-safe tools with validation]
[Adds comprehensive tests and observability]
[Validates quality gates]
β
Production-ready server complete with 85% test coverage!
What you get: Production-ready code following Toyota Way principles, with comprehensive tests, structured logging, metrics collection, and zero clippy warnings.
Learn more: AI-Assisted Development Course | AI Agents README
Scaffold and build servers using the cargo-pmcp CLI:
Installation:
# Install Rust
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
rustup update
# Install cargo-pmcp
cargo install cargo-pmcp
Create a server:
# Create workspace
cargo pmcp new my-mcp-workspace
cd my-mcp-workspace
# Add a server using a template
cargo pmcp add server myserver --template minimal
# Start development server with hot-reload
cargo pmcp dev --server myserver
# Generate and run tests
cargo pmcp test --server myserver --generate-scenarios
cargo pmcp test --server myserver
# Build for production
cargo build --release
Available templates:
minimal - Empty structure for custom serverscalculator - Arithmetic operations (learning)complete_calculator - Full-featured reference implementationsqlite_explorer - Database browser patternLearn more: cargo-pmcp Guide
Use the pmcp crate directly for maximum control:
Installation:
[dependencies]
pmcp = "1.8"
tokio = { version = "1", features = ["full"] }
serde = { version = "1", features = ["derive"] }
schemars = "0.8" # For type-safe tools
Type-safe server example:
use pmcp::{ServerBuilder, TypedTool, RequestHandlerExtra, Error};
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
#[derive(Debug, Deserialize, Serialize, JsonSchema)]
#[schemars(deny_unknown_fields)]
struct WeatherArgs {
#[schemars(description = "City name")]
city: String,
#[schemars(description = "Number of days (1-5)")]
days: Option<u8>,
}
#[derive(Debug, Serialize, JsonSchema)]
struct WeatherOutput {
temperature: f64,
conditions: String,
}
async fn get_weather(args: WeatherArgs, _extra: RequestHandlerExtra) -> pmcp::Result<WeatherOutput> {
// Validate
if args.city.is_empty() {
return Err(Error::validation("City cannot be empty"));
}
let days = args.days.unwrap_or(1);
if !(1..=5).contains(&days) {
return Err(Error::validation("Days must be 1-5"));
}
// Call weather API...
Ok(WeatherOutput {
temperature: 72.0,
conditions: "Sunny".to_string(),
})
}
#[tokio::main]
async fn main() -> pmcp::Result<()> {
let server = ServerBuilder::new()
.name("weather-server")
.version("1.0.0")
.tool("get-weather", TypedTool::new("get-weather", |args, extra| {
Box::pin(get_weather(args, extra))
}).with_description("Get weather forecast for a city"))
.build()?;
server.run_stdio().await?;
Ok(())
}
Learn more: pmcp-book | pmcp-course | API Documentation
High-performance Rust implementation of the MCP protocol.
Key Features:
unwrap(), comprehensive error handlingLatest Version: pmcp = "1.8.3"
Documentation:
Scaffolding and development toolkit for MCP servers.
What it does:
Commands:
cargo pmcp new <workspace> # Create workspace
cargo pmcp add server <name> # Add server
cargo pmcp dev --server <name> # Start dev server
cargo pmcp test --server <name> # Run tests
cargo pmcp deploy --target <target> # Deploy to production
cargo pmcp deploy logs --tail # Stream logs
cargo pmcp deploy destroy --clean # Remove deployment
Why use it?
Learn more: cargo-pmcp Guide
27-chapter comprehensive reference guide to building MCP servers with pmcp.
π Read Online
Coverage:
Local development:
make book-serve # Serve at http://localhost:3000
make book-open # Build and open in browser
Interactive course with quizzes, exercises, and real-world projects for mastering MCP development.
π Start the Course
Course Structure:
Features:
Local development:
cd pmcp-course && mdbook serve # Serve at http://localhost:3000
AI agent configurations that teach Kiro and Claude Code how to build MCP servers.
Supported AI Assistants:
Kiro (Steering Files) - 10,876 lines of persistent MCP expertise
Claude Code (Subagent) - ~750 lines of focused MCP knowledge
What AI agents know:
Community implementations welcome:
Learn more: AI-Assisted Development Course | ai-agents/
Highlights:
Full changelog: CHANGELOG.md
Migration guides:
schemarsThe SDK includes 60+ comprehensive examples covering all features:
# Basic examples
cargo run --example 01_client_initialize # Client setup
cargo run --example 02_server_basic # Basic server
cargo run --example 03_client_tools # Tool usage
# Type-safe tools (v1.6.0+)
cargo run --example 32_typed_tools --features schema-generation
cargo run --example 33_advanced_typed_tools --features schema-generation
# Advanced features
cargo run --example 09_authentication # OAuth/Bearer
cargo run --example 13_websocket_transport # WebSocket
cargo run --example 15_middleware # Middleware chain
# Testing
cargo run --example 26-server-tester -- test http://localhost:8080
# AI-assisted development
# See ai-agents/README.md for Kiro and Claude Code setup
See examples/README.md for complete list.
Comprehensive testing tool for validating MCP server implementations.
Features:
Installation:
cargo install mcp-server-tester
# Or download pre-built binaries from releases
Usage:
# Test a server
mcp-tester test http://localhost:8080
# Protocol compliance check
mcp-tester compliance http://localhost:8080 --strict
# Connection diagnostics
mcp-tester diagnose http://localhost:8080
Learn more: examples/26-server-tester/README.md
PMCP is built following Toyota Production System principles:
Jidoka (θͺεε): Automation with human touch
unwrap() in productionGenchi Genbutsu (ηΎε°ηΎη©): Go and see
Kaizen (ζΉε): Continuous improvement
Metric PMCP (Rust) TypeScript SDK Improvement
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Overall Speed 16x 1x 16x faster
Memory Usage <10 MB ~500 MB 50x lower
SSE Parsing 336,921 ev/s 32,691 ev/s 10.3x faster
JSON-RPC Parsing 195,181 docs/s N/A SIMD-optimized
Round-trip Latency <100 ΞΌs ~1-2 ms 10-20x faster
Base64 Operations 252+ MB/s N/A Optimized
Run benchmarks:
make bench # General benchmarks
cargo run --example 32_simd_parsing # SIMD-specific
Full WASM support for browser and edge deployment:
Targets:
Quick start:
# Build for Cloudflare Workers
cargo build --target wasm32-unknown-unknown --no-default-features --features wasm
# Deploy
make cloudflare-sdk-deploy
Learn more: WASM Guide | WASM Example
git clone https://github.com/paiml/rust-mcp-sdk
cd rust-mcp-sdk
# Install development tools
make setup
# Run quality checks
make quality-gate
make test-all # All tests
make test-property # Property tests
make coverage # Coverage report
make mutants # Mutation tests
We welcome contributions! Please:
git checkout -b feature/amazing-feature)make quality-gate)See: CONTRIBUTING.md
| Feature | TypeScript SDK | PMCP (Rust) |
|---|---|---|
| Protocol Version | 2024-10-07+ | 2024-10-07+ |
| Transports | stdio, SSE, WebSocket | stdio, SSE, WebSocket, WASM |
| Authentication | OAuth 2.0, Bearer | OAuth 2.0, Bearer, OIDC |
| Tools | β | β (Type-safe) |
| Prompts | β | β (Workflows) |
| Resources | β | β (Subscriptions) |
| Sampling | β | β |
| Performance | 1x | 16x faster |
| Memory | Baseline | 50x lower |
This project is licensed under the MIT License - see the LICENSE file for details.
Built with π¦ Rust and β€οΈ following Toyota Way principles