Skip to main content

SingleStore MCP server

Project description

SingleStore MCP Server

MIT Licence PyPI Downloads Smithery

Model Context Protocol (MCP) is a standardized protocol designed to manage context between large language models (LLMs) and external systems. This repository provides an installer and an MCP Server for Singlestore, enabling seamless integration.

With MCP, you can use Claude Desktop, Cursor, or any compatible MCP client to interact with SingleStore using natural language, making it easier to perform complex operations effortlessly.

Requirements

  • Python >= v3.11.0
  • uvx installed on your python environment
  • Claude Desktop, Cursor, or another supported LLM client

Client Setup

1. Init Command

The simplest way to set up the MCP server is to use the initialization command:

uvx singlestore-mcp-server init

This command will:

  1. Authenticate the user
  2. Automatically locate the configuration file for your platform
  3. Create or update the configuration to include the SingleStore MCP server
  4. Provide instructions for starting the server

You can also explicitly pass a <SINGLESTORE_API_KEY>:

uvx singlestore-mcp-server init <SINGLESTORE_API_KEY>

To specify a client (e.g., claude or cursor), use the --client flag:

uvx singlestore-mcp-server init <SINGLESTORE_API_KEY> --client=<client>

2. Installing via Smithery

To install mcp-server-singlestore automatically via Smithery:

npx -y @smithery/cli install @singlestore-labs/mcp-server-singlestore --client=<client>

Replace <client> with claude or cursor as needed.

3. Manual Configuration

Claude Desktop and Cursor

  1. Add the following configuration to your client configuration file:
  • Claude Desktop:

  • Cursor

    {
      "mcpServers": {
       "singlestore-mcp-server": {
        "command": "uvx",
        "args": [
          "singlestore-mcp-server",
          "start",
          "<SINGLESTORE_API_KEY>"
        ]
       }
      }
    }
    
  1. Restart your client after making changes to the configuration.

Components

Tools

The server implements the following tools:

  • workspace_groups_info: Retrieve details about the workspace groups accessible to the user
    • No arguments required
    • Returns details of the workspace groups
  • workspaces_info: Retrieve details about the workspaces in a specific workspace group
    • Arguments: workspaceGroupID (string)
    • Returns details of the workspaces
  • organization_info: Retrieve details about the user's current organization
    • No arguments required
    • Returns details of the organization
  • list_of_regions: Retrieve a list of all regions that support workspaces for the user
    • No arguments required
    • Returns a list of regions
  • execute_sql: Execute SQL operations on a connected workspace
    • Arguments: workspace_group_identifier, workspace_identifier, username, password, database, sql_query
    • Returns the results of the SQL query in a structured format
  • list_virtual_workspaces: List all starter workspaces accessible to the user
    • No arguments required
    • Returns details of available starter workspaces
  • create_virtual_workspace: Create a new starter workspace with a user
    • Arguments:
      • name: Name of the starter workspace
      • database_name: Name of the database to create
      • username: Username for accessing the workspace
      • password: Password for the user
      • workspace_group: Object containing name (optional) and cellID (mandatory)
    • Returns details of the created workspace and user
  • execute_sql_on_virtual_workspace: Execute SQL operations on a virtual workspace
    • Arguments: virtual_workspace_id, username, password, sql_query
    • Returns the results of the SQL query in a structured format including data, row count, columns, and status
  • list_notebook_samples: List all notebook samples available in SingleStore Spaces
    • No arguments required
    • Returns details of available notebook samples
  • create_notebook: Create a new notebook in the user's personal space
    • Arguments: notebook_name, content (optional)
    • Returns details of the created notebook
  • list_personal_files: List all files in the user's personal space
    • No arguments required
    • Returns details of all files in the user's personal space
  • create_scheduled_job: Create a new scheduled job to run a notebook
    • Arguments:
      • name: Name for the job
      • notebook_path: Path to the notebook to execute
      • schedule_mode: Once or Recurring
      • execution_interval_minutes: Minutes between executions (optional)
      • start_at: When to start the job (optional)
      • description: Description of the job (optional)
      • create_snapshot: Whether to create notebook snapshots (optional)
      • runtime_name: Name of the runtime environment
      • parameters: Parameters for the job (optional)
      • target_config: Target configuration for the job (optional)
    • Returns details of the created job
  • get_job_details: Get details about a specific job
    • Arguments: job_id
    • Returns detailed information about the specified job
  • list_job_executions: List execution history for a specific job
    • Arguments: job_id, start (optional), end (optional)
    • Returns execution history for the specified job

Dockerization

Building the Docker Image

To build the Docker image for the MCP server, run the following command in the project root:

docker build -t mcp-server-singlestore .

Running the Docker Container

To run the Docker container, use the following command:

docker run -d \
  -p 8080:8080 \
  --name mcp-server \
  mcp-server-singlestore

Using Docker Secrets

To securely pass secrets to the container, create a Docker secret and mount it:

echo "your-secret-value" | docker secret create mcp_secret -

Then, run the container with the secret:

docker service create \
  --name mcp-server \
  --secret mcp_secret \
  mcp-server-singlestore

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

singlestore_mcp_server-0.2.7.tar.gz (67.9 kB view details)

Uploaded Source

Built Distribution

singlestore_mcp_server-0.2.7-py3-none-any.whl (39.3 kB view details)

Uploaded Python 3

File details

Details for the file singlestore_mcp_server-0.2.7.tar.gz.

File metadata

  • Download URL: singlestore_mcp_server-0.2.7.tar.gz
  • Upload date:
  • Size: 67.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for singlestore_mcp_server-0.2.7.tar.gz
Algorithm Hash digest
SHA256 afb03f8a68905c12678bad245a9297b73fecf31c83e63f0073d1828af7beceae
MD5 d3c908cf8e7b9613fce60327d9215114
BLAKE2b-256 e12abb94089afb3a0301fb0992a9b31f77b63a2ab5fbd7dc32b294b07cc312eb

See more details on using hashes here.

File details

Details for the file singlestore_mcp_server-0.2.7-py3-none-any.whl.

File metadata

File hashes

Hashes for singlestore_mcp_server-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a7c75a7e616157a0156486513113587c11f8b0a69f2555a9179c56482ab92d3d
MD5 d1003b2101fb1324f3f7f0dcb9e7e5ae
BLAKE2b-256 43691998dbc4e51d1a436025c1dd6496582c29b44d5370fda94ad848594550d6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page