GigAPI MCP Server
Supports writing data using InfluxDB Line Protocol format to GigAPI's timeseries database, enabling seamless data ingestion from InfluxDB-compatible sources.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@GigAPI MCP Servershow me the schema for the temperature_data table in mydb"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
GigAPI MCP Server
An MCP server for GigAPI Timeseries Lake that provides seamless integration with Claude Desktop and other MCP-compatible clients.
Features
GigAPI Tools
run_select_queryExecute SQL queries on your GigAPI cluster.
Input:
sql(string): The SQL query to execute,database(string): The database to execute against.All queries are executed safely through GigAPI's HTTP API with NDJSON format.
list_databasesList all databases on your GigAPI cluster.
Input:
database(string): The database to use for the SHOW DATABASES query (defaults to "mydb").
list_tablesList all tables in a database.
Input:
database(string): The name of the database.
get_table_schemaGet schema information for a specific table.
Input:
database(string): The name of the database,table(string): The name of the table.
write_dataWrite data using InfluxDB Line Protocol format.
Input:
database(string): The database to write to,data(string): Data in InfluxDB Line Protocol format.
health_checkCheck the health status of the GigAPI server.
pingPing the GigAPI server to check connectivity.
Related MCP server: FreeAgent MCP Server
Quick Start
1. Install the MCP Server
Option A: From PyPI (Recommended)
# The package will be available on PyPI after the first release
# Users can install it directly with uv
uv run --with mcp-gigapi --python 3.11 mcp-gigapi --helpOption B: From Source
# Clone the repository
git clone https://github.com/gigapi/mcp-gigapi.git
cd mcp-gigapi
# Install dependencies
uv sync2. Configure Claude Desktop
Open the Claude Desktop configuration file located at:
On macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonOn Windows:
%APPDATA%/Claude/claude_desktop_config.json
Add the following configuration:
For the Public Demo (Recommended for Testing)
{
"mcpServers": {
"mcp-gigapi": {
"command": "uv",
"args": [
"run",
"--with",
"mcp-gigapi",
"--python",
"3.13",
"mcp-gigapi"
],
"env": {
"GIGAPI_HOST": "gigapi.fly.dev",
"GIGAPI_PORT": "443",
"GIGAPI_TIMEOUT": "30",
"GIGAPI_VERIFY_SSL": "true",
"GIGAPI_DEFAULT_DATABASE": "mydb"
}
}
}
}For Local Development
{
"mcpServers": {
"mcp-gigapi": {
"command": "uv",
"args": [
"run",
"--with",
"mcp-gigapi",
"--python",
"3.13",
"mcp-gigapi"
],
"env": {
"GIGAPI_HOST": "localhost",
"GIGAPI_PORT": "7971",
"GIGAPI_TIMEOUT": "30",
"GIGAPI_VERIFY_SSL": "false",
"GIGAPI_DEFAULT_DATABASE": "mydb"
}
}
}
}With Authentication
{
"mcpServers": {
"mcp-gigapi": {
"command": "uv",
"args": [
"run",
"--with",
"mcp-gigapi",
"--python",
"3.13",
"mcp-gigapi"
],
"env": {
"GIGAPI_HOST": "your-gigapi-server",
"GIGAPI_PORT": "7971",
"GIGAPI_USERNAME": "your_username",
"GIGAPI_PASSWORD": "your_password",
"GIGAPI_TIMEOUT": "30",
"GIGAPI_VERIFY_SSL": "true",
"GIGAPI_DEFAULT_DATABASE": "your_database"
}
}
}
}Important: Replace the
uvcommand with the absolute path to youruvexecutable:which uv # Find the pathRestart Claude Desktop to apply the changes.
API Compatibility
This MCP server is designed to work with GigAPI's HTTP API endpoints:
Query Endpoints
POST /query?db={database}&format=ndjson- Execute SQL queries with NDJSON response formatAll queries return NDJSON (Newline Delimited JSON) format for efficient streaming
Write Endpoints
POST /write?db={database}- Write data using InfluxDB Line Protocol
Administrative Endpoints
GET /health- Health checkGET /ping- Simple ping
Example Usage
Writing Data
Use InfluxDB Line Protocol format:
curl -X POST "http://localhost:7971/write?db=mydb" --data-binary @/dev/stdin << EOF
weather,location=us-midwest,season=summer temperature=82
weather,location=us-east,season=summer temperature=80
weather,location=us-west,season=summer temperature=99
EOFReading Data
Execute SQL queries via JSON POST with NDJSON format:
curl -X POST "http://localhost:7971/query?db=mydb&format=ndjson" \
-H "Content-Type: application/json" \
-d '{"query": "SELECT time, temperature FROM weather WHERE time >= epoch_ns('\''2025-04-24T00:00:00'\''::TIMESTAMP)"}'Show Databases/Tables
# Show databases
curl -X POST "http://localhost:7971/query?db=mydb&format=ndjson" \
-H "Content-Type: application/json" \
-d '{"query": "SHOW DATABASES"}'
# Show tables
curl -X POST "http://localhost:7971/query?db=mydb&format=ndjson" \
-H "Content-Type: application/json" \
-d '{"query": "SHOW TABLES"}'
# Count records
curl -X POST "http://localhost:7971/query?db=mydb&format=ndjson" \
-H "Content-Type: application/json" \
-d '{"query": "SELECT count(*), avg(temperature) FROM weather"}'Environment Variables
Required Variables
GIGAPI_HOST: The hostname of your GigAPI serverGIGAPI_PORT: The port number of your GigAPI server (default: 7971)
Optional Variables
GIGAPI_USERNAMEorGIGAPI_USER: The username for authentication (if required)GIGAPI_PASSWORDorGIGAPI_PASS: The password for authentication (if required)GIGAPI_TIMEOUT: Request timeout in seconds (default: 30)GIGAPI_VERIFY_SSL: Enable/disable SSL certificate verification (default: true)GIGAPI_DEFAULT_DATABASE: Default database to use for queries (default: mydb)GIGAPI_MCP_SERVER_TRANSPORT: Sets the transport method for the MCP server (default: stdio)GIGAPI_ENABLED: Enable/disable GigAPI functionality (default: true)
Example Configurations
For Local Development
# Required variables
GIGAPI_HOST=localhost
GIGAPI_PORT=7971
# Optional: Override defaults for local development
GIGAPI_VERIFY_SSL=false
GIGAPI_TIMEOUT=60
GIGAPI_DEFAULT_DATABASE=mydbFor Production with Authentication
# Required variables
GIGAPI_HOST=your-gigapi-server
GIGAPI_PORT=7971
GIGAPI_USERNAME=your_username
GIGAPI_PASSWORD=your_password
# Optional: Production settings
GIGAPI_VERIFY_SSL=true
GIGAPI_TIMEOUT=30
GIGAPI_DEFAULT_DATABASE=your_databaseFor Public Demo
GIGAPI_HOST=gigapi.fly.dev
GIGAPI_PORT=443
GIGAPI_VERIFY_SSL=true
GIGAPI_DEFAULT_DATABASE=mydbData Format
GigAPI uses Hive partitioning with the structure:
/data
/mydb
/weather
/date=2025-04-10
/hour=14
*.parquet
metadata.jsonDevelopment
Setup Development Environment
Install dependencies:
uv sync --all-extras --dev source .venv/bin/activateCreate a
.envfile in the root of the repository:GIGAPI_HOST=localhost GIGAPI_PORT=7971 GIGAPI_USERNAME=your_username GIGAPI_PASSWORD=your_password GIGAPI_TIMEOUT=30 GIGAPI_VERIFY_SSL=false GIGAPI_DEFAULT_DATABASE=mydbFor testing with the MCP Inspector:
fastmcp dev mcp_gigapi/mcp_server.py
Running Tests
# Run all tests
uv run pytest -v
# Run only unit tests
uv run pytest -v -m "not integration"
# Run only integration tests
uv run pytest -v -m "integration"
# Run linting
uv run ruff check .
# Test with public demo
python test_demo.pyTesting with Public Demo
The repository includes a test script that validates the MCP server against the public GigAPI demo:
python test_demo.pyThis will test:
✅ Health check and connectivity
✅ Database listing (SHOW DATABASES)
✅ Table listing (SHOW TABLES)
✅ Data queries (SELECT count(*) FROM table)
✅ Sample data retrieval
PyPI Publishing
This package is automatically published to PyPI on each GitHub release. The publishing process is handled by GitHub Actions workflows:
CI Workflow (
.github/workflows/ci.yml): Runs tests on pull requests and pushes to mainPublish Workflow (
.github/workflows/publish.yml): Publishes to PyPI when a release is created
For Users
Once published, users can install the package directly from PyPI:
# Install and run the MCP server
uv run --with mcp-gigapi --python 3.11 mcp-gigapiFor Maintainers
To publish a new version:
Update the version in
pyproject.tomlCreate a GitHub release
The workflow will automatically publish to PyPI
See RELEASING.md for detailed release instructions.
Troubleshooting
Common Issues
Connection refused: Check that GigAPI is running and the host/port are correct
Authentication failed: Verify username/password are correct
SSL certificate errors: Set
GIGAPI_VERIFY_SSL=falsefor self-signed certificatesNo databases found: Ensure you're using the correct default database (usually "mydb")
Debug Mode
Enable debug logging by setting the log level:
import logging
logging.basicConfig(level=logging.DEBUG)License
Apache-2.0 license
Contributing
Fork the repository
Create a feature branch
Make your changes
Add tests
Submit a pull request
Support
Issues: GitHub Issues
Documentation: GigAPI Documentation
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Appeared in Searches
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/gigapi/gigapi-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server