grafana/mcp-k6
If you are the rightful owner of mcp-k6 and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
An experimental MCP server for k6, providing script validation, test execution, documentation search, and guided script generation.
k6 MCP Server
An experimental MCP (Model Context Protocol) server for k6, written in Go. It offers script validation, test execution, documentation browsing, and guided script generation.
[!IMPORTANT]
This project is still experimental. Expect sharp edges, keep a local clone up to date, and share feedback or issues so we can iterate quickly.
Features
Tools
- Script Validation:
validate_scriptruns k6 scripts with minimal configuration (1 VU, 1 iteration) and returns actionable errors to help quickly produce correct code. - Test Execution:
run_scriptruns k6 performance tests locally with configurable VUs, duration, stages, and options, and, when possible, extracts insights from the results. - Documentation Browsing:
list_sectionsandget_documentationprovide structured navigation of the official k6 docs and allow retrieving full markdown for specific sections.
Resources
- Best Practices Resources: Comprehensive k6 scripting guidelines and patterns to help you write effective, idiomatic, and correct tests.
- Type Definitions: Up‑to‑date k6 TypeScript type definitions to improve accuracy and editor tooling.
Prompts
- Script Generation with
generate_script: Generate production‑ready k6 test scripts from plain‑English requirements. It automatically follows modern testing practices by leveraging embedded best practices, documentation, and type definitions.
Getting Started
Choose your preferred installation method:
- 🐳 Option 1: Docker (Recommended)
- 🍎 Option 2: Homebrew macOS
- 🐧 Option 3: Package Installation (Linux)
- 💻 Option 4: Native Installation
Option 1: Docker (Recommended)
The easiest way to get started. The Docker image includes k6 and all dependencies.
Prerequisites:
- Docker: Install from docker.com
Pull the official image:
docker pull grafana/mcp-k6:latest
[!NOTE]
That's it! You're ready to run the containerized server.
Proceed to Editor Integrations to configure your editor.
Option 2: Homebrew macOS
Install mcp-k6 using Homebrew. k6 will be automatically installed as a dependency.
Installation:
# Add the grafana homebrew tap repository
brew tap grafana/grafana
# Install mcp-k6
brew install mcp-k6
# Verify installation
mcp-k6 --version
[!NOTE]
To update to a newer version, download and install the latest formula again, or usebrew upgradeif installed from the tap. Proceed to Editor Integrations to configure your editor.
Option 3: Package Installation (Linux)
Pre-built packages are available for Debian/Ubuntu and RHEL/Fedora/CentOS distributions.
Version naming: Git tags include the
vprefix (e.g.v0.2.0), but release files drop it. ReplaceVERSIONbelow with just the numeric part (0.2.0).
Prerequisites:
- k6 (recommended): Should be installed for script execution
Debian/Ubuntu (.deb)
Download and install the .deb package from the latest release:
# For amd64 (x86_64)
curl -LO https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_amd64.deb
sudo dpkg -i mcp-k6_0.2.0_linux_amd64.deb
# For arm64
curl -LO https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_arm64.deb
sudo dpkg -i mcp-k6_0.2.0_linux_arm64.deb
Or install directly with apt:
# Download the package
curl -LO https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_amd64.deb
# Install with apt (resolves dependencies)
sudo apt install ./mcp-k6_0.2.0_linux_amd64.deb
RHEL/Fedora/CentOS (.rpm)
Download and install the .rpm package from the latest release:
# For amd64 (x86_64)
curl -LO https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_amd64.rpm
sudo rpm -i mcp-k6_0.2.0_linux_amd64.rpm
# For arm64
curl -LO https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_arm64.rpm
sudo rpm -i mcp-k6_0.2.0_linux_arm64.rpm
Or use dnf/yum:
# Fedora/RHEL 8+
sudo dnf install https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_amd64.rpm
# CentOS/RHEL 7
sudo yum install https://github.com/grafana/mcp-k6/releases/latest/download/mcp-k6_VERSION_linux_amd64.rpm
Verify installation:
mcp-k6 --version
[!NOTE]
The binary is installed to/usr/bin/mcp-k6. Proceed to Editor Integrations to configure your editor.
Option 4: Native Installation
For development or if you prefer running the server natively.
Prerequisites:
- Go 1.24.4+: For building and running the MCP server
- k6: Must be installed and available in PATH for script execution
- GNU Make: Provides the automation targets used by this project (typically preinstalled on macOS/Linux)
Verify the tooling:
go version
k6 version
make --version
Installation:
-
Clone the repository:
git clone https://github.com/grafana/mcp-k6 cd mcp-k6 -
Prepare assets and install the server (builds docs assets, embeds resources, installs
mcp-k6into your Go bin):make install -
Run the server locally (optional):
make run -
Verify the binary (optional):
mcp-k6 --version
Whenever docs or resources change, rebuild embeds with:
make prepare
[!NOTE]
Proceed to Editor Integrations to configure your editor.
HTTP Transport Mode
mcp-k6 supports two transport modes:
- Stdio (Default): Best for local, single-user setups where your editor or MCP client manages the server process directly.
- Streamable HTTP: Ideal for remote deployments, shared team instances, or complex network setups where clients connect over the network.
Running in HTTP Mode
To start the server in HTTP mode, use the -transport=http flag:
Native:
mcp-k6 -transport=http -addr=:8080
Docker:
docker run -p 8080:8080 grafana/mcp-k6 -transport=http -addr=:8080
Configuration Flags
-addr: Listening address (default:8080). To listen on all interfaces, use:8080or0.0.0.0:8080.-endpoint: Endpoint path for the MCP server (default/mcp).-stateless: Run in stateless mode without session tracking (defaultfalse).
Remote Deployment (Team Usage)
You can deploy mcp-k6 as a shared service for your team. This allows multiple users to connect their MCP clients (like Claude Desktop or Cursor) to a central instance, sharing the execution environment.
Example Deployment:
- Deploy the Docker container to your infrastructure (e.g., Kubernetes, EC2).
- Expose port
8080. - Configure the server to listen on all interfaces:
-addr=0.0.0.0:8080.
Security Note: The server has no built-in authentication. It should be deployed in a trusted network (VPN, private VPC) or behind a secure proxy that handles authentication.
Editor Integrations
mcp-k6 speaks MCP over stdio by default, but can be configured for Streamable HTTP.
Connect via Streamable HTTP
If you are running the server in HTTP mode (locally or remotely), configure your editor to connect via Streamable HTTP:
{
"mcpServers": {
"remote-k6": {
"url": "http://your-server-ip:8080/mcp"
}
}
}
Cursor IDE
Create or update ~/.cursor/mcp_servers.json (or the profile-specific config):
Docker:
{
"mcpServers": {
"k6": {
"command": "docker",
"args": ["run", "--rm", "-i", "grafana/mcp-k6"]
}
}
}
Native:
{
"mcpServers": {
"mcp-k6": {
"command": "mcp-k6"
}
}
}
Restart Cursor or reload the MCP configuration, then call the tools from chat (validate scripts, run load tests, search docs, generate scripts).
Claude Code
Add the server to Claude Code:
Docker:
claude mcp add --scope=user --transport=stdio k6 -- docker run --rm -i grafana/mcp-k6
Native:
claude mcp add --scope=user --transport=stdio k6 mcp-k6
Use --scope=local if you prefer the configuration to live inside the current project. Reload the workspace to pick up the new server.
Claude Desktop
Place one of the following snippets in your Claude Desktop MCP configuration file (create it if necessary):
Docker:
{
"mcpServers": {
"k6": {
"command": "docker",
"args": ["run", "--rm", "-i", "grafana/mcp-k6"]
}
}
}
Native:
{
"mcpServers": {
"mcp-k6": {
"command": "mcp-k6"
}
}
}
Restart the desktop app or reload its MCP plugins afterwards.
Codex CLI
Codex CLI (experimental) supports MCP servers over stdio.
- Locate your Codex configuration (see
codex help configfor the exact path on your system). - Add or merge one of the following blocks under the top-level
mcpServerskey:
Docker:
{
"mcpServers": {
"k6": {
"command": "docker",
"args": ["run", "--rm", "-i", "grafana/mcp-k6"]
}
}
}
Native:
{
"mcpServers": {
"mcp-k6": {
"command": "mcp-k6"
}
}
}
- Restart Codex or reload its configuration (
codex reload) to make the new server available.
Available Tools
validate_script
Validate a k6 script by running it with minimal configuration (1 VU, 1 iteration).
Parameters:
script(string, required)
Returns: valid, exit_code, stdout, stderr, error, duration
run_script
Run k6 performance tests with configurable parameters.
Parameters:
script(string, required)vus(number, optional)duration(string, optional)iterations(number, optional)stages(object, optional)options(object, optional)
Returns: success, exit_code, stdout, stderr, error, duration, metrics, summary
list_sections
Browse the embedded documentation hierarchy without overwhelming model context. The tool returns a depth-limited tree (default depth 1) so you can progressively expand only the branches you need.
Parameters:
version(string, optional): Specific docs version (v1.4.x,allfor list).category(string, optional): Filter to a top-level docs category.depth(number, optional, default 1, max 5): How many levels of children to include in the tree. Depth counts from the root you request.root_slug(string, optional): List the immediate children under this slug (e.g.,using-k6), just likelsinside a folder. Combine withdepthto include deeper descendants.
Response highlights:
tree: Depth-limited nodes with inlinechildren,child_count, andhas_moreso you know when to fetch another layer.versionandavailable_versions: Confirm the docs version in use.depthandroot_slug: Echo the arguments used so agents can decide whether to dive deeper.
get_documentation
Retrieve full markdown content for a specific documentation section.
Parameters:
slug(string, required): Section slug (use list_sections to discover them).version(string, optional): Specific docs version (v1.4.x, etc.).
Returns section, content, version, and available_versions.
Available Resources
Script Generation Template
AI-powered k6 script generation with structured workflow:
- Research and discovery phase
- Best practices integration
- Production-ready script creation
- Automated validation and testing
- File system integration
Resource URI: prompts://k6/generate_script
Development
Run make list to get a list of available Make commands.
Usage Examples
Basic Script Validation
# In your MCP-enabled editor, ask:
"Can you validate this k6 script?"
# Then provide your k6 script content
Performance Testing
# In your MCP-enabled editor, ask:
"Run a load test with 10 VUs for 2 minutes using this script"
# The system will execute the test and provide detailed metrics
Documentation Browsing
# In your MCP-enabled editor, ask:
"List the top-level k6 documentation sections"
"Show me the scenarios section documentation"
"Fetch the markdown for javascript-api/k6-http/request"
Script Generation
# In your MCP-enabled editor, ask:
"Generate a k6 script to test a REST API with authentication"
"Create a browser test for an e-commerce checkout flow"
"Generate a WebSocket load test script"
Troubleshooting
Build fails with “dist/sections.json: no matching files”
Generate the docs assets first:
make docs
MCP Server Not Found
If your editor can't find the mcp-k6 server:
- Ensure it's installed:
make install - Check your editor's MCP configuration
- Verify the server starts:
mcp-k6(should show MCP server output)
Test Execution Failures
If k6 tests fail to execute:
- Verify k6 is installed:
k6 version - Check script syntax with the validate tool first
- Ensure resources don't exceed limits (50 VUs, 5m duration)
Contributing
- Fork the repository
- Create a feature branch
- Run tests:
go test ./... - Run linter:
golangci-lint run - Submit a pull request
License
This project is licensed under the MIT License - see the LICENSE file for details.