This project contains the source code for the Kinetica Model Context Protocol (MCP) server, as well as examples of how to configure and run the server.
The Kinetica MCP server exposes tools and resources for interacting with Kinetica's database, SQL-GPT contexts, and real-time monitoring.
The MCP server has separate modes depending on how you want the LLM to generate SQL. Each mode contains a different set tools to facilitate the workflow. This functionality is controlled by the environment variable KINETICA_TTS_MODE.
-
Server-side Inference Mode (KINETICA_TTS_MODE=server)
The LLM will choose a SQL context and use Kinetica's native text-to-sql capabilities via the
generate_sql()tool. This requires that you have appropriate SQL contexts configured in Kinetica. (see SQL-GPT). Available tools are:list_sql_contextsgenerate_sqlquery_sqldescribe_table
-
Local Inference Mode (KINETICA_TTS_MODE=local, default)
The LLM will retrieve table descriptions generate its own SQL. This mode will result in more tokens being consumed from table descriptions but it does not require the use of SQL contexts. Available tools are:
- resource
sql-context://{context_name} - resource
table-monitor://{table} query_sqldescribe_tablestart_table_monitorkinetica_sql_promptlist_tablesget_recordsinsert_records
- resource
-
list_tables()List all available tables, views, and schemas in the Kinetica instance. Results will be filtered by the KINETICA_SCHEMA env variable.
-
describe_table(table_name: str)Return a dictionary of column name to column type.
-
query_sql(sql: str, limit: int = 10)Run a read-only SQL query on the database, returns results as JSON.
-
get_records(table_name: str, limit: int = 10)Fetch raw records from a table as a list of dictionaries.
-
insert_records(table_name: str, records: list[dict])Insert a list of records into the specified table.
-
start_table_monitor(table: str)Start a real-time monitor for inserts, updates, and deletes on a table.
-
list_sql_contexts()List available SQL contexts and their corresponding tables.
-
generate_sql(context_name: str, question: str)Generate SQL queries using Kinetica's text-to-SQL capabilities.
-
sql-context://{context_name}Return a structured view of a SQL-GPT context, including:
context_name: Fully qualified table name.tables: Table descriptions containing description, table rules, and column comments.rules: List of defined semantic rules.samples: One shot training examples.
The server can optionally be configured to support the OAUTH authorization-code workflow. Common variables are:
KINETICA_URL: The Kinetica API URL (e.g.http://your-kinetica-host:9191)KINETICA_SCHEMA: Filter tables by schema (optional, default=*)KINETICA_LOGLEVEL: Server Loglevel (optional, default=warning)KINETICA_TTS_MODE: Indicates the tex-to-sql mode (serverorlocal)
See conf_tmpl.sh for an example configuration.
If the MCP will allow access from any user you must specify a username/password that it should use when connecting to Kinetica.
KINETICA_USER: Kientica usernameKINETICA_PASSWD: Kinetica password
When OAUTH is enabled users will be redirected to the authentication server where they will enter their Kinetica credentials. The authentication server will then redirected back to the MCP server where they will be given an authentication token. This token can be perpetually cached to avoid the need for future authentications. Additionally the MCP server will authenticate with Kinetica using a handshake key that will allow it to impersonate the authenticated user and their permissions.
To enable this you will need:
- An Authentication server capable of providing an Authorization Grant.
- The kinetica handshake key.
The required parameters to enable set these variables:
KINETICA_OAUTH_HANDSHAKE_KEY: The unencrypted handshake key. This can be found inhttpd/etc/gpudb_httpd.conf.KINETICA_OAUTH_EXTERNAL_HOST: The external of the MCP and OAUTH servers.
Note: It is recommended that you not use
KINETICA_SCHEMAonly when you are using OAUTH2
In this example we will invoke the uv run command to install the mcp-kinetica package automatically when
Claude desktop starts. For this to work we will use uv to create a virtual environment with python >=3.10 that
will be used by the MCP runtime.
If you have not already downloaded Claude desktop you can get it at https://claude.ai/download.
Note: As an alternative you could install the
mcp-kineticawith pip and avoid using UV but it is recommended in the fastmcp documentation.
-
Make sure you have UV installed.
pip install --upgrade uv
-
Create the python virtual environment.
You must choose a directory
<your_venv_path>for the python runtime.uv venv --python 3.12 <your_venv_path>
-
Make a note of the
pythonanduvpaths.UV and your VENV could be using different python interpreters. Make a note of these paths and save them for the claude config file.
Note: Windows users should activate with
<your_venv_path>/bin/activate.bat$ source <your_venv_path>/bin/activate $ which uv <uv_exe_path> $ which python <python_exe_path>
-
Open your Claude Desktop configuration file:
The app provides a shortcut in Settings->Developer->Edit Config.
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%/Claude/claude_desktop_config.json
- macOS:
-
Add an
mcp-kineticaentry to themcpServersblock:You will need to edit the
<uv_exe_path>,<python_exe_path>, and Kinetica connection info.{ "mcpServers": { "mcp-kinetica": { "command": "<uv_exe_path>", "args": [ "run", "--python", "<python_exe_path>", "--with", "setuptools", "--with", "mcp-kinetica", "mcp-kinetica" ], "env": { "KINETICA_URL": "<http://your-kinetica-host:9191>", "KINETICA_USER": "<your_username>", "KINETICA_PASSWD": "<your_password>", "KINETICA_LOGLEVEL": "INFO", "KINETICA_SCHEMA": "*", "KINETICA_TTS_MODE": "server" } } } } -
Restart Claude Desktop to apply the changes.
In Claude Desktop open Settings->Connectors and look for an entry named mcp-kinetica.
The MCP Inspector is a web UI used for exploring the features of an MCP Service and simulating the activities of an LLM model. You will need Node.js >= 18 for the inspector.
-
Clone the GitHub project:
git clone git@github.com:kineticadb/mcp-kinetica.git cd mcp-kinetica -
Create a
.envfile in your project root with the following keys:KINETICA_URL=http://<your-kinetica-host>:9191 KINETICA_USER=<your_username> KINETICA_PASSWD=<your_password>
-
Update Python environment with uv:
[~/mcp-kinetica]$ pip install uv [~/mcp-kinetica]$ uv sync
-
Activate Python environment:
-
Windows:
.venv\Scripts\activate.bat
-
Linux:
[~/mcp-kinetica]$ source .venv/bin/activate
-
-
Use
fastmcp devfor an interactive testing environment with the MCP Inspector:[~/mcp-kinetica]$ fastmcp dev mcp_kinetica/mcp_main.py
To create a local package in editable mode:
[~/mcp-kinetica]$ fastmcp dev mcp_kinetica/mcp_main.py --with-editable . -
Launch MCP Inspector in a browser, pointing at the URL output by the
fastmcpcommand; for instancehttp://127.0.0.1:6274, given this output:Starting MCP inspector... Proxy server listening on port 6277 MCP Inspector is up and running at http://127.0.0.1:6274
Note: MCP inspector will default to
uvas the command to run. If not usinguvfor package management, the MCP Inspector parameters can be updated as follows:
- Command:
python3- Arguments:
mcp_kinetica/mcp_main.py
This section describes how to run unauthenticated test cases under tests/.
Note: The
uvutility is not required.
-
Clone the GitHub project:
git clone git@github.com:kineticadb/mcp-kinetica.git cd mcp-kinetica -
Create a
.envfile in your project root with the following keys:KINETICA_URL=http://<your-kinetica-host>:9191 KINETICA_USER=<your_username> KINETICA_PASSWD=<your_password>
-
Install the test dependencies:
[~/mcp-kinetica]$ pip install --group test .
-
Run pytest:
[~/mcp-kinetica]$ pytest -rA [...] PASSED tests/test_server_ki.py::test_list_contexts PASSED tests/test_server_ki.py::test_generate_sql PASSED tests/test_server_li.py::test_create_test_table PASSED tests/test_server_li.py::test_list_tables PASSED tests/test_server_li.py::test_describe_table PASSED tests/test_server_li.py::test_get_records PASSED tests/test_server_li.py::test_insert_records PASSED tests/test_server_li.py::test_query_sql_success PASSED tests/test_server_li.py::test_query_sql_failure PASSED tests/test_server_li.py::test_create_context PASSED tests/test_server_li.py::test_get_sql_context PASSED tests/test_server_li.py::test_get_prompt
The fastmcp library allows for authenticated testing on localhost without the need for SSL. This means we can configure the MCP and auth servers with unencrypted ports and connections from localhost will work.
-
Configure the auth server to use unencrypted ports. For example:
KINETICA_URL=https://172.31.72.27:8082/gpudb KINETICA_EXTERNAL_HOST=localhost KINETICA_MCP_URI=http://localhost:8390 KINETICA_HANDSHAKE_KEY='NDMxMTQ5MjAyNS0wOS0xOCAxMjozMDo1MS40MzExNTc='Start the auth server.
[kinetica-auth/bin]$ ./start_auth.sh
-
Configure the MCP server to use unencrypted ports. For example:
KINETICA_URL=http://172.31.72.27:9191 KINETICA_LOGLEVEL=INFO KINETICA_OAUTH_URL=http://localhost:8380 KINETICA_OAUTH_HANDSHAKE_KEY='NDMxMTQ5MjAyNS0wOS0xOCAxMjozMDo1MS40MzExNTc=' KINETICA_OAUTH_EXTERNAL_HOST=localhost KINETICA_OAUTH_BASE_URL=http://localhost:8390Start the MCP server.
[kinetica-mcp/bin]$ ./start_mcp.sh
-
Run the authentication test:
Your browser should open to a login page. After logging in with a Kinetica user you will be redirected back to the MCP server.
[kinetica-mcp]$ pytest tests/test_oauth.py::test_query_sql_success
For bugs, please submit an issue on Github.
For support, you can post on
stackoverflow under the
kinetica tag or
Slack.
- Ask a question on Slack: Slack
- Follow on GitHub: Follow @kineticadb
- Email us: support@kinetica.com
- Visit: https://www.kinetica.com/contact/