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.72;18604
pymosq_async;0:08.31;25824
pymosq_true_async;0:09.76;24964
paho;0:09.13;23220
gmqtt;0:04.67;24664
mqttools;0:06.74;27820
aiomqtt;0:52.20;577952
amqtt;1:04.67;757272

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.5.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.5-py3-none-any.whl (12.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pymosquitto-0.3.5.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.5.tar.gz
Algorithm Hash digest
SHA256 ed5318e9b45858b8fce99bdf40fd0c9e1f9728dd9dde5921d26611e2b1c51fce
MD5 0dd639b251a902f8d93d4cbc6db619de
BLAKE2b-256 edf4cba8ace6689bfe95f876def9e794e7ee3181dc6bf49a716934111b1da9f9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pymosquitto-0.3.5-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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 3234d60ba6161a3167a8b83561583966c5dd5443cf5df5157f5d098637e5a61a
MD5 e8a71ed961a1b24d02a7dd10a7790593
BLAKE2b-256 94a35d8f26e1c142cdc361dbe230e25b1dd4ed58638792ace8fc241b25482d72

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