npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

mcp-aiven

v1.3.3

Published

MCP server for Aiven cloud data platform - manage PostgreSQL, Kafka, and other services

Downloads

225

Readme

Aiven MCP Server

A Model Context Protocol (MCP) server for the Aiven cloud data platform.

Manage PostgreSQL, Apache Kafka, applications, and other Aiven services directly from AI assistants like Claude, Cursor, and VS Code Copilot.

[!WARNING] Use with care. This MCP server can create, modify, and delete Aiven services and data on your behalf. AI agents may execute destructive actions (dropping databases, deleting services, producing messages) based on their interpretation of your prompts. You are fully responsible for the actions taken through this tool.

Permissions: Access is governed by the Aiven user permissions associated with the authenticated account. The MCP server can only perform actions that your Aiven user is allowed to do.

AI Agent Security: AI agents may need access credentials (database connection strings, streaming tokens) to act on your behalf. Review what your agent is doing, especially in production environments. Follow your organization's security policies and do a risk assessment before giving AI agents access to sensitive resources.

Quick Start

Option 1: Remote (hosted by Aiven)

The MCP server is hosted at https://mcp.aiven.live/mcp. Your MCP client will prompt you to authorize on Aiven.

Claude Code

claude mcp add --scope user --transport http aiven-mcp "https://mcp.aiven.live/mcp"

Cursor

Install MCP Server

Or manually add to Cursor MCP settings:

{
  "mcpServers": {
    "aiven-mcp": {
      "url": "https://mcp.aiven.live/mcp"
    }
  }
}

VS Code / Copilot

Add to .vscode/mcp.json in your workspace:

{
  "servers": {
    "aiven-mcp": {
      "type": "http",
      "url": "https://mcp.aiven.live/mcp"
    }
  }
}

Read-Only Mode (Remote)

Enable read-only mode by adding ?read_only=true to the URL. All write operations will be excluded from the MCP:

{
  "mcpServers": {
    "aiven-mcp": {
      "url": "https://mcp.aiven.live/mcp?read_only=true"
    }
  }
}

Scoped Tools (Remote)

Reduce the tool surface exposed to your AI agent by adding ?services_scope= to the URL. Useful when you only work with a subset of Aiven services and want to keep the agent's context focused. Combine values with commas. core (project/service discovery) is always included implicitly.

Valid scopes: all, core, pg, kafka, application, integrations. Use all to explicitly load every tool (same as omitting the param). all cannot be combined with other scopes.

{
  "mcpServers": {
    "aiven-mcp": {
      "url": "https://mcp.aiven.live/mcp?services_scope=kafka"
    }
  }
}

You can also combine with read_only:

https://mcp.aiven.live/mcp?services_scope=pg&read_only=true

Option 2: stdio (local)

Run the server locally as a child process of your MCP client. Requires Node.js 18+.

You must provide your Aiven API token via the AIVEN_TOKEN environment variable. Create a token here.

Claude Code

claude mcp add --scope user aiven-mcp -e AIVEN_TOKEN=your-token-here -- npx -y mcp-aiven

Cursor, VS Code -- add to your MCP client config:

{
  "mcpServers": {
    "aiven-mcp": {
      "command": "npx",
      "args": ["-y", "mcp-aiven"],
      "env": {
        "AIVEN_TOKEN": "your-token-here"
      }
    }
  }
}

Config file locations:

  • Cursor: Cursor Settings > MCP Servers
  • VS Code: .vscode/mcp.json in your workspace

Option 3: Local development

Run a local build of the server (useful for development and testing):

pnpm install && pnpm generate:api-types && pnpm generate && pnpm build && AIVEN_TOKEN="<YOUR_TOKEN>" MCP_TRANSPORT="http" PORT=3000 node dist/index.js

The server listens on port 3000 by default. Connect your MCP client to http://localhost:3000/mcp.

To point a remote deployment at a custom host (e.g. your local build), set MCP_HOST:

MCP_HOST=http://localhost:3000 node dist/index.js

Environment Variables

| Variable | Required | Default | Description | |---|---|---|---| | AIVEN_TOKEN | stdio only | -- | Aiven API token (create one here) | | AIVEN_READ_ONLY | No | false | Set to true to expose only read-only tools | | AIVEN_SERVICES_SCOPE | No | -- | Comma-separated scopes to expose (e.g. kafka, pg,kafka, or all). Valid: all, core, pg, kafka, application, integrations. core is always included. Omitting the var or setting all loads every tool. | | MCP_HOST | No | https://mcp.aiven.live | Override the OAuth protected resource host | | MCP_TRANSPORT | No | stdio | Set to http to start an HTTP server instead of stdio |

In remote (HTTP) mode, AIVEN_TOKEN is not needed. Your MCP client sends your token as a Bearer token with each request.

Tools

Core

| Tool | Description | |---|---| | aiven_project_list | List projects | | aiven_project_get | Get project details | | aiven_list_project_clouds | List cloud platforms for a project | | aiven_project_vpc_list | List VPCs for a project | | aiven_service_list | List services | | aiven_service_type_plans | List plans with cloud availability | | aiven_service_plan_pricing | Get pricing for a plan in a specific cloud | | aiven_service_create | Create a service | | aiven_service_get | Get service information | | aiven_service_update | Update a service (plan, config, power state) | | aiven_service_metrics_fetch | Fetch metrics for managed data services | | aiven_service_application_metrics_get | Fetch metrics for application services | | aiven_project_get_service_logs | Get service log entries | | aiven_service_query_activity | Fetch current queries for a service | | aiven_project_get_event_logs | Get project event log entries |

Kafka

| Tool | Description | |---|---| | aiven_kafka_topic_list | List Kafka topics | | aiven_kafka_topic_create | Create a Kafka topic | | aiven_kafka_topic_get | Get Kafka topic info | | aiven_kafka_topic_update | Update a Kafka topic | | aiven_kafka_topic_delete | Delete a Kafka topic | | aiven_kafka_topic_message_list | Read messages from a Kafka topic | | aiven_kafka_topic_message_produce | Produce messages into a Kafka topic | | aiven_kafka_connect_available_connectors | List available connector types | | aiven_kafka_connect_list | List running connectors | | aiven_kafka_connect_create_connector | Create a connector | | aiven_kafka_connect_edit_connector | Edit a connector | | aiven_kafka_connect_get_connector_status | Get connector status | | aiven_kafka_connect_pause_connector | Pause a connector | | aiven_kafka_connect_resume_connector | Resume a connector | | aiven_kafka_connect_restart_connector | Restart a connector | | aiven_kafka_connect_delete_connector | Delete a connector | | aiven_kafka_schema_registry_subjects | List Schema Registry subjects | | aiven_kafka_schema_registry_subject_version_get | Get Schema Registry subject version |

PostgreSQL

| Tool | Description | |---|---| | aiven_pg_service_available_extensions | List available extensions | | aiven_pg_service_query_statistics | Fetch query statistics | | aiven_pg_bouncer_create | Create a PgBouncer connection pool | | aiven_pg_bouncer_update | Update a PgBouncer connection pool | | aiven_pg_bouncer_delete | Delete a PgBouncer connection pool | | aiven_pg_read | Run a read-only SQL query | | aiven_pg_write | Run a write SQL statement (INSERT, UPDATE, DELETE, CREATE TABLE, etc.) | | aiven_pg_optimize_query | AI-powered query optimization (EverSQL) |

Applications

| Tool | Description | |---|---| | aiven_application_deploy | Deploy a Dockerized application to Aiven | | aiven_application_redeploy | Rebuild and redeploy an existing application | | aiven_vcs_integration_list | List connected VCS (GitHub) accounts | | aiven_vcs_integration_repository_list | List repositories for a VCS integration |

Documentation

| Tool | Description | |---|---| | aiven_docs_search | Search the official Aiven documentation in natural language. Only available on the hosted server (https://mcp.aiven.live/mcp) — not exposed in self-hosted deployments. |

Contributing

See CONTRIBUTING.md for development setup, running locally, and adding new tools.

License

Apache-2.0