[ Switch to styled version → ]


← Docs index

Pilot Protocol vs MCP vs A2A vs ACP

This page compares four protocols for AI agent communication: Pilot Protocol, MCP, A2A, and ACP. It describes what each protocol does, where they overlap, and how they can be used together.

Overview

The AI agent ecosystem has multiple protocols for different communication needs. They operate at different layers and are often complementary.

vs MCP (Model Context Protocol)

MCP connects an LLM to tools and data sources. Pilot Protocol connects agents to each other.

MCP is designed for a single model interacting with local tools. Pilot Protocol is for distributed agents communicating across networks. An MCP server can run on top of a Pilot tunnel to expose tools to remote agents.

vs A2A (Agent-to-Agent)

A2A defines the application-level contract between agents, including agent cards, task lifecycle, and message schemas. Pilot Protocol provides the network-level connectivity for those messages.

A2A assumes agents are reachable via HTTP URLs. Pilot Protocol makes agents reachable behind NATs, firewalls, or without public IPs. A2A agent cards can advertise Pilot addresses, and A2A JSON-RPC messages can travel over Pilot tunnels.

vs ACP (Agent Communication Protocol)

ACP focuses on multi-agent orchestration within a runtime. Pilot Protocol focuses on the network layer.

ACP orchestrates agents within a single runtime environment. Pilot Protocol connects agents across different machines, networks, and organizations. ACP agents can use Pilot tunnels to communicate with agents in remote runtimes.

Feature matrix

When to use what

Use Pilot Protocol for:

Use MCP for:

Use A2A for:

Use ACP for:

Using them together

These protocols are designed for different layers and can be combined.

Pilot + MCP: Run an MCP server on one machine and expose it over a Pilot tunnel. Remote agents connect to the MCP server's Pilot address without a public IP, with end-to-end encryption and trust-gated access.

# Agent A runs an MCP server, exposed on Pilot port 80
# Agent B connects from across the internet
pilotctl connect <agent-a-address> 80
# MCP JSON-RPC flows over the encrypted Pilot tunnel

Pilot + A2A: Agents advertise A2A agent cards with their Pilot address. Task requests and responses travel over Pilot tunnels instead of public HTTP endpoints, providing NAT traversal, encryption, and trust.

# Agent card includes Pilot address instead of URL
{
  "name": "research-agent",
  "pilot_address": "1:0001.0000.0042",
  "skills": [{"name": "web-research"}]
}

Pilot + ACP: ACP runtimes on different machines connect via Pilot tunnels. Agents in one runtime can discover and communicate with agents in another as if they were local. The Pilot tunnel handles routing, encryption, and NAT traversal.

Related