garmin-mcp-server
Provides tools to download, sync, and query Garmin Connect activity data from a local SQLite database, including metrics like heart rate, pace, cadence, power, VO2 max, and more.
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., "@garmin-mcp-serverShow me my 5 most recent runs"
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.
Garmin MCP Server
A Model Context Protocol (MCP) server that connects Claude Desktop to your real Garmin Connect running data stored in a local SQLite database.
Setup for Claude Desktop
1. Install Dependencies
npm install2. Configure Garmin Credentials
Create a .env file in the project root:
cp .env.example .envEdit .env and add your Garmin Connect credentials:
GARMIN_USERNAME=your-email@example.com
GARMIN_PASSWORD=your-password3. Download Your Garmin Data
npm run downloadThis downloads all your activities from Garmin Connect to a local SQLite database at data/garmin-data.db.
4. Configure Claude Desktop
First, get the absolute path to this project:
pwdThis will output something like /Users/yourusername/Code/garmin-mcp-server.
macOS: Edit ~/Library/Application Support/Claude/claude_desktop_config.json
Linux: Edit ~/.config/Claude/claude_desktop_config.json
Windows: Run cd to get the path, then edit %APPDATA%\Claude\claude_desktop_config.json
Add this configuration (replace the path with your actual project path):
{
"mcpServers": {
"garmin-mcp-server": {
"command": "npx",
"args": ["-y", "tsx", "/Users/yourusername/Code/garmin-mcp-server/src/index.ts"],
"cwd": "/Users/yourusername/Code/garmin-mcp-server"
}
}
}Replace /Users/yourusername/Code/garmin-mcp-server with your actual path from the pwd command.
5. Restart Claude Desktop
After restarting, you can ask Claude:
"Sync my latest Garmin activities"
"Show me my 5 most recent runs"
"What's my average pace this month?"
"Analyze my running performance trends"
"How many kilometers did I run this year?"
Related MCP server: WHOOP MCP Server
Features
Local SQLite Database - Your data stored locally for fast access
Auto-Sync - Update your data from Garmin Connect directly through Claude
SQL Queries - Run custom queries to analyze your training data
Comprehensive Metrics - Heart rate, pace, cadence, power, VO2 max, and more
AI Analysis - Let Claude analyze your running trends and performance
Privacy-First - All data stays on your machine
Self-Hosting with Docker
Deploy your own instance using Docker for use with Claude, ChatGPT, or any MCP-compatible client.
Quick Start with Docker Compose
Create a directory and download the compose file:
mkdir garmin-mcp && cd garmin-mcp
curl -O https://raw.githubusercontent.com/vnglst/garmin-mcp-server/main/docker-compose.ymlCreate a
.envfile:
GARMIN_USERNAME=your-email@example.com
GARMIN_PASSWORD=your-password
API_KEY=your-secret-api-keyStart the server:
docker compose up -dThe server runs at http://localhost:3000 with:
MCP endpoint:
POST /mcpHealth check:
GET /health
Coolify Deployment
Create a new service from Git repository
Set the following environment variables:
GARMIN_USERNAME: Your Garmin Connect emailGARMIN_PASSWORD: Your Garmin Connect passwordAPI_KEY: Secret key for authenticationPORT: 3000 (default)
Configure health check path:
/healthDeploy
Using the Pre-built Image
docker run -d \
--name garmin-mcp-server \
-p 3000:3000 \
-e GARMIN_USERNAME=your-email@example.com \
-e GARMIN_PASSWORD=your-password \
-e API_KEY=your-secret-key \
-v garmin-data:/app/data \
ghcr.io/vnglst/garmin-mcp-server:latestMCP Client Configuration
Configure your MCP client to connect to the HTTP endpoint:
{
"mcpServers": {
"garmin": {
"url": "https://your-server.example.com/mcp",
"transport": "http",
"headers": {
"Authorization": "Bearer your-api-key"
}
}
}
}Environment Variables
Variable | Required | Description |
| Yes | Garmin Connect email |
| Yes | Garmin Connect password |
| No | API key for authentication (recommended) |
| No | Server port (default: 3000) |
Available MCP Tools
The server exposes three tools that Claude can use:
1. get-schema
Get the database schema to understand available data fields.
Example usage in Claude:
"What data fields are available in my running database?"
"Show me the database schema"
2. run-query
Execute SELECT queries against your activities database.
Example usage in Claude:
"Show me my 10 most recent runs"
"What's my average heart rate this month?"
"Find all runs longer than 10km"
"Calculate my total distance this year"
Security: Only SELECT queries are allowed - no data modification.
3. sync-activities
Download and sync new activities from Garmin Connect to the local database.
Example usage in Claude:
"Sync my latest Garmin activities"
"Update my running data"
"Check for new workouts"
Returns a summary showing:
Number of new activities downloaded
Total activities in the database
Date of your latest activity
What Data You Get
All data from your Garmin device stored in a SQLite database (58+ fields):
Basic Metrics:
Activity ID, name, description, timestamps (local & GMT)
Activity type, location name
Distance, duration, elapsed duration, moving duration
Calories, steps, lap count
Heart Rate Data:
Average/max heart rate
Lactate threshold BPM
Time in each HR zone (1-5)
VO2 Max value
Speed & Pace:
Average/max speed
Fastest splits (1K, 5K, 10K, mile)
Running Dynamics:
Average/max stride length
Average/max cadence (including double cadence)
Average vertical oscillation
Average ground contact time
Vertical ratio, vertical speed
Training Load & Intensity:
Activity training load
Training effect (aerobic/anaerobic)
Vigorous/moderate intensity minutes
Elevation:
Elevation gain/loss
Min/max elevation
Power Metrics:
Average/max power
Grit and Flow scores
How It Works
Initial Setup: Run
npm run downloadto download all your activities from Garmin Connect into a local SQLite databaseClaude Integration: The MCP server exposes tools that Claude can use to query your data
Stay Updated: Use the
sync-activitiestool in Claude to download new activities anytimeFlexible Queries: Claude can run SQL queries to analyze your data in any way you want
Development
# Download/update activities from Garmin
npm run download
# Build TypeScript to JavaScript
npm run build
# Test MCP server manually
npm run test:mcp
# Run server directly (for testing)
npm startNote: When using with Claude Desktop via the tsx configuration, you don't need to build - changes to TypeScript files are automatically picked up.
Troubleshooting
Authentication Issues
Verify credentials in
.envfile (GARMIN_USERNAME and GARMIN_PASSWORD)Ensure you can log into connect.garmin.com manually
Try logging in via web browser first
Check that your password doesn't contain special characters that need escaping
Database Not Found
Run
npm run downloadfirst to create the databaseCheck that
data/garmin-data.dbexists in your project directoryVerify the database file isn't corrupted (try deleting and re-downloading)
Sync Not Working in Claude
Restart Claude Desktop after configuration changes
Check Claude Desktop logs for error messages
Verify the paths in
claude_desktop_config.jsonare absolute, not relativeEnsure
.envfile exists in the project root directory
Query Errors
Only SELECT queries are allowed (INSERT, UPDATE, DELETE are blocked)
Use the
get-schematool to see available table columnsCheck SQL syntax is correct
Security & Privacy
Your data stays completely private:
Credentials stored locally in
.envfile onlyDirect connection to Garmin Connect (no intermediary servers)
All data stored in local SQLite database on your machine
No third-party data sharing or cloud uploads
Database queries run locally
Only SELECT queries allowed (read-only access for Claude)
Technical Details
Architecture:
TypeScript-based MCP server
SQLite database for local storage
Direct integration with Garmin Connect API (via
garmin-connectlibrary)Runs via
tsxfor development (no build step needed with Claude Desktop)MCP SDK for Claude Desktop integration
Database:
Location:
data/garmin-data.dbFormat: SQLite 3
Updates: Incremental (only new activities downloaded)
Contains: All activity data from Garmin Connect
Requirements
Node.js 18+
npm (comes with Node.js)
Garmin Connect account with running/fitness activities
Claude Desktop for MCP integration
Garmin device that syncs to Garmin Connect (watch, bike computer, etc.)
Contributing
Feel free to open issues or submit pull requests for:
Bug fixes
New data fields to track
Additional MCP tools
Documentation improvements
License
MIT
Note: This project is not affiliated with, endorsed by, or sponsored by Garmin Ltd. or Garmin International, Inc.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/vnglst/garmin-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server