Skip to main content

MQTT Model Context Protocol Server for AI-powered smart home control

Project description

MQTT MCP Server

PyPI Python License

MCP server that connects AI assistants to MQTT brokers for smart home automation and IoT device control.

What it does:

  • Discovers MQTT topics and devices on your network
  • Reads sensor values and device states
  • Sends commands to control devices
  • Monitors real-time MQTT events

Use cases:

  • Control smart home devices through AI assistants
  • Monitor IoT sensor networks
  • Automate home automation workflows
  • Debug MQTT integrations

Quick Navigation

Choose your system:

Linux

macOS

Windows


Linux

Linux • Claude Code

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Claude Code

claude mcp add --transport stdio mqtt \
  --env MQTT_HOST=YOUR_BROKER_IP \
  --env MQTT_PORT=1883 \
  --env MQTT_USERNAME=YOUR_USERNAME \
  --env MQTT_PASSWORD=YOUR_PASSWORD \
  -- python3 -m mqtt_mcp.server

Step 3: Verify

claude mcp list

You should see: mqtt: python3 -m mqtt_mcp.server - ✓ Connected


Linux • Codex CLI

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Codex

codex mcp add mqtt \
  --env MQTT_HOST=YOUR_BROKER_IP \
  --env MQTT_PORT=1883 \
  --env MQTT_USERNAME=YOUR_USERNAME \
  --env MQTT_PASSWORD=YOUR_PASSWORD \
  -- python3 -m mqtt_mcp.server

Step 3: Verify

codex mcp list

Linux • Cursor

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Cursor

Open Cursor Settings → MCP, or create ~/.cursor/mcp.json (global) or .cursor/mcp.json (project-only):

{
  "mcpServers": {
    "mqtt": {
      "command": "python3",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart Cursor


Linux • Cline

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Cline

In VS Code, click MCP Servers icon → Configure MCP Servers, or edit cline_mcp_settings.json:

{
  "mcpServers": {
    "mqtt": {
      "command": "python3",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart VS Code


Linux • Other Clients

For any MCP client that supports stdio transport:

1. Install the package:

pip install mqtt-mcp-server

2. Configure with these values:

  • Command: python3
  • Args: ["-m", "mqtt_mcp.server"]
  • Environment variables:
    • MQTT_HOST - Your broker IP/hostname
    • MQTT_PORT - Broker port (usually 1883)
    • MQTT_USERNAME - Optional username
    • MQTT_PASSWORD - Optional password

macOS

macOS • Claude Code

Step 1: Install the package

pip3 install mqtt-mcp-server

Step 2: Add to Claude Code

claude mcp add --transport stdio mqtt \
  --env MQTT_HOST=YOUR_BROKER_IP \
  --env MQTT_PORT=1883 \
  --env MQTT_USERNAME=YOUR_USERNAME \
  --env MQTT_PASSWORD=YOUR_PASSWORD \
  -- python3 -m mqtt_mcp.server

Step 3: Verify

claude mcp list

You should see: mqtt: python3 -m mqtt_mcp.server - ✓ Connected


macOS • Codex CLI

Step 1: Install the package

pip3 install mqtt-mcp-server

Step 2: Add to Codex

codex mcp add mqtt \
  --env MQTT_HOST=YOUR_BROKER_IP \
  --env MQTT_PORT=1883 \
  --env MQTT_USERNAME=YOUR_USERNAME \
  --env MQTT_PASSWORD=YOUR_PASSWORD \
  -- python3 -m mqtt_mcp.server

Step 3: Verify

codex mcp list

macOS • Claude Desktop

Step 1: Install the package

pip3 install mqtt-mcp-server

Step 2: Configure Claude Desktop

Open: ~/Library/Application Support/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "mqtt": {
      "command": "python3",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart Claude Desktop


macOS • Cursor

Step 1: Install the package

pip3 install mqtt-mcp-server

Step 2: Add to Cursor

Open Cursor Settings → MCP, or create ~/.cursor/mcp.json (global) or .cursor/mcp.json (project-only):

{
  "mcpServers": {
    "mqtt": {
      "command": "python3",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart Cursor


macOS • Cline

Step 1: Install the package

pip3 install mqtt-mcp-server

Step 2: Add to Cline

In VS Code, click MCP Servers icon → Configure MCP Servers, or edit cline_mcp_settings.json:

{
  "mcpServers": {
    "mqtt": {
      "command": "python3",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart VS Code


macOS • Other Clients

For any MCP client that supports stdio transport:

1. Install the package:

pip3 install mqtt-mcp-server

2. Configure with these values:

  • Command: python3
  • Args: ["-m", "mqtt_mcp.server"]
  • Environment variables:
    • MQTT_HOST - Your broker IP/hostname
    • MQTT_PORT - Broker port (usually 1883)
    • MQTT_USERNAME - Optional username
    • MQTT_PASSWORD - Optional password

Windows

Windows • Claude Code

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Claude Code

claude mcp add --transport stdio mqtt `
  --env MQTT_HOST=YOUR_BROKER_IP `
  --env MQTT_PORT=1883 `
  --env MQTT_USERNAME=YOUR_USERNAME `
  --env MQTT_PASSWORD=YOUR_PASSWORD `
  -- python -m mqtt_mcp.server

Step 3: Verify

claude mcp list

You should see: mqtt: python -m mqtt_mcp.server - ✓ Connected


Windows • Codex CLI

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Codex

codex mcp add mqtt `
  --env MQTT_HOST=YOUR_BROKER_IP `
  --env MQTT_PORT=1883 `
  --env MQTT_USERNAME=YOUR_USERNAME `
  --env MQTT_PASSWORD=YOUR_PASSWORD `
  -- python -m mqtt_mcp.server

Step 3: Verify

codex mcp list

Windows • Claude Desktop

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Configure Claude Desktop

Open: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "mqtt": {
      "command": "python",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart Claude Desktop


Windows • Cursor

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Cursor

Open Cursor Settings → MCP, or create ~/.cursor/mcp.json (global) or .cursor/mcp.json (project-only):

{
  "mcpServers": {
    "mqtt": {
      "command": "python",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart Cursor


Windows • Cline

Step 1: Install the package

pip install mqtt-mcp-server

Step 2: Add to Cline

In VS Code, click MCP Servers icon → Configure MCP Servers, or edit cline_mcp_settings.json:

{
  "mcpServers": {
    "mqtt": {
      "command": "python",
      "args": ["-m", "mqtt_mcp.server"],
      "env": {
        "MQTT_HOST": "YOUR_BROKER_IP",
        "MQTT_PORT": "1883",
        "MQTT_USERNAME": "YOUR_USERNAME",
        "MQTT_PASSWORD": "YOUR_PASSWORD"
      }
    }
  }
}

Step 3: Restart VS Code


Windows • Other Clients

For any MCP client that supports stdio transport:

1. Install the package:

pip install mqtt-mcp-server

2. Configure with these values:

  • Command: python (not python3)
  • Args: ["-m", "mqtt_mcp.server"]
  • Environment variables:
    • MQTT_HOST - Your broker IP/hostname
    • MQTT_PORT - Broker port (usually 1883)
    • MQTT_USERNAME - Optional username
    • MQTT_PASSWORD - Optional password

Available Tools

After installation, ask your AI assistant: "What MQTT tools are available?"

You should see 4 tools:

topics

Discover MQTT topics on your broker.

Parameters:
- scan_timeout: Scan duration in seconds (1-60, default: 10)
- keywords: Filter topics by keywords
- limit: Max results (1-200, default: 50)

value

Read current values from topics (uses cache for speed).

Parameters:
- topics: List of topic paths (required)
- timeout: Wait time per topic (1-60, default: 5)

publish

Send commands to MQTT devices.

Parameters:
- messages: List of {topic, payload, qos, retain}
- timeout: Network timeout (1-30, default: 3)

record

Monitor MQTT events in real-time.

Parameters:
- timeout: Recording duration (1-300, default: 30)
- topics: Specific topics to monitor
- keywords: Filter by keywords

Troubleshooting

"python3 not found" (Windows)

Use 'python' instead of 'python3' in all commands

"Connection refused"

1. Check MQTT broker is running
2. Verify MQTT_HOST and MQTT_PORT are correct
3. Check firewall settings
4. Test connection: mosquitto_sub -h YOUR_HOST -p 1883 -t "#"

"Module not found: mqtt_mcp"

Install the package: pip install mqtt-mcp-server
If using venv, make sure it's activated

Tools not appearing

1. Restart your AI client
2. Check JSON syntax in config file
3. Verify connection: claude mcp list (or codex mcp list)
4. Check logs (location depends on client)

Permission errors (Linux/macOS)

Use pip3 install --user mqtt-mcp-server
Or install in virtual environment

Development

For contributors and developers:

Install from source

# Clone repository
git clone https://github.com/eduard256/mqtt-mcp-server.git
cd mqtt-mcp-server

# Create virtual environment
python3 -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install in development mode
pip install -e .

Run tests

# Linux/macOS
python3 tests/test_topics.py
python3 tests/test_value.py
python3 tests/test_publish.py
python3 tests/test_record.py

# Windows
python tests\test_topics.py
python tests\test_value.py
python tests\test_publish.py
python tests\test_record.py

Requirements

  • Python 3.10+
  • MQTT broker (Mosquitto, EMQX, HiveMQ, etc.)

Links

License

MIT License - See LICENSE for details

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mqtt_mcp_server-1.0.2.tar.gz (19.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mqtt_mcp_server-1.0.2-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file mqtt_mcp_server-1.0.2.tar.gz.

File metadata

  • Download URL: mqtt_mcp_server-1.0.2.tar.gz
  • Upload date:
  • Size: 19.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for mqtt_mcp_server-1.0.2.tar.gz
Algorithm Hash digest
SHA256 c232bdb0c688f1e688da8a5cc89b18cbc05cade8c5fc32430b1cd7b7bd573820
MD5 ac1e897eaea4f9346f2f99778913a2c9
BLAKE2b-256 510bcabdcfaf3feadc00182bc3f0c704f56efbf359bce7f80559078b04b1198a

See more details on using hashes here.

File details

Details for the file mqtt_mcp_server-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for mqtt_mcp_server-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5814e2761eab7e2ba55f6cc86b6f1b457d0d9db1cbcc57ed3c75dbdf1db3374a
MD5 0f96fb669bcccbfaa30e937c317620cd
BLAKE2b-256 8f202f0c1182d0318af81449e90f896d7d967e371799a4c15b481237d128ab49

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page