Skip to content

A Model Context Protocol (MCP) server that indexes PostgreSQL databases with **read-only** access and enables LLMs to query schema information - **without storing database content**.

Notifications You must be signed in to change notification settings

Kenny1338/monkey-postgres-mcp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PostgreSQL Schema MCP Server

A Model Context Protocol (MCP) server that indexes PostgreSQL database schemas and enables LLMs to query schema information and execute read-only SQL queries through natural language.

Overview

This MCP server provides:

  • Schema metadata indexing for PostgreSQL databases
  • Support for multiple PostgreSQL databases simultaneously
  • Background schema indexing with configurable intervals
  • Seamless integration with MCP-compatible clients (Kilo Code, Cursor, Claude Desktop)
  • Read-only query execution with built-in security controls
  • Natural language interface for database exploration

Why MCP?

The Model Context Protocol provides:

  • No custom UI/interface required
  • Direct integration with AI development tools
  • Standardized protocol for LLM tool calls
  • Native support for asynchronous operations

Architecture

┌─────────────────────────────────────────────────────────────┐
│                  LLM Client (MCP Compatible)                │
│  "Show me all tables in the database"                       │
└─────────────────────────┬───────────────────────────────────┘
                          │ MCP Protocol
┌─────────────────────────▼───────────────────────────────────┐
│                    MCP Server                                │
│  ┌──────────────────────────────────────────────────────┐   │
│  │ Tools: list_databases, get_schema, execute_query...  │   │
│  └──────────────────────────────────────────────────────┘   │
└─────────────────────────┬───────────────────────────────────┘
                          │
        ┌─────────────────┼─────────────────┐
        │                 │                 │
┌───────▼────────┐ ┌─────▼──────┐ ┌────────▼─────────┐
│ Schema Indexer │ │Schema Cache│ │ Metadata Store   │
│   (Worker)     │ │  (Memory)  │ │    (SQLite)      │
└───────┬────────┘ └────────────┘ └──────────────────┘
        │
        │ Read-Only Schema Queries
        │
┌───────▼─────────────────────────────────────────────────┐
│  PostgreSQL Databases (information_schema access)       │
│  ┌──────────┐  ┌──────────┐  ┌──────────┐             │
│  │   DB 1   │  │   DB 2   │  │   DB N   │             │
│  └──────────┘  └──────────┘  └──────────┘             │
└─────────────────────────────────────────────────────────┘

Quick Start

Prerequisites

  • Node.js 20+
  • PostgreSQL database(s)
  • MCP-compatible client (Kilo Code, Cursor, or Claude Desktop)

Installation

# Clone the repository
git clone <repository-url>
cd postgres-schema-mcp

# Install dependencies
npm install

# Configure environment variables
cp .env.example .env
# Edit .env and add your PostgreSQL credentials

# Create database configuration
cp config/databases.example.json config/databases.json
# Edit config/databases.json with your database details

# Build the project
npm run build

PostgreSQL Read-Only User Setup

For security, create a dedicated read-only user:

-- Create read-only user
CREATE USER readonly_user WITH PASSWORD 'secure_password';

-- Grant connection to database
GRANT CONNECT ON DATABASE your_database TO readonly_user;

-- Grant schema access
GRANT USAGE ON SCHEMA public TO readonly_user;

-- Grant access to information_schema and pg_catalog only
GRANT SELECT ON ALL TABLES IN SCHEMA information_schema TO readonly_user;
GRANT SELECT ON ALL TABLES IN SCHEMA pg_catalog TO readonly_user;

-- No direct data table access required for schema indexing

MCP Client Configuration

Add the server to your MCP client configuration:

Kilo Code / Cursor:

Location:

  • macOS/Linux: ~/.config/Code/User/globalStorage/kilocode.kilo-code/settings/mcp_settings.json
  • Windows: %APPDATA%\Code\User\globalStorage\kilocode.kilo-code\settings\mcp_settings.json

Configuration:

{
  "mcpServers": {
    "postgres-schema": {
      "command": "node",
      "args": ["/absolute/path/to/postgres-schema-mcp/dist/index.js"],
      "env": {
        "PG_SCHEMA_PASSWORD": "your_schema_password",
        "PG_QUERY_PASSWORD": "your_query_password"
      }
    }
  }
}

Running the Server

# Development mode with auto-reload
npm run dev

# Production mode
npm start

Configuration

Database Configuration

Create config/databases.json from the example:

{
  "databases": [
    {
      "id": "production-db",
      "name": "Production Database",
      "connection": {
        "host": "localhost",
        "port": 5432,
        "database": "myapp",
        "schemaUser": "readonly_schema_user",
        "schemaPassword": "${PG_SCHEMA_PASSWORD}",
        "queryUser": "readonly_query_user",
        "queryPassword": "${PG_QUERY_PASSWORD}",
        "ssl": false
      },
      "indexing": {
        "enabled": true,
        "interval": "1h",
        "schemas": ["public"],
        "excludeTables": ["migrations", "schema_version"]
      },
      "queryExecution": {
        "enabled": true,
        "maxLimit": 1000,
        "defaultLimit": 100,
        "timeout": 30000,
        "rateLimit": {
          "maxQueries": 100,
          "windowMs": 60000,
          "maxConcurrent": 5
        }
      }
    }
  ],
  "worker": {
    "parallelism": 3,
    "retryAttempts": 3
  }
}

Environment Variables

Create .env from .env.example:

# PostgreSQL Credentials
PG_SCHEMA_PASSWORD=your_schema_readonly_password
PG_QUERY_PASSWORD=your_query_readonly_password

# Metadata DB Path
METADATA_DB_PATH=./data/metadata.db

# Logging
LOG_LEVEL=info

Available MCP Tools

ask_monkey

Natural language database assistant powered by LLM reasoning.

Requirements:

  • Currently requires LM Proxy running with GitHub Copilot
  • Configure in .env:
    AGENT_ENABLED=true
    AGENT_LM_PROXY_URL=http://localhost:4000
    AGENT_MODEL=gpt-4o

Input:

{
  "question": "Show me all tables in the database",
  "databaseId": "production-db",
  "detailed": false
}

Ask in natural language - Monkey builds and executes the optimal SQL query for you.

Note: The Monkey agent is an autonomous database assistant that:

  • Analyzes your natural language questions
  • Reads database schemas automatically
  • Builds and executes optimized SQL queries
  • Returns formatted results with reasoning steps

For more details on LM Proxy setup, see the vscode-lm-proxy documentation.

CLI Tools

Add Database Interactively

npm run add-db

Interactive wizard to add new databases:

  • Connection details
  • SSL configuration
  • Schema selection
  • Query limits
  • Connection testing

Discover Schemas

npm run discover

Explore schemas in configured databases.

View Logs

npm run logs

View server logs for debugging and monitoring.

Project Structure

postgres-schema-mcp/
├── src/
│   ├── index.ts              # Entry point
│   ├── mcp/
│   │   ├── server.ts         # MCP server implementation
│   │   └── tools/            # Tool implementations
│   ├── agent/
│   │   └── monkey.ts         # Natural language query agent
│   ├── db/
│   │   └── metadata.ts       # SQLite metadata store
│   ├── services/
│   │   ├── schemaExtractor.ts
│   │   ├── queryExecutor.ts
│   │   └── queryValidator.ts
│   └── types/
│       └── index.ts
├── config/
│   └── databases.json        # Database configurations
├── data/
│   └── metadata.db           # Schema cache
└── bin/
    └── monkey.cjs            # CLI wrapper

Development

Scripts

# Development
npm run dev          # Start with auto-reload
npm run build        # Build TypeScript
npm start            # Start production server

# Database Management
npm run add-db       # Add new database
npm run discover     # Discover schemas

# Utilities
npm run logs         # View logs
npm run help         # Show all commands

Testing

# Run all tests
npm test

# Run specific test suites
npm run test:unit
npm run test:integration

Security

Best Practices

  1. Read-Only Users: Always use dedicated read-only PostgreSQL users
  2. Environment Variables: Never commit credentials to version control
  3. SSL/TLS: Use SSL for production databases
  4. Least Privilege: Grant only necessary schema access permissions
  5. Rate Limiting: Configure appropriate query rate limits

What is NOT Stored

  • No row data from tables
  • No column contents
  • No sensitive information
  • Only schema metadata (structure)

Query Execution Security

  • Only SELECT queries allowed
  • Automatic LIMIT enforcement
  • Query timeout protection
  • Rate limiting per database
  • Read-only transaction mode
  • Query validation and sanitization

Performance

Optimizations

  • In-memory schema caching
  • Incremental schema updates
  • Parallel database indexing
  • Connection pooling
  • SQLite indexes for fast metadata queries

Typical Indexing Times

  • Small database (< 50 tables): 5-10 seconds
  • Medium database (50-200 tables): 30-60 seconds
  • Large database (200+ tables): 2-5 minutes

Troubleshooting

Server Fails to Start

# Check Node.js version
node --version  # Should be >= 20

# Reinstall dependencies
npm install

# Check logs
npm run logs

Database Connection Issues

# Test connection manually
psql -h localhost -U readonly_user -d your_database

# Check user permissions
\du readonly_user

MCP Client Not Detecting Server

  1. Verify absolute path in MCP configuration
  2. Rebuild the project: npm run build
  3. Restart the MCP client completely
  4. Check client logs for errors

Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

MIT License - see LICENSE file for details

Credits

  • Model Context Protocol by Anthropic
  • PostgreSQL - The world's most advanced open source database
  • Node.js runtime

Support

For issues or questions:

  • Open an issue on GitHub
  • Check existing issues and documentation
  • Review the troubleshooting section

Built for better LLM-database integration through the Model Context Protocol.

About

A Model Context Protocol (MCP) server that indexes PostgreSQL databases with **read-only** access and enables LLMs to query schema information - **without storing database content**.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published