QGIS MCP
Provides tools for interacting with QGIS, enabling AI agents to manage projects, layers, execute processing algorithms, and run arbitrary PyQGIS code within a QGIS environment.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@QGIS MCPCreate a new project and load a shapefile of rivers."
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
QGIS MCP (hardened fork)
QGIS MCP connects QGIS to an LLM through the Model Context Protocol (MCP), allowing agentic interaction with and control of QGIS. This enables prompt-assisted project creation, layer loading, code execution and more.
Attribution & lineage
This is a hardened fork, distributed under GPL v3 (see LICENSE). Credit to the chain it builds on:
BlenderMCP by Siddharth Ahuja — the original concept.
QGIS MCP by Juan Santos Ochoa (jjsantos01) — the QGIS adaptation this is based on.
QGIS2OllamaMCP by Anita Graser — the immediate upstream of this fork.
What this fork changes
See CHANGELOG.md for details. In short, two security hardening changes (both untested against a live QGIS — verify locally before relying on them):
Shared-secret token on the plugin socket (port 9876). The plugin generates a random token in
~/.qgis_mcp/tokenon first run; the MCP server reads the same file and must present the token, so other local processes can't drive QGIS just by reaching the socket.Loopback-only MCP server. The MCP server (port 9877) now binds explicitly to
127.0.0.1, so it is never exposed to your network regardless of library defaults.
⚠️ Security note: by design this tool lets the LLM run arbitrary Python inside QGIS (the
execute_codetool). Only run the plugin/server while you are actively using it, and only on a machine you trust. After starting, confirm port 9877 is on127.0.0.1withnetstat -ano | findstr 9877.The token check is fail-open: if the plugin cannot read or write
~/.qgis_mcp/token, it logs a warning and runs without authentication rather than refusing to start. Watch the QGIS log to confirm the token loaded.
Related MCP server: QGISMCP
Components
The system consists of two main components:
QGIS plugin: A QGIS plugin that creates a socket server within QGIS to receive and execute commands.
MCP Server: A Python server that implements the Model Context Protocol and connects to the QGIS plugin.
Installation
Prerequisites
QGIS 3.X (tested with 3.38)
Ollama and model with support for agents (tested with ministral-3:latest)
For the MCP server Python environment:
pip install fastmcp ollama(the upstreamrequestsandlupaare not used by this code and are omitted)
QGIS plugin
To install the plugin, you need to copy the folder qgis_mcp_plugin and its content into your QGIS plugins folder.
Usage
Starting the connection in QGIS
In QGIS, go to
plugins>QGIS2OllamaMCP>QGIS2OllamaMCP
Click "Start Server"
Will launch on localhost:9876 by default.Check the logs to see the connection status

Starting the MCP server
python src/qgis_mcp/qgis_mcp_server.py
Will launch on localhost:9877/sse by default (bound to 127.0.0.1).
Tools
ping- Simple ping command to check server connectivityget_qgis_info- Get QGIS information about the current installationload_project- Load a QGIS project from the specified pathcreate_new_project- Create a new project and save itget_project_info- Get current project informationadd_vector_layer- Add a vector layer to the projectadd_raster_layer- Add a raster layer to the projectget_layers- Retrieve all layers in the current projectremove_layer- Remove a layer from the project by its IDzoom_to_layer- Zoom to the extent of a specified layerget_layer_features- Retrieve features from a vector layer with an optional limitexecute_processing- Execute a processing algorithm with the given parameterssave_project- Save the current project to the given pathrender_map- Render the current map view to an image fileexecute_code- Execute arbitrary PyQGIS code provided as a string
Starting the conversation
You can launch an example conversation using:
python src/qgis_mcp/qgis_mcp_client.py
Note: you need to update the project file path to point to a project file on your machine.
Then launch the interactive client to start experimenting:
python src/qgis_mcp/qgis_mcp_client_interactive.py
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Sir-Adrien-Claudington/QGIS-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server