How to Create Remote MCP Server with MCP Proxy
-
by Blog Admin
- 39
Learn how to deploy an MCP server on Vultr using FastMCP and connect it with Claude Desktop via a local proxy. Explore how MCP enables natural language interfaces for structured, context-aware workflows.
The Model Context Protocol (MCP) is a new standard for organizing contextual data used by Large Language Models (LLMs). Instead of relying only on plain prompts, MCP structures key information—like user identity, goals, memory, and tools—so models can act more consistently across sessions, apps, and environments. By encoding context in a formal way, MCP makes it easier to integrate LLMs into intelligent, tool-aware workflows.
In this article, we’ll take you through the steps of running a sample MCP (Model Context Protocol) server built with FastMCP, hosted on a Vultr cloud instance. The server is backed by an SQLite database and exposes natural-language-powered endpoints that you can interact with using your local Claude Desktop application. By setting up a local mcp-proxy
, you’ll be able to bridge Claude with your remote MCP server, allowing seamless queries and database operations directly from your desktop environment.
Get Started Right Away
The code for the MCP server and the sample SQLite database is available in this GitHub repository. To set up the server remotely, follow the steps below in your system terminal.
- Deploy an Ubuntu Server on Vultr.
- Clone the Github Repository
console
$ git clone https://github.com/vultr-marketing/code-samples.git
- Navigate into the
mcp_sqlite_sse
directory.console$ cd code-samples/mcp/mcp_sqlite_sse
- Create a
.env
file.console$ nano .env
- Add the following variables in the file.
DB_PATH=sample.db MCP_PORT=8080 READ_ONLY=true
DB_PATH
: Path to your SQLite database file.MCP_PORT
: Port used by the MCP server (not used in stdio mode, but good to define).READ_ONLY
: Set to true to block insert/update/delete queries for safety. Save and close the file.
- Install dependencies.
console
$ pip3 install -r requirements.txt
- Allow incoming connections to port
8080
.console$ ufw allow 8080
- Run the MCP Server.
console
$ python3 server.py
Understand the Sample MCP Server
The server script launches a Model Context Protocol (MCP) server using FastMCP
and connects it to a local SQLite database. It enables structured interaction with the database using natural language, typically via an LLM interface.
Transport Layer http
with Server-Sent Events (SSE)
The server uses the http
transport layer to communicate over standard web protocols—ideal for remote deployment on platforms like Vultr. It supports Server-Sent Events (SSE), a crucial feature that enables real-time, streamed responses from the server to your local Claude Desktop via mcp-proxy
.
SSE is a core part of live interaction between Claude and your remote MCP server. It ensures that streamed responses (like query results or multi-step outputs) arrive smoothly and in real-time.
This design allows Claude Desktop to interact with your database seamlessly, as if the server were running locally. The SSE implementation is lightweight and handled within the FastAPI-based backend exposed by FastMCP.
For an overview of the server’s features and tools, see the How to Create MCP Server Using FastMCP in Python article on Vultr Docs.
Use Claude Desktop to Interact
Download the Claude Desktop application, it automatically detects MCP servers defined in its configuration file and makes them accessible for use within any conversation.
- Install the
mcp-proxy
dependency on your local system.console$ uv tool install mcp-proxy
- Get the path to the installed dependency.
console
$ where mcp-proxy
Copy the path to be used later.
- Start the Claude Desktop application.
- Locate the settings option in the application.
- Select Developer settings.
- Click on Edit Config.
- Add the following configuration snippet to your Claude Desktop config file.
json
{ "mcpServers": { "vultr-fastmcp": { "command": "<MCP_PROXY_PATH>", "args": [ "http://<VULTR_SERVER_IP>:8080/sse" ], "env": { "API_ACCESS_TOKEN": "" } } } }
- Once the new configuration is in place, restart the Claude desktop application.
- To confirm the server is running, go to the Developer settings in Claude Desktop and check if the status next to the JSON file shows as running.
- Make sure the MCP server tools are available to the application.
Ask Questions and Perform Operations
You can run interactive queries by chatting naturally. Using the available tools, the LLM will translate your requests into SQL queries, execute them on the sample database, and respond in plain language.
The data shown in the image is sample data used for demonstration purposes and may differ from actual data. The LLM will also display the database queries it is executing and the tools it is using to retrieve the data.Conclusion
By following this article, you’ve learned how to deploy a FastMCP-based MCP server on a Vultr cloud instance and connect it with Claude Desktop using a local
mcp-proxy
. This setup transforms your desktop into a natural language interface for remote structured data, allowing you to issue queries and commands effortlessly. It also highlights the power of MCP in creating persistent, context-aware systems that can scale across different environments. With this foundation in place, you can now explore building more advanced agents, integrating additional tools, or expanding your MCP server to support collaborative multi-agent workflows.
Learn how to deploy an MCP server on Vultr using FastMCP and connect it with Claude Desktop via a local proxy. Explore how MCP enables natural language interfaces for structured, context-aware workflows. The Model Context Protocol (MCP) is a new standard for organizing contextual data used by Large Language Models…
Learn how to deploy an MCP server on Vultr using FastMCP and connect it with Claude Desktop via a local proxy. Explore how MCP enables natural language interfaces for structured, context-aware workflows. The Model Context Protocol (MCP) is a new standard for organizing contextual data used by Large Language Models…