MCP and LLMs: Tools

Introduction to Model Context Protocol (MCP)

James Chapman

AI Curriculum Manager, DataCamp

MCP Tools to LLM Tools

 

Tool ⇄ LLM integration is highly LLM-dependent

  • LLMs accept tools in different ways and with different syntax
  • Use Claude via Anthropic's Messages API
  • Focus: processes and transformations

llm_mcp.png

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct1.jpg

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct2.jpg

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct3.jpg

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct4.jpg

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct5.jpg

Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct6.jpg

Introduction to Model Context Protocol (MCP)

MCP Server: timezone_server.py

from mcp.server.fastmcp import FastMCP
import requests

mcp = FastMCP("Timezone Converter")

@mcp.tool()
def convert_timezone(date_time: str, from_timezone: str, to_timezone: str) -> str:
    ...

if __name__ == "__main__":
    mcp.run(transport="stdio")
Introduction to Model Context Protocol (MCP)

Expanding the Client Code

async def get_tools_from_mcp():
            # ... 
            return response.tools

async def call_mcp_tool(tool_name: str, arguments: dict) -> str:        
            # ...
            result = await session.call_tool(tool_name, arguments)
            return str(result.content[0].text)

async def call_anthropic_llm(user_query: str):
Introduction to Model Context Protocol (MCP)

Setup: Format the Tools for the LLM

async def call_anthropic_llm(user_query: str):
    """Call Claude with MCP tools."""

mcp_tools = await get_tools_from_mcp()
anthropic_tools = [] for tool in mcp_tools:
anthropic_tool = { "name": tool.name, "description": tool.description or "", "input_schema": tool.inputSchema, # MCP uses JSON Schema format }
anthropic_tools.append(anthropic_tool)
Introduction to Model Context Protocol (MCP)

1. Send the Query and Tools to the LLM

from anthropic import AsyncAnthropic
async def call_anthropic_llm(user_query: str):
    # ...

client = AsyncAnthropic(api_key="<ANTHROPIC_API_TOKEN>")
response = await client.messages.create( model="claude-sonnet-4-6", max_tokens=1024, messages=[{"role": "user", "content": user_query}], tools=anthropic_tools, )
Introduction to Model Context Protocol (MCP)

2. Checking for a Tool Call

async def call_anthropic_llm(user_query: str):
    # ...

    if response.stop_reason == "tool_use":

tool_use = next(b for b in response.content if b.type == "tool_use") name = tool_use.name args = tool_use.input print(f"Model decided to call: {name}") print(f"Arguments: {args}\n")
Introduction to Model Context Protocol (MCP)

3. Calling the Tool | 4. The Follow-Up Message

async def call_anthropic_llm(user_query: str):
    # ...

    if response.stop_reason == "tool_use":
        # ...

result = await call_mcp_tool(name, args)
tool_result = {"type": "tool_result", "tool_use_id": tool_use.id, "content": result} followup = await client.messages.create( model="claude-sonnet-4-6", max_tokens=1024, messages=[ {"role": "user", "content": user_query}, {"role": "assistant", "content": response.content}, {"role": "user", "content": [tool_result]}, ], tools=anthropic_tools, )
Introduction to Model Context Protocol (MCP)

5. The Final Response

async def call_anthropic_llm(user_query: str):
    # ...

    if response.stop_reason == "tool_use":
        # ...

final = next((b.text for b in followup.content if b.type == "text"), None) if final: print(f"\nAssistant: {final}") else: print("No follow-up message from model.")
else: text = next((b.text for b in response.content if b.type == "text"), "") print(f"\nAssistant: {text}") return str(text)
Introduction to Model Context Protocol (MCP)

Testing the Function

if __name__ == "__main__":
    asyncio.run(call_anthropic_llm("It is 9:50 AM in the UK in January. What time 
    is it in Lisbon, Portugal?"))
Assistant: It's 9:50 AM in Lisbon as well.
Introduction to Model Context Protocol (MCP)

The Tool-Calling Workflow

fct6.jpg

Introduction to Model Context Protocol (MCP)

Let's practice!

Introduction to Model Context Protocol (MCP)

Preparing Video For Download...