Server data from the Official MCP Registry
An MCP server giving access to Grafana dashboards, data and more.
An MCP server giving access to Grafana dashboards, data and more.
Remote endpoints: streamable-http: https://mcp.grafana.com/mcp
Valid MCP server (1 strong, 1 medium validity signals). No known CVEs in dependencies. Imported from the Official MCP Registry.
Endpoint verified · Requires authentication · 1 issue found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: GRAFANA_URL
Environment variable: GRAFANA_SERVICE_ACCOUNT_TOKEN
Environment variable: GRAFANA_USERNAME
Environment variable: GRAFANA_PASSWORD
Environment variable: GRAFANA_ORG_ID
Environment variable: GRAFANA_EXTRA_HEADERS
Environment variable: GRAFANA_FORWARD_HEADERS
Remote Plugin
No local installation needed. Your AI client connects to the remote endpoint directly.
Add this to your MCP configuration to connect:
{
"mcpServers": {
"io-github-grafana-mcp-grafana": {
"env": {
"GRAFANA_URL": "your-grafana-url-here",
"GRAFANA_ORG_ID": "your-grafana-org-id-here",
"GRAFANA_PASSWORD": "your-grafana-password-here",
"GRAFANA_USERNAME": "your-grafana-username-here",
"GRAFANA_EXTRA_HEADERS": "your-grafana-extra-headers-here",
"GRAFANA_FORWARD_HEADERS": "your-grafana-forward-headers-here",
"GRAFANA_SERVICE_ACCOUNT_TOKEN": "your-grafana-service-account-token-here"
},
"url": "https://mcp.grafana.com/mcp"
}
}
}From the project's GitHub README.
A [Model Context Protocol][mcp] (MCP) server for Grafana.
This provides access to your Grafana instance and the surrounding ecosystem.
Requires uv. Add the following to your MCP client configuration (e.g. Claude Desktop, Cursor):
{
"mcpServers": {
"grafana": {
"command": "uvx",
"args": ["mcp-grafana"],
"env": {
"GRAFANA_URL": "http://localhost:3000",
"GRAFANA_SERVICE_ACCOUNT_TOKEN": "<your service account token>"
}
}
}
}
For Grafana Cloud, replace GRAFANA_URL with your instance URL (e.g. https://myinstance.grafana.net). See Usage for more installation options including Docker, binary, and Helm.
The following features are currently available in MCP server. This list is for informational purposes only and does not represent a roadmap or commitment to future features.
$.title, $.panels[*].title) to fetch only needed data and reduce context window consumptionNote: Run panel query tools are disabled by default. To enable them, add
runpanelqueryto your--enabled-toolsflag.
The dashboard tools now include several strategies to manage context window usage effectively (issue #101):
get_dashboard_summary for dashboard overview and planning modificationsget_dashboard_property with JSONPath when you only need specific dashboard partsget_dashboard_by_uid unless you specifically need the complete dashboard JSONNote: Query examples tools are disabled by default. To enable them, add
examplesto your--enabled-toolsflag.
Note: InfluxDB tools are disabled by default. To enable them, add
influxdbto your--enabled-toolsflag.
dialect parameter.Note: ClickHouse tools are disabled by default. To enable them, add
clickhouseto your--enabled-toolsflag.
Note: CloudWatch tools are disabled by default. To enable them, add
cloudwatchto your--enabled-toolsflag.
Note: Graphite tools are disabled by default. To enable them, add
graphiteto your--enabled-toolsflag.
Note: Athena tools are disabled by default. To enable them, add
athenato your--enabled-toolsflag.
Note: Snowflake tools are disabled by default. To enable them, add
snowflaketo your--enabled-toolsflag.
Queries go through Grafana's Snowflake datasource (Grafana Enterprise plugin grafana-snowflake-datasource), so authentication is handled by the datasource configuration in Grafana — credentials are never seen by the MCP server. This is the same model used for the ClickHouse tools.
INFORMATION_SCHEMA.TABLES. Optional database/schema filters.SNOWFLAKE.TELEMETRY.EVENTS) for logs and traces, or any user table.
$__timeFilter(column), $__timeFrom, $__timeTo, $__from, $__to (Unix ms), $__interval (seconds), $__interval_ms, and ${varname} for template variable substitution.Note: Elasticsearch/OpenSearch tools are disabled by default. To enable them, add
elasticsearchto your--enabled-toolsflag.
Note: Quickwit tools are disabled by default. To enable them, add
quickwitto your--enabled-toolsflag.
Note: Admin tools are disabled by default. To enable them, include
adminin your--enabled-toolsflag.
http://localhost:3000/d/dashboard-uid)http://localhost:3000/d/dashboard-uid?viewPanel=5)http://localhost:3000/explore?left={"datasource":"prometheus-uid"})from=now-1h&to=now)what, when, tags, data).provisioningPreview parameter.
The list of tools is configurable, so you can choose which tools you want to make available to the MCP client.
This is useful if you don't use certain functionality or if you don't want to take up too much of the context window.
To disable a category of tools, use the --disable-<category> flag when starting the server. For example, to disable
the OnCall tools, use --disable-oncall, or to disable navigation deeplink generation, use --disable-navigation.
Each tool requires specific RBAC permissions to function properly. When creating a service account for the MCP server, ensure it has the necessary permissions based on which tools you plan to use. The permissions listed are the minimum required actions - you may also need appropriate scopes (e.g., datasources:*, dashboards:*, folders:*) depending on your use case.
Tip: If you're not familiar with Grafana RBAC or you want a quicker, simpler setup instead of configuring many granular scopes, you can assign a built-in role such as Editor to the service account. The Editor role grants broad read/write access that will allow most MCP server operations; it is less granular (and therefore less restrictive) than manually-applied scopes, so use it only when convenience is more important than strict least-privilege access.
Note: Grafana Incident and Sift tools use basic Grafana roles instead of fine-grained RBAC permissions:
For more information about Grafana RBAC, see the official documentation.
Scopes define the specific resources that permissions apply to. Each action requires both the appropriate permission and scope combination.
Common Scope Patterns:
Broad access: Use * wildcards for organization-wide access
datasources:* - Access to all datasourcesdashboards:* - Access to all dashboardsfolders:* - Access to all foldersteams:* - Access to all teamsLimited access: Use specific UIDs or IDs to restrict access to individual resources
datasources:uid:prometheus-uid - Access only to a specific Prometheus datasourcedashboards:uid:abc123 - Access only to dashboard with UID abc123folders:uid:xyz789 - Access only to folder with UID xyz789teams:id:5 - Access only to team with ID 5global.users:id:123 - Access only to user with ID 123Examples:
Full MCP server access: Grant broad permissions for all tools
datasources:* (datasources:read, datasources:query)
dashboards:* (dashboards:read, dashboards:create, dashboards:write)
folders:* (for dashboard creation and alert rules)
teams:* (teams:read)
global.users:* (users:read)
Limited datasource access: Only query specific Prometheus and Loki instances
datasources:uid:prometheus-prod (datasources:query)
datasources:uid:loki-prod (datasources:query)
Dashboard-specific access: Read only specific dashboards
dashboards:uid:monitoring-dashboard (dashboards:read)
dashboards:uid:alerts-dashboard (dashboards:read)
| Tool | Category | Description | Required RBAC Permissions | Required Scopes |
|---|---|---|---|---|
list_teams | Admin | List all teams | teams:read | teams:* or teams:id:1 |
list_users_by_org | Admin | List all users in an organization | users:read | global.users:* or global.users:id:123 |
list_all_roles | Admin | List all Grafana roles | roles:read | roles:* |
get_role_details | Admin | Get details for a Grafana role | roles:read | roles:uid:editor |
get_role_assignments | Admin | List assignments for a role | roles:read | roles:uid:editor |
list_user_roles | Admin | List roles for users | roles:read | global.users:id:123 |
list_team_roles | Admin | List roles for teams | roles:read | teams:id:7 |
get_resource_permissions | Admin | List permissions for a resource | permissions:read | dashboards:uid:abcd1234 |
get_resource_description | Admin | Describe a Grafana resource type | permissions:read | dashboards:* |
search_dashboards | Search | Search for dashboards | dashboards:read | dashboards:* or dashboards:uid:abc123 |
get_dashboard_by_uid | Dashboard | Get a dashboard by uid | dashboards:read | dashboards:uid:abc123 |
update_dashboard | Dashboard | Update or create a new dashboard | dashboards:create, dashboards:write | dashboards:*, folders:* or folders:uid:xyz789 |
get_dashboard_panel_queries | Dashboard | Get panel title, queries, datasource UID and type from a dashboard | dashboards:read | dashboards:uid:abc123 |
run_panel_query | RunPanelQuery* | Execute one or more dashboard panel queries | dashboards:read, datasources:query | dashboards:uid:*, datasources:uid:* |
get_dashboard_property | Dashboard | Extract specific parts of a dashboard using JSONPath expressions | dashboards:read | dashboards:uid:abc123 |
get_dashboard_summary | Dashboard | Get a compact summary of a dashboard without full JSON | dashboards:read | dashboards:uid:abc123 |
list_datasources | Datasources | List datasources | datasources:read | datasources:* |
get_datasource | Datasources | Get a datasource by UID or name | datasources:read | datasources:uid:prometheus-uid |
get_query_examples | Examples* | Get example queries for a datasource type | datasources:read | datasources:* |
query_prometheus | Prometheus | Execute a query against a Prometheus datasource | datasources:query | datasources:uid:prometheus-uid |
list_prometheus_metric_metadata | Prometheus | List metric metadata | datasources:query | datasources:uid:prometheus-uid |
list_prometheus_metric_names | Prometheus | List available metric names | datasources:query | datasources:uid:prometheus-uid |
list_prometheus_label_names | Prometheus | List label names matching a selector | datasources:query | datasources:uid:prometheus-uid |
list_prometheus_label_values | Prometheus | List values for a specific label | datasources:query | datasources:uid:prometheus-uid |
query_prometheus_histogram | Prometheus | Calculate histogram percentile values | datasources:query | datasources:uid:prometheus-uid |
list_incidents | Incident | List incidents in Grafana Incident | Viewer role | N/A |
create_incident | Incident | Create an incident in Grafana Incident | Editor role | N/A |
add_activity_to_incident | Incident | Add an activity item to an incident in Grafana Incident | Editor role | N/A |
get_incident | Incident | Get a single incident by ID | Viewer role | N/A |
query_loki_logs | Loki | Query and retrieve logs using LogQL (either log or metric queries) | datasources:query | datasources:uid:loki-uid |
list_loki_label_names | Loki | List all available label names in logs | datasources:query | datasources:uid:loki-uid |
list_loki_label_values | Loki | List values for a specific log label | datasources:query | datasources:uid:loki-uid |
query_loki_stats | Loki | Get statistics about log streams | datasources:query | datasources:uid:loki-uid |
query_loki_patterns | Loki | Query detected log patterns to identify common structures | datasources:query | datasources:uid:loki-uid |
analyze_loki_labels | Loki | Audit a Loki label strategy (live or static) and optionally diagnose query performance | datasources:query | datasources:uid:loki-uid |
suggest_loki_alloy_label_config | Config | Generate an Alloy loki.process snippet enforcing approved labels | N/A | N/A |
query_influxdb | InfluxDB | Query InfluxDB using InfluxQL (v1) or Flux (v2) | datasources:query | datasources:uid:influxdb-uid |
list_clickhouse_tables | ClickHouse* | List tables in a ClickHouse database | datasources:query | datasources:uid:* |
describe_clickhouse_table | ClickHouse* | Get table schema with column types | datasources:query | datasources:uid:* |
query_clickhouse | ClickHouse* | Execute SQL queries with macro substitution | datasources:query | datasources:uid:* |
list_cloudwatch_namespaces | CloudWatch* | List available AWS CloudWatch namespaces | datasources:query | datasources:uid:* |
list_cloudwatch_metrics | CloudWatch* | List metrics in a namespace | datasources:query | datasources:uid:* |
list_cloudwatch_dimensions | CloudWatch* | List dimensions for a metric | datasources:query | datasources:uid:* |
query_cloudwatch | CloudWatch* | Execute CloudWatch metric queries | datasources:query | datasources:uid:* |
list_athena_catalogs | Athena* | List available Athena data catalogs | datasources:query | datasources:uid:* |
list_athena_databases | Athena* | List databases in an Athena catalog | datasources:query | datasources:uid:* |
list_athena_tables | Athena* | List tables in an Athena database | datasources:query | datasources:uid:* |
describe_athena_table | Athena* | Get column names for an Athena table | datasources:query | datasources:uid:* |
query_athena | Athena* | Execute SQL queries with macro substitution | datasources:query | datasources:uid:* |
query_elasticsearch | Elasticsearch/OpenSearch* | Query Elasticsearch or OpenSearch using Lucene syntax or Query DSL | datasources:query | datasources:uid:datasource-uid |
query_quickwit | Quickwit* | Query Quickwit using Lucene syntax or Query DSL | datasources:query | datasources:uid:quickwit-uid |
list_snowflake_tables | Snowflake* | List tables in a Snowflake database/schema via INFORMATION_SCHEMA | datasources:query | datasources:uid:* |
describe_snowflake_table | Snowflake* | Get table schema (column types, nullability, defaults, comments) | datasources:query | datasources:uid:* |
query_snowflake | Snowflake* | Execute SQL queries with macro/variable substitution | datasources:query | datasources:uid:* |
alerting_manage_rules | Alerting | Manage alert rules (list, get, versions, create, update, delete) | alert.rules:read + alert.rules:write for mutations | folders:* or folders:uid:alerts-folder |
alerting_manage_routing | Alerting | Manage notification policies, contact points, and time intervals | alert.notifications:read | Global scope |
list_oncall_schedules | OnCall | List schedules from Grafana OnCall | grafana-oncall-app.schedules:read | Plugin-specific scopes |
get_oncall_shift | OnCall | Get details for a specific OnCall shift | grafana-oncall-app.schedules:read | Plugin-specific scopes |
get_current_oncall_users | OnCall | Get users currently on-call for a specific schedule | grafana-oncall-app.schedules:read | Plugin-specific scopes |
list_oncall_teams | OnCall | List teams from Grafana OnCall | grafana-oncall-app.user-settings:read | Plugin-specific scopes |
list_oncall_users | OnCall | List users from Grafana OnCall | grafana-oncall-app.user-settings:read | Plugin-specific scopes |
list_alert_groups | OnCall | List alert groups from Grafana OnCall with filtering options | grafana-oncall-app.alert-groups:read | Plugin-specific scopes |
get_alert_group | OnCall | Get a specific alert group from Grafana OnCall by its ID | grafana-oncall-app.alert-groups:read | Plugin-specific scopes |
get_sift_investigation | Sift | Retrieve an existing Sift investigation by its UUID | Viewer role | N/A |
get_sift_analysis | Sift | Retrieve a specific analysis from a Sift investigation | Viewer role | N/A |
list_sift_investigations | Sift | Retrieve a list of Sift investigations with an optional limit | Viewer role | N/A |
find_error_pattern_logs | Sift | Finds elevated error patterns in Loki logs. | Editor role | N/A |
find_slow_requests | Sift | Finds slow requests from the relevant tempo datasources. | Editor role | N/A |
list_pyroscope_label_names | Pyroscope | List label names matching a selector | datasources:query | datasources:uid:pyroscope-uid |
list_pyroscope_label_values | Pyroscope | List label values matching a selector for a label name | datasources:query | datasources:uid:pyroscope-uid |
list_pyroscope_profile_types | Pyroscope | List available profile types | datasources:query | datasources:uid:pyroscope-uid |
query_pyroscope | Pyroscope | Query profiles, metrics, or both from Pyroscope | datasources:query | datasources:uid:pyroscope-uid |
get_assertions | Asserts | Get assertion summary for a given entity |
Documentation truncated — see the full README on GitHub.
Be the first to review this server!
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace · Finance
Free stock data and market news for any MCP-compatible AI assistant.
by mcp-marketplace · Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm — conversationally
by mcp-marketplace · Developer Tools
Search and install MCP servers from inside your AI client.