CockroachDB
A server for direct interaction with CockroachDB databases.
CockroachDB MCP Server
This is a CockroachDB MCP server for Cursor, implemented based on the Model Context Protocol (MCP) specification, allowing you to interact directly with CockroachDB database in Cursor.
Features
- Connect to CockroachDB database
- Get all tables from the database
- Get table structure information
- Execute SQL queries
- Provide database status resources
- Provide SQL query templates
- Automatic reconnection mechanism to ensure connection stability
- Connection keep-alive mechanism to prevent connection timeout
- Graceful process exit handling
- Detailed logging for troubleshooting
- Support manual disconnection
Installation
Installing via Smithery
To install CockroachDB MCP Server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @Swayingleaves/cockroachdb-mcp-server --client claude
- Clone the repository and enter the project directory
- Install dependencies:
pip install -r requirements.txt
- Install uv
curl -LsSf https://astral.sh/uv/install.sh | sh
Using in Cursor
{
"mcpServers": {
"cockroachdb-mcp": {
"command": "uv",
"args": [
"--directory",
"/Users/local/cockroachdb-mcp",
"run",
"server.py"
],
"jdbc_url": "jdbc:postgresql://localhost:26257/defaultdb",
"username": "root",
"password": "root"
}
}
}
MCP Function Description
Tools
connect_database
Connect to CockroachDB database.
Parameters:
jdbc_url: JDBC connection URL (e.g., jdbc:postgresql://localhost:26257/defaultdb)username: Database usernamepassword: Database password
initialize_connection
Initialize database connection, can be called immediately after connecting to the MCP server to establish a database connection.
Parameters:
jdbc_url: JDBC connection URL (e.g., jdbc:postgresql://localhost:26257/defaultdb)username: Database usernamepassword: Database password
disconnect_database
Manually disconnect from the database.
No parameters.
get_tables
Get all tables from the database.
No parameters.
get_table_schema
Get structure information of a specified table.
Parameters:
table_name: Table name
execute_query
Execute SQL query.
Parameters:
query: SQL query statement
Resources
db://status
Get database connection status.
Returns:
- When not connected:
"Not connected" - When connected:
"Connected - [Database version]" - When connection error:
"Connection error - [Error message]"
Prompts
sql_query_template
SQL query template to help users write SQL queries.
Logs
Server logs are saved in logs/cockroachdb_mcp.log file. You can check this file to understand the server's running status and detailed logs.
The log file uses a rotating log mechanism, with each log file maximum size of 10MB and keeping up to 5 backup files to prevent excessive disk space usage.
Special Character Handling
This server uses psycopg2 to connect directly to CockroachDB database, which automatically handles special characters in usernames and passwords without additional URL encoding. This ensures correct database connection even when passwords contain special characters (such as @, %, &, etc.).
TCP Keep-alive Settings
The server is configured with TCP keep-alive mechanism by default to prevent connections from being closed due to long periods of inactivity:
keepalives=1: Enable TCP keepalivekeepalives_idle=30: Send keepalive after 30 seconds of idle timekeepalives_interval=10: Send keepalive every 10 secondskeepalives_count=5: Give up after 5 attempts
Troubleshooting
If you encounter problems, please check the log file logs/cockroachdb_mcp.log, which will help you understand the server's running status and potential issues.
Common Issues
- Connection Refused: Ensure the CockroachDB server is running and accessible from your machine.
- Authentication Failed: Check if the username and password are correct.
- Connection Timeout: Check if the network connection is stable, especially when connecting to a remote database.
- Database Server Issues: Check if the CockroachDB server is running properly.
Servidores relacionados
Pokemon
Provides access to a comprehensive Pokemon database through a standardized MCP interface.
Google Data Catalog by CData
A read-only MCP server for Google Data Catalog, powered by CData. Requires a separate CData JDBC Driver for operation.
MCP ArcKnowledge
Manage and query custom knowledge bases using webhook endpoints.
mcp-clickhousex
A read-only MCP server for ClickHouse that supports metadata discovery, parameterized queries, and query analysis.
UniProt MCP Server
Fetch protein information from the UniProt database.
OPTIMADE MCP Server
A configurable MCP server for the OPTIMADE API, allowing custom filters and endpoints for materials science databases.
Generect MCP
Generect MCP connects your live lead database directly to AI models like OpenAI or Claude without exports or delays. It streams enriched, up-to-date contact data (titles, firmographics, signals) straight into prompts so LLMs can personalize, score, and recommend leads automatically in real time.
CData Sage 300
A read-only MCP server by CData that enables LLMs to query live data from Sage 300.
Instructure DAP
Query Canvas and other Instructure data using the Instructure Data Access Platform (DAP) API.
Powerdrill
An MCP server that provides tools to interact with Powerdrill datasets, enabling smart AI data analysis and insights.