Accéder au contenu principal

Parlez vous MQTT?

Parlez vous MQTT?

MQTT (Message Queuing Telemetry Transport - https://fr.wikipedia.org/wiki/MQTT) est un Bus logiciel utilisant des mécanismes de Publish/Subscribe pour transmettre des données à un serveur et permettre à des clients de s'abonner à ces modifications.

Le protocole est basé sur TCP/IP et est suffisament simple, du moins pour la partie client, pour être embarqué dans des micro-controlleurs tels que le Cerbuino Bee ou l'ESP 8266.
Un document d'IBM explique assez précisément le fonctionnement : http://www.redbooks.ibm.com/redbooks/pdfs/sg248054.pdf.
Le serveur peut tout aussi bien être local, embarqué sur un Raspberry, que distant, hébergé sur un serveur de test public ou sur un serveur privé.

Côté serveur Je m'interesserai plus particulièrement au serveur Mosquitto disponible sur Raspberry Pi. Pour tester sur PC, il existe également une version en Java.
Le serveur est uniquement en attente des clients qui vont s'abonner à des données et d'autres qui vont publier des données. Lorsqu'une donnée est publiée, elle est diffusée à l'ensemble des clients qui s'y sont abonnés.

Les données sont généralement des chaînes de caractères de type (Variable = Valeur), mais elles peuvent également être des données binaires.
La valeur peut être une donnée simple : (/chambre_enfants/temperature=21).
Ou être une donnée complexe : (/maison={'chambre_1':'21', 'chambre_2':'19'})
La manière dont la valeur va être interprétée dépend de chaque client.

Serveur MQTT en Java

Moquette est un serveur MQTT simple en Java qui s'installe en 1 minute chrono.
Le serveur peut être récupéré sur https://github.com/andsel/moquette. La dernière versions 0.8 fournit des scripts permettant de l'exécuter aussi bien sous Linux que sous Windows.
Une fois le fichier distribution-0.8-bundle-tar.tar.gz récupéré, il suffit de les dézipper et détarrer avec 7-zip ou tout autre utilitaire :
gunzip distribution-0.8-bundle-tar.tar.gz
cd distribution-0.8-bundle-tar.tar
tar xvf  distribution-0.8-bundle-tar.tar
Pour le lancer, il faut préalablement définir la variable d'environnement JAVA_HOME.
 set JAVA_HOME="C:\Java\jdk1.7.0_40"  
 cd bin  
 moquette.bat  
 "                                     "  
 " ___ ___            _  _    ___ ________ _____ _____ "  
 " | \/ |           | | | |    | \/ | _ |_  _|_  _| "  
 " | . . | ___  __ _ _  _ ___| |_| |_ ___ | . . | | | | | |  | |  "  
 " | |\/| |/ _ \ / _\ | | | |/ _ \ __| __/ _ \ | |\/| | | | | | |  | |  "  
 " | | | | (_) | (_| | |_| | __/ |_| || __/ | | | \ \/' / | |  | |  "  
 " \_| |_/\___/ \__, |\__,_|\___|\__|\__\___| \_| |_/\_/\_\ \_/  \_/  "  
 "          | |                          "  
 "          |_|                          "  
 "                                     "  
 Using JAVA_HOME:    ""C:\Java\jdk1.7.0_40""  
 Using MOQUETTE_HOME:  "C:\Users\ftoure\Downloads\2016\04.Avril\distribution-0.8  
 -bundle-tar.tar"  
 0  [main] INFO Server - Persistent store file: C:\Users\ftoure\Downloads\201  
 6\04.Avril\distribution-0.8-bundle-tar.tar\bin\moquette_store.mapdb  
 20  [main] INFO MapDBPersistentStore - Starting with existing [C:\Users\ftour  
 e\Downloads\2016\04.Avril\distribution-0.8-bundle-tar.tar\bin\moquette_store.map  
 db] db file  
 404 [main] INFO FileAuthenticator - Loading password file: C:\Users\ftoure\Do  
 wnloads\2016\04.Avril\distribution-0.8-bundle-tar.tar\config\password_file.conf  

Le serveur peut également être embarqué dans une application Java. Voir l'exemple fournit à l'adresse : https://github.com/andsel/moquette/tree/master/embedding_moquette/src/main/java/io/moquette/testembedded .
Le serveur est par défaut assez verbeux. N'hésitez pas à modifier le fichier de configuration "conf/moquette-log.properties" pour n'afficher que les Warnings et les Errors.

Client MQTT en Java

Il existe plusieurs clients Java pour PC, ligne de commande, Android, etc. L'un des plus simple que j'ai trouvé est fourni par le projet Paho : https://github.com/eclipse/paho.mqtt.java/tree/master/org.eclipse.paho.sample.utility.
Voici une copie de l'interface graphique utilisée.


L'utilisation est assez intuitive. Après avoir lancé le serveur, démarrez le client et indiquez l'adresse IP et le port du serveur, puis sélectionnez "Connect". L’icône à droite doit passer du rouge au vert. Dans la partie "Subscribe Topic", entrez un nom d'attribut et cliquez sur Subscribe.
Dans la partie "Topic", entrez le même nom, ainsi qu'un texte libre en dessous, puis cliquez sur "Publish".
Le texte devrait apparaitre dans la fenêtre située sous "Receive Topic", ainsi que le nom de l'attribut qui a été modifié.
Pour vous faire une idée du protocole, vous pouvez cliquer sur le bouton "History" qui listera les différents échanges.

Conclusion

Voici les premiers pas pour commencer avec MQTT. Je reviendrai dans un autre billet pour indiquer d'autres utilisations sur le Raspberry et l'ESP8266.

Commentaires

Posts les plus consultés de ce blog

Utilisez votre tablette Android comme second écran pour Linux (Raspberry Pi, MK908II)

Les tablettes Android atteignent désormais des prix qui défient toute concurrence. On trouve désormais des modèles à 39 € TTC en super marché, soit à peine plus cher que le Raspberry PI, mais avec un écran. Ces modèles souvent mono-core 1Ghz ou 1,4 Ghz avec 512 ou 1Go de mémoire ne sont très probablement pas utilisables pour une utilisation régulière sur Internet et ne sont en aucun point comparables à leur équivalent de marque (Samsung, Sony, LG, HTC, Lenovo, etc). Plusieurs tutoriels indiquent comment connecter utiliser une tablette Android comme second écran ( http://www.linux-magazine.com/Online/Blogs/Productivity-Sauce/Use-an-Android-Device-as-Screen-and-Input-for-Raspberry-Pi ). Ces méthodes utilisent généralement l'USB Tethering qui n'est malheureusement disponible que sur les téléphones ou tablettes avec un accès mobile (3G ou 4G) inclus. Dans ce billet, je vais vous montrer comment se connecter à une tablette en utilisant le mode Debug adb (Android Debug Bridge

Supprimer les partitions Raspberry sur une carte SD sous Windows avec Diskpart

Si vous souhaitez récupérer une ancienne carte SD utilisée pour démarrer un Raspberry pour un autre usage (appareil photo, etc), il vous faudra supprimer les deux partitions créées au moment de l'écriture de l'image sur la carte SD. Vous pouvez voir les partition en sélectionnant Menu Windows/Ordinateur/bouton droit "Gérer". Voici un exemple du résultat final. Vous pouvez supprimer la partition Unix de 7 Gb (ou 4Gb en fonction de la taille de votre carte) en sélectionnant la partition puis en faisant "bouton droit Supprimer". Laissez juste une partition pour pouvoir faire les autres manipulations avec DISKPART. Démarrez l'outil DISKPART en ligne de commande. Une nouvelle fenêtre s'ouvrira. Microsoft DiskPart version 6.1.7601 Copyright (C) 1999-2008 Microsoft Corporation. DISKPART> list disk   N° disque  Statut         Taille   Libre    Dyn  GPT   ---------  -------------  -------  -------  ---  ---   Disque 0    En ligne        238 G octe

Emulateur Raspberry Pi sous Windows

Si vous souhaitez développer ou tester des applications pour Raspberry Pi, vous pouvez, soit compiler directement l'application sur Raspberry, soit la développer sous Linux ou Windows et la compiler pour Raspberry. La seconde solution est souvent plus simple car elle permet de disposer d'un environnement de compilation complet tel qu'Eclipse pour le développement. Une fois l'application développée, il faut la tester sur Raspberry. Là, il faut copier l'application en utilisant un client FTP ou SCP, puis se connecter en SSH et lancer l'exécutable. Il existe un autre moyen de tester une application Raspberry sans avoir à l'allumer. Il suffit de passer par un émulateur tel que QEMU qui permet de lancer un OS pour processeur ARM sous Linux ou Windows. L'émulateur sous Windows 1. Récupérez l'émulateur à l'adresse suivante : http://sourceforge.net/projects/rpi-emulator-win32/ . 2. Dézippés le contenu de l'image Rpi-Occidentalis-v02-qemu.7z av