Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eerimoq/mqttools
MQTT version 5.0 client and broker using asyncio
https://github.com/eerimoq/mqttools
asyncio mqtt mqtt-5 mqtt-broker mqtt-client python
Last synced: 25 days ago
JSON representation
MQTT version 5.0 client and broker using asyncio
- Host: GitHub
- URL: https://github.com/eerimoq/mqttools
- Owner: eerimoq
- License: mit
- Created: 2019-05-01T16:15:41.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2021-12-24T12:15:07.000Z (about 3 years ago)
- Last Synced: 2024-10-19T11:10:20.495Z (3 months ago)
- Topics: asyncio, mqtt, mqtt-5, mqtt-broker, mqtt-client, python
- Language: Python
- Homepage:
- Size: 557 KB
- Stars: 60
- Watchers: 7
- Forks: 14
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
MQTT Tools
==========MQTT tools in Python 3.7 and later.
Both the client and the broker implements MQTT version 5.0 using
``asyncio``.Client features:
- Subscribe to and publish QoS level 0 topics.
- Broker session resume (or clean start support) for less initial
communication.- Topic aliases for smaller publish packets.
- ``monitor``, ``subscribe`` and ``publish`` command line commands.
Broker features:
- Subscribe to and publish QoS level 0 topics.
- Session resume (or clean start support) for less initial
communication. Session state storage in RAM.- ``broker`` command line command.
Limitations:
There are lots of limitations in both the client and the broker. Here
are a few of them:- QoS level 1 and 2 messages are not supported. A session state storage
is required to do so, both in the client and the broker.- Authentication is not supported.
MQTT version 5.0 specification:
https://docs.oasis-open.org/mqtt/mqtt/v5.0/os/mqtt-v5.0-os.htmlProject homepage: https://github.com/eerimoq/mqttools
Documentation: https://mqttools.readthedocs.io
Installation
============.. code-block:: python
pip install mqttools
Examples
========There are plenty of examples in the `examples folder`_.
Command line
------------Subscribe
^^^^^^^^^Connect to given MQTT broker and subscribe to a topic. All received
messages are printed to standard output... code-block:: text
$ mqttools subscribe /test/#
Connecting to 'localhost:1883'.
Connected.
Topic: /test
Message: 11
Topic: /test/mqttools/foo
Message: barPublish
^^^^^^^Connect to given MQTT broker and publish a message to a topic.
.. code-block:: text
$ mqttools publish /test/mqttools/foo bar
Connecting to 'localhost:1883'.Published 1 message(s) in 0 seconds from 1 concurrent task(s).
Publish multiple messages as quickly as possible with ``--count`` to
benchmark the client and the broker... code-block:: text
$ mqttools publish --count 100 /test/mqttools/foo
Connecting to 'localhost:1883'.Published 100 message(s) in 0.39 seconds from 10 concurrent task(s).
Monitor
^^^^^^^Connect to given MQTT broker and monitor given topics in a text based
user interface... code-block:: text
$ mqttools monitor /test/#
.. image:: https://github.com/eerimoq/mqttools/raw/master/docs/monitor.png
The menu at the bottom of the monitor shows the available commands.
- Quit: Quit the monitor. Ctrl-C can be used as well.
- Play/Pause: Toggle between playing and paused (or running and freezed).
- Format: Message formatting; `auto`, `binary` or `text`.
Broker
^^^^^^Start a broker to serve clients.
.. code-block:: text
$ mqttools broker
Scripting
---------Subscribe
^^^^^^^^^An example connecting to an MQTT broker, subscribing to the topic
``/test/#``, and printing all published messaged... code-block:: python
import asyncio
import mqttoolsasync def subscriber():
client = mqttools.Client('localhost', 1883)await client.start()
await client.subscribe('/test/#')while True:
message = await client.messages.get()if message is None:
print('Broker connection lost!')
breakprint(f'Topic: {message.topic}')
print(f'Message: {message.message}')asyncio.run(subscriber())
Publish
^^^^^^^An example connecting to an MQTT broker and publishing the message
``bar`` to the topic ``/test/mqttools/foo``... code-block:: python
import asyncio
import mqttoolsasync def publisher():
async with mqttools.Client('localhost', 1883) as client:
client.publish(mqttools.Message('/test/mqttools/foo', b'bar'))asyncio.run(publisher())
.. _examples folder: https://github.com/eerimoq/mqttools/tree/master/examples