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.51;18432
pymosq_async;0:07.43;25424
pymosq_true_async;0:09.28;25000
paho;0:08.74;23400
gmqtt;0:04.16;24688
mqttools;0:06.17;27804
aiomqtt;0:52.38;578184
amqtt;1:01.23;767248

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.6.tar.gz (13.7 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.6-py3-none-any.whl (12.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pymosquitto-0.3.6.tar.gz
  • Upload date:
  • Size: 13.7 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.6.tar.gz
Algorithm Hash digest
SHA256 28d56c5be781ac8e04136f7ad8e1eca711c39b106a49c0d00030e11e6675cbc7
MD5 d982c7b025ad2743250127ff2dfecd91
BLAKE2b-256 b4c47971aa04c2981abdc83c4145b6dd150e37af6a89222428c0e33ea6678c28

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pymosquitto-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 12.3 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.6-py3-none-any.whl
Algorithm Hash digest
SHA256 507589e67e1afacb49e8a23ee8551c45d1b21b14b867ae269c5e0dcfcb4df74c
MD5 fd247bc148099b39d29dc8baf396dab5
BLAKE2b-256 fed2bfed194322834afdd91e491ec604184225ebf2ed1b288248e2270db1508a

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