惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
G
GRAHAM CLULEY
P
Privacy & Cybersecurity Law Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
宝玉的分享
宝玉的分享
P
Proofpoint News Feed
H
Help Net Security
V
Visual Studio Blog
阮一峰的网络日志
阮一峰的网络日志
C
Cisco Blogs
人人都是产品经理
人人都是产品经理
Know Your Adversary
Know Your Adversary
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Recorded Future
Recorded Future
I
Intezer
罗磊的独立博客
T
The Exploit Database - CXSecurity.com
Blog — PlanetScale
Blog — PlanetScale
Malwarebytes
Malwarebytes
Spread Privacy
Spread Privacy
T
Tor Project blog
V
Vulnerabilities – Threatpost
云风的 BLOG
云风的 BLOG
腾讯CDC
B
Blog RSS Feed
Stack Overflow Blog
Stack Overflow Blog
F
Future of Privacy Forum
MyScale Blog
MyScale Blog
Latest news
Latest news
IT之家
IT之家
MongoDB | Blog
MongoDB | Blog
The Hacker News
The Hacker News
S
Securelist
博客园 - 【当耐特】
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threat Research - Cisco Blogs
Jina AI
Jina AI
Cisco Talos Blog
Cisco Talos Blog
B
Blog
博客园 - 三生石上(FineUI控件)
Last Week in AI
Last Week in AI
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
M
MIT News - Artificial intelligence
V
V2EX
D
Darknet – Hacking Tools, Hacker News & Cyber Security
The Cloudflare Blog
The GitHub Blog
The GitHub Blog
博客园 - 聂微东
F
Full Disclosure
C
CERT Recently Published Vulnerability Notes

DEV Community

African Creators Deserve Better: How I Built a Payment Gateway for Every Corner of the Continent React CRUD basics Should Websites Allow AI Search Crawlers? Beyond the Prompt: How to Build Stateful AI Agents with Persistent Memory and Self-Learning Loops AgentGuard 0.3.0 — macOS menu bar app, Telegram rollback, and more Antigravity CLI: A Hands-On Guide to Google's Terminal Coding Agent Shopify Functions vs Shopify Scripts: A Migration Walkthrough What Actually Survives a Chicago-Area Winter on Your Deck Rethinking Geo-Blocking and Stripe's Failures in Global Access: A Cautionary Tale of Misoptimization I Built a Free Brat Generator - Here's What I Learned About Next.js Performance published Found a Second Layer to a GitHub Follow Botnet? AI Daily Digest: May 22, 2026 — Agentic Workflows, Coding Agents & Embodied AI How I Secured Internal Microservice Calls Without Passing JWTs Stop Mixing Them Up: SLI vs SLO vs SLA Explained Rebuilding My Engineering Mind Building a Music Production Ecosystem Instead of Just Releasing Plugins The Vonage Dev Discussion: How AI is transforming software development I Gave Our Enterprise AI a Memory. It Started Citing Last Quarter's Incidents. 𝐓𝐡𝐞 𝐂𝐨𝐦𝐦𝐮𝐧𝐢𝐜𝐚𝐭𝐢𝐨𝐧 𝐒𝐭𝐲𝐥𝐞 𝐂𝐫𝐢𝐬𝐢𝐬 Hermes Agent in the Wild: How I Turned It Into an AI Ops Employee Navigating the Hazy Jungle of Global E-commerce: How We Built a Reliable System for Digital Creators in Tanzania The Cost of Cross-Platform Development: Native Module Integration AI-Native Apps Will Swallow the Web I switched my Gemma 4 model three times in 72 hours. Here's the decision tree I wish I'd had. Inside #100DaysofSolana: A Guided Path into Web3 I Built and Shipped TinyHab: an ADHD-Friendly Habit Tracker for iOS I'm an ECE Student Who Vibe Codes Hardware Projects — Here's What Google I/O 2026 Actually Changed for Me From Fragmented Pipelines to Coherent Intelligence — Why Gemma 4 Actually Changes How I Work Our AI Inference Bill Dropped 65% After We Stopped Treating Every Query the Same Why P95 Latency Is the Only Metric That Matters at 3 AM Recycling made easy: a Polish recycling assistant powered by Gemma 4 The Complete Guide to Running a Midnight Node: Setup, Sync & Monitoring De CSRF a RCE: una visita web cuesta una shell en OpenYak Why We Built a Faster Wiki Building a Browser-Based Inkarnate Alternative for D&D Battle Maps Apache Kafka How to Build a FinTech Platform as a Solo Developer (By Any Means Necessary) Your LLM Logs Deserve Better — Send Claude Code Events to Bronto I built a free tool to track subscriptions and stop getting surprised by charges Building the TEYZIX CORE Internship Portal — My Full-Stack Development Journey PocketCFO: a private personal-finance brain that runs entirely in your browser Go Idioms I Wish I Knew Earlier Hey how are you guys I'm newbie web developer , learning wordpress+elementor Right now I don't know what to make I don't know what to write or use what color can you tell me about it ? Google I/O 2026 Blew My Mind — Here's What It Means for the Family App I'm Building 5 Things I Learned in My First Month as a Dev Intern EU AI Sovereignty Belongs in the Workflow Layer Why AI Coding Agents Need Business Context, Not Just Code Context How I Built 9 Claude AI Features into a Production SaaS Expo SDK 56 HashiCorp built an MCP server for writing Terraform. I built one for reviewing it Why Enterprise AI Agent Deployments Keep Failing Date Shear: A New Term for a Common Programming Pain Point Compass v1.1.0 · we shipped a memory plugin that catches its own consumption drift Zod Validation: Type-Safe APIs & Forms in TypeScript (Complete Guide) GitHub Actions CI/CD: Build a Complete Node.js Pipeline (2026) MCP in 2026: The numbers behind the ecosystem explosion working with an ai model mirror Learnt new things Four Metrics That Actually Tell You Whether Your Enterprise RAG Is Working Beyond the Stateless Prompt: Building an Auditable Product Intelligence Pipeline with Cascadeflow and Hindsight Most Creators Are Building in Pieces. I’m Building the Entire System. The Hidden Privacy Problem in Every AI App CVE-2026-26007: Subgroup Confinement Attack in pyca/cryptography The One Thing I See in Every Developer Who Gets Unstuck AI Memory Governance for Legal Tech: How Contract AI Agents Handle Privileged Data Two tables, zero migrations, full LINQ — a .NET data engine that's been running our production for 3 months Join the GitHub Finish-Up-A-Thon Challenge: $3,000 Prize Pool! I Replaced a $50/Month OCR API with Gemma 4’s Native Vision (And You Can Too) Building a Data-Driven Medical Image Enhancement Pipeline with Differential Evolution 🔥🩻 Why I Like Small Software Beyond the Model: Why the Gemini Ecosystem and Google AI Studio Are Redefining Enterprise AI Architecture in 2026 Complete set of Claude Skills for Solo Developer I read 50 years of network science, then built a CRM that runs entirely in the browser The New AI Workflow Is Not “More Agents” How to Make Large Time-Series Charts Smooth in Vue.js + ApexCharts (and fix Zoom & Scroll behavior issues) I Built a Cross-Platform Port Intelligence Tool to Stop Accidental Process Kills During Local Dev AI is heading toward a wall, and most people still don’t see it... Python String Methods Explained Simply (Common Operations) Why We Built a Zero-Knowledge Clipboard Manager for Developers (And Dropped Native Mobile Apps) Add Your Own Component to Bombie in 5 Edits Why Your OSS Advocacy Strategy Probably Doesn't Fit Building an MCP server for a Swiss hosting provider (and what reverse-engineering its manager taught me) Does MCP Still Matter in the AI Ecosystem? Building a Smart LRU Cache in Java: When Machines Mimic Human Memory 🧠💻 A Beginner’s Guide to Redux in React Build a Real-Time Excalidraw-like Collaborative Canvas using Velt MCP and Antigravity🎉 Using Reddit to Validate SaaS Ideas Before Building How We Built an AI That Evolves Alongside a Creator Through Memory Building a Self-Hosted AI WhatsApp Agent for Structured Invoice Extraction Three Design Decisions That Shaped the Enterprise RAG Retrieval Pipeline How React's Virtual DOM Works Under the Hood Build a Dropbox Paper-Style Collaborative Editor with Next.js and Velt💥 Holy Typos, Batman! How I Built 'SpellJump' How to Test Frontend Error States Without Breaking Your Backend A .NET Dinosaur in Web3. Day 8 — Reading & Writing — WishList Chain Building AI Digital Employees with Markus: An Open-Source Platform for Agent Teams [Boost] The Auditor — High-Reasoning Synthesis and the Ethics of Governance Building 'Offline Brain': How I Wrote My First Custom Agent Skill for Android (Google I/O 2026) 📱🧠 Building a Superhuman-Style Collaborative Email Editor with Next.js and Velt🔥
The Universal Remote for AI: A Deep Dive into the Model Context Protocol (MCP)
RS · 2026-05-22 · via DEV Community

Connect any AI model to any tool, database, or API — once and for all.


For years, AI developers faced what's known as the N × M integration problem.

Suppose you wanted three different AI models to interact with five external services — GitHub, Slack, a database, and Jira. You'd have to write and maintain fifteen separate, brittle custom integrations. Every new model meant five more. Every new service meant three more. The combinatorics were brutal.

The Model Context Protocol (MCP) changes everything. Think of it as the USB-C port for AI: a secure, open standard that lets any AI model seamlessly plug into any external data source or tool using one universal language.

Whether you're building a simple chat assistant or a fully autonomous agent, understanding MCP is no longer optional.


The N × M Problem, Visualised

Without a universal protocol, every model–service pair needs its own custom glue code. Three models × four services = twelve separate integrations to build and maintain:

                GitHub      Slack       Postgres    Jira
GPT           ❌ custom   ❌ custom   ❌ custom   ❌ custom
Claude        ❌ custom   ❌ custom   ❌ custom   ❌ custom
Your Agent    ❌ custom   ❌ custom   ❌ custom   ❌ custom

Enter fullscreen mode Exit fullscreen mode

Add a new model? Four more integrations. Add a new service? Three more. The maintenance burden compounds with every addition.

With MCP, you connect your model once to the MCP ecosystem, and every MCP-compatible tool becomes instantly available. No more N×M explosions — just one clean, reusable interface.


Core Architecture: Three Roles, One Protocol

At its heart, MCP defines three distinct roles:

🖥️ Host
The application that runs the AI model and the user interface, orchestrating everything. Think of it as the brain of the operation. Examples: Claude Desktop, Cursor IDE, or your own custom agent app. The Host owns the LLM, the chat interface, and enforces security.

🔌 Client
A lightweight protocol engine embedded inside the Host — completely invisible to the user. It discovers available tools, manages request lifecycles, and translates AI commands into standard JSON-RPC messages. Think of it as the universal translator.

🌉 Server
A lightweight program that speaks MCP on one side and a native service API on the other. Think of it as a specialised power adapter. Examples: a local SQLite server, an enterprise Salesforce connector, or a file-system bridge.

Here's how they fit together:

  User
   │
   ▼
┌─────────────────────────┐
│  Host Application       │
│  (LLM + MCP Client)     │
└───────────┬─────────────┘
            │ JSON-RPC over Transport
            ▼
┌─────────────────────────┐
│  MCP Server             │
│  (GitHub, DB, FileSys…) │
└───────────┬─────────────┘
            │
            ▼
   External API / Database

Enter fullscreen mode Exit fullscreen mode


The Transport Layer: How Client and Server Actually Talk

MCP messages travel over one of two transport mechanisms:

STDIO (Standard Input/Output)
Best for local integrations. The Host spawns the MCP Server as a child process, and they communicate through standard input/output streams — zero network overhead, ultra-fast, and secure by default since nothing leaves your machine. Perfect for personal dev tools.

HTTP / SSE (Server-Sent Events)
Best for remote or enterprise integrations. A central server runs in the cloud, and local clients connect using standard web protocols. Scalable, supports multiple simultaneous clients, and works over the internet. This is the backbone of team-wide and enterprise MCP deployments.


The Three Primitives: Verbs, Nouns, and Templates

When a Client connects to a Server, it gains access to three kinds of capabilities — the building blocks of every MCP interaction.

🛠️ Tools — what the AI can *do*
Executable functions the AI can invoke to take action. Examples: execute_sql_query, create_github_issue, send_email.

📂 Resources — what the AI can *read*
Read-only context the AI can pull in without taking any action. Examples: database schemas, log files, user profiles.

📝 Prompts — how the AI should structure its output
Server-hosted templates that shape how the AI thinks or formats its response. Examples: a "code review prompt" or a "customer support reply template".


Advanced Features: When the Server Talks Back

Early AI integrations were strictly one-way: the AI requested data, and the tool returned it. MCP introduces true two-way dialogue with three powerful mechanisms.

🔄 Sampling (Server → AI)

The MCP Server doesn't have its own LLM — but sometimes it needs AI reasoning mid-task.

Scenario: A server fetches 1,000 raw log entries. Instead of dumping them all into the conversation, it sends a Sampling request back to the Host: "Use your LLM to summarise these logs into the top 3 trends." The Host processes the logs, returns a clean summary, and the Server continues.

🛑 Elicitation (Server → User)

When high-stakes decisions are involved, the AI shouldn't guess. Elicitation lets a Server pause execution and ask the human for clarification before proceeding.

Scenario: The AI decides to delete old database records. Before executing, the MCP Server sends an Elicitation request. The Host surfaces a dialog: "Delete records older than 30 days or 90 days?" Once the user responds, execution resumes.

🌳 Roots (Safe Boundaries)

Roots define the strict sandbox where the AI is allowed to operate — most commonly used with file-system servers.

The Client tells the Server: "You may only read and write inside /projects/my-app." If the AI attempts to access /etc/passwd, the Server rejects the request outright based on that Root definition.


The Autonomous Agent Loop: The ReAct Pattern

So how does an AI actually use all of this to solve complex tasks without constant hand-holding? It follows the ReAct (Reason + Act) loop — a design pattern that keeps the agent moving forward, using only MCP for execution.

  User Input
      │
      ▼
  🧠 Reason (LLM thinks)
      │
      ▼
  🔀 Decide: need a tool?
   │               │
  No              Yes
   │               │
   ▼               ▼
 Done        ⚡ Act (MCP Tool Call)
                   │
                   ▼
             📥 Observe Result
                   │
                   └──── repeat ────┘

Enter fullscreen mode Exit fullscreen mode

Here's what that looks like in code:

def agent_loop(user_prompt, mcp_client, llm, max_steps=10):
    conversation_memory = [user_prompt]
    tools = mcp_client.list_tools()

    for step in range(max_steps):
        # REASON
        ai_response = llm.generate(conversation_memory, tools)
        conversation_memory.append(ai_response)

        # DECIDE
        if ai_response.is_finished:
            return ai_response.final_answer

        if ai_response.has_tool_call:
            tool_name = ai_response.tool_name
            tool_args = ai_response.tool_arguments

            # ACT (MCP Client executes)
            result = mcp_client.execute(tool_name, tool_args)
            conversation_memory.append(f"Tool result: {result}")

    # Safety circuit breaker
    return "Error: task too complex, exceeded maximum steps."

Enter fullscreen mode Exit fullscreen mode

The safety circuit breaker: The max_steps parameter prevents infinite loops. If the LLM gets stuck retrying a failing tool, this hard stop saves both compute and API costs.


Security: Two Rules That Actually Matter

Giving an autonomous agent access to a universal tool standard is powerful — and potentially dangerous. Two safeguards are non-negotiable.

1. Human-in-the-loop for destructive actions

Not every action carries the same risk. A rough rule of thumb:

  • Read logs — no approval needed, it's a safe read operation
  • Delete data — always require explicit user confirmation
  • Send an email — always require explicit user confirmation

The Host should always require a physical confirmation click before the MCP Client executes any write or delete operation.

2. Principle of Least Privilege

Use Roots to lock servers to specific directories or data scopes. Never grant a server more access than it absolutely needs. Treat every MCP Server as a separate microservice with its own threat model — because effectively, it is.


Why MCP Is a Foundational Shift

  • Standardisation — one protocol to learn, build, and debug across every tool and model
  • Reusability — write a GitHub MCP server once; use it with any MCP-compatible AI
  • Security — built-in boundaries via Roots, human approval gates, and sandboxed processes
  • Scalability — from local one-off scripts to enterprise-grade agent fleets

MCP isn't just another abstraction layer. It's the shift that turns AI systems from fragile, hard-coded scripts into modular, secure, plug-and-play agents.


Where to Start

The best way to understand MCP is to build with it:

  1. Spin up a simple MCP server — try a local filesystem or SQLite bridge
  2. Connect it to a host — use Claude Desktop or a lightweight Python script
  3. Experiment with tool calls — let your AI read files, query a database, or open a GitHub issue

The protocol is open, the tooling is maturing fast, and the ecosystem is growing quickly. The developers who get fluent with MCP now will be the ones building the agents that matter next.


Found this useful? Follow for more deep-dives into AI infrastructure and agentic systems.