Adding Resources in Multi-Server MCP
Learn how to implement MCP resources in multiple servers to read from external data sources and update a client to discover and execute these guided workflows.
We'll cover the following...
downloadOur agent is now an effective orchestrator, capable of managing a diverse set of tools and user-driven prompts from both the weather_server and the task_server. However, its awareness of the world is still incomplete. While we have seen how resources can provide context from a single source, a truly powerful assistant must be able to draw upon data from multiple, specialized domains.
This brings us to the next level of orchestration: managing distributed data. How can our client discover resources from multiple servers at the same time? How does it load context from one server and use it to inform a task on another? In this lesson, we will solve this by adding resources to both servers and upgrading our client to seamlessly handle context from any connected source, making our agent truly data-aware across the entire system.
Expanding our multi-server scenario
In earlier lessons, we built an agent with the ability to read the delivery_log resource from the weather_server. But in any real-world application, relevant data is rarely stored in one place. It is often distributed across different systems and domains. Let’s expand our scenario to reflect this reality. Imagine our user, a team lead, not only needs to check the weather for deliveries but also needs to manage action items from their weekly sync. These action items are stored in a separate meeting_notes.txt file, which is naturally managed by the task_server.
This presents a clear orchestration challenge for our client:
- How can it present a unified view of all available data sources, the delivery log from the - weather_serverand the meeting notes from the- task_server?
- When a user wants to load the meeting notes, how does the client know to query the - task_serverspecifically?
- How can we empower the user to load the - meeting_notesto create new tasks, and then seamlessly switch contexts to load the- delivery_logto check for weather delays?
The simple client we have now cannot handle this distributed context. It needs to be upgraded into a more intelligent orchestrator that can manage and present a catalog of resources from our entire multi-server ecosystem.
To enable our client to solve this orchestration problem, our first step is to ensure that both servers are properly configured to expose their unique data resources.
Adding resources to our MCP servers
We will now enhance each of our existing servers, using the @mcp.resource() decorator to expose specific data files as readable resources. We will start by reviewing the delivery_log resource we ...