MCP Database Server with read-only access
Project description
MCP Database Server
A Model Context Protocol (MCP) server implementation in Python that provides strictly read-only access to databases. It allows Large Language Models (LLMs) to inspect schemas and query data safely without risking data modification.
Features
- 🛡️ Strict Read-Only: Enforced at the driver level (e.g., SQLite
?mode=ro) or session level (MySQLSET SESSION TRANSACTION READ ONLY). - 🏗️ Repository Pattern: Abstracted database access allows for easy extension to other backends (PostgreSQL, MySQL) via Dependency Injection.
- ⚡ FastMCP: Built efficiently using the official MCP Python SDK.
- 🔌 Connection Pooling: Automatic connection pooling for MySQL using
DBUtilsto ensure performance and reliability. - 🔧 Easy Configuration: Managed via environment variables and Makefiles.
Project Structure
mcp_db_server/: Main Python package for the MCP server.__init__.py: Entry point and server initialization.db/: Repository implementations (sqlite_repository.py,mysql_repository.py).
seed.py: Utility script to populate the database (write access).Makefile: Automation for common tasks.pyproject.toml: Package configuration and dependencies.
Quick Start
Prerequisites
- Python 3.12+ (managed via
venv) make(optional, but recommended)- MySQL Server (optional, if using MySQL backend)
1. Setup
Use the Makefile to create a virtual environment, install dependencies, and seed a test database:
make setup
This runs pip install -r requirements.txt and python seed.py.
2. Configuration
The project uses python-dotenv. Copy the example config and adjust as needed:
cp .env.example .env
Key Variables:
DB_ENGINE:sqlite(Default) ormysqlDB_ADDRESS: Path to db file (SQLite) or Host URL (MySQL).DB_PORT: Database port (Default: 3306 for MySQL).DB_USER/DB_PASSWORD: Database credentials (required for MySQL).DB_SCHEMA: Database name (required for MySQL).
3. Run the Server
Start the MCP server:
make run
(Or directly via venv/bin/python server.py)
Usage with LLMs
Once running, the server exposes the following tools to connected MCP clients:
list_tables()- Returns a list of all tables in the database.
describe_table(table_name: str)- Returns the schema (columns, types, primary keys) for the specified table.
read_query(query: str)- Executes a SQL
SELECTquery. - Note: Queries attempting to modify data will raise a
Security ErrororOperationalError.
- Executes a SQL
Development
Running Tests
Execute the unit test suite:
make test
Extending
To add support for a new database (e.g., Postgres):
- Create
db/postgres_repository.pyimplementation ofDatabaseRepository. - Update
server.pyto instantiate it whenDB_ENGINE=postgres.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_db_server-0.1.3.tar.gz.
File metadata
- Download URL: mcp_db_server-0.1.3.tar.gz
- Upload date:
- Size: 5.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e3d50a62725c79cf46c4030ef4c434201940fc2b797fe9cdd3d5069d90454aff
|
|
| MD5 |
481dce78d9141ed7c65b317c4b7d34e8
|
|
| BLAKE2b-256 |
f4679c33cf7cbd4d74700da0e8a22691b373163ea083cb2a4e08803dcb49c6b8
|
Provenance
The following attestation bundles were made for mcp_db_server-0.1.3.tar.gz:
Publisher:
python-publish.yml on monkey-mode/mcp-db-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_db_server-0.1.3.tar.gz -
Subject digest:
e3d50a62725c79cf46c4030ef4c434201940fc2b797fe9cdd3d5069d90454aff - Sigstore transparency entry: 924386467
- Sigstore integration time:
-
Permalink:
monkey-mode/mcp-db-server@500bbd3142afb8aab3dadc720199a1071dc273b5 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/monkey-mode
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@500bbd3142afb8aab3dadc720199a1071dc273b5 -
Trigger Event:
release
-
Statement type:
File details
Details for the file mcp_db_server-0.1.3-py3-none-any.whl.
File metadata
- Download URL: mcp_db_server-0.1.3-py3-none-any.whl
- Upload date:
- Size: 7.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49fd9cd9e293db21641e81d769864b632fd78f4e6b266c54483fe744d3cce9d3
|
|
| MD5 |
37f835d058b7043d8ed7267289ade978
|
|
| BLAKE2b-256 |
f17ab46f090875e7e8084a7f7e98aadcddf33e677a5d13e2c7c1f1b022076c6b
|
Provenance
The following attestation bundles were made for mcp_db_server-0.1.3-py3-none-any.whl:
Publisher:
python-publish.yml on monkey-mode/mcp-db-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_db_server-0.1.3-py3-none-any.whl -
Subject digest:
49fd9cd9e293db21641e81d769864b632fd78f4e6b266c54483fe744d3cce9d3 - Sigstore transparency entry: 924386469
- Sigstore integration time:
-
Permalink:
monkey-mode/mcp-db-server@500bbd3142afb8aab3dadc720199a1071dc273b5 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/monkey-mode
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@500bbd3142afb8aab3dadc720199a1071dc273b5 -
Trigger Event:
release
-
Statement type: