Skip to main content

A lightweight Python MQTT client implemented as a thin wrapper around libmosquitto

Project description

PyMosquitto

A lightweight Python MQTT client implemented as a thin wrapper around libmosquitto.

It provides an efficient synchronous client (client.Client) and two variants of asynchronous clients:

  • aio.AsyncClient - async interface to libmosquitto loop running in its own thread. It's faster, but consumes a little bit more memory.
  • aio.TrueAsyncClient - manages all events in asyncio loop by utilizing mosquitto_loop_{read,write,misc} functions.

Dependencies

  • python3.8+
  • libmosquitto1

Installation

  • pip install pymosquitto

TODO

  • add v5 support

Usage

from pymosquitto import Client


def on_message(client, userdata, msg):
    print(msg)


client = Client()
client.on_connect = lambda *_: client.subscribe("#", 1)
client.on_message = on_message
client.connect_async("localhost", 1883)
client.loop_forever()

Async client example:

import asyncio

from pymosquitto.aio import AsyncClient


async def main():
    async with AsyncClient() as client:
        await client.connect("localhost", 1883)
        await client.subscribe("#", 1)
        async for msg in client.read_messages():
            print(msg)


asyncio.run(main())

Check out more examples in tests directory.

Benchmarks

Receiving one million messages with QoS 0.

*The memory plots exclude the Python interpreter overhead (~8.7 MB).

benchmark-results

Losers excluded:

benchmark-results-fast

benchmark.csv

Module;Time;RSS
pymosq;0:04.63;18340
pymosq_async;0:07.35;25792
pymosq_true_async;0:09.59;24872
paho;0:08.77;23400
gmqtt;0:04.15;24680
mqttools;0:06.21;27872
aiomqtt;0:51.03;578184
amqtt;0:58.32;756508

License

MIT

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

pymosquitto-0.3.7.tar.gz (13.6 kB view details)

Uploaded Source

Built Distribution

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

pymosquitto-0.3.7-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file pymosquitto-0.3.7.tar.gz.

File metadata

  • Download URL: pymosquitto-0.3.7.tar.gz
  • Upload date:
  • Size: 13.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pymosquitto-0.3.7.tar.gz
Algorithm Hash digest
SHA256 8aa6b84d05768d9c86aeab64445d2d2b8686bdf0a92d526bb9e116a942d08aba
MD5 d447622a617f406cb3e7db222f4bf7b8
BLAKE2b-256 1c563cbfb30f9c4b1cf360bbe4f040f37cc7d31d1e84fb0814a05112bdf0f77c

See more details on using hashes here.

File details

Details for the file pymosquitto-0.3.7-py3-none-any.whl.

File metadata

  • Download URL: pymosquitto-0.3.7-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pymosquitto-0.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 821b56d16e0465a7a46bed96df8967c0d78afa06b2ef7d5473ea890966a7ed68
MD5 79418e45878314f5e3916b6e76bdd01b
BLAKE2b-256 0af3a879f1fe882b478c12088231ca10fbc9657a6e8e715c94240766790ceb6c

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