godot_client | ||
resources | ||
rp2040_client | ||
README.md |
In this workshop, we will learn how to use MQTT for connected devices.
- Install Mosquitto Broker and Client
- Adjust ports/firewalls
On the client side, we will learn to install and use an MQTT client on diverse devices.
- Install MicroPython client on RP2040
- Install GDScript client on Godot Game Engine
Software Required
- Git (for downloading project repo)
- Thonny (python code editor with RP2040 support)
Optional
- Raspberry Pi running Raspbian
- Godot Game Engine
Intro
What is MQTT? MQTT is a very lightweight protocol for sending messages around a network. It is simple and easy to work with, involving the use of a "broker" that centralizes the messages, and "clients" that can receive and send the messages.
Because MQTT is so lightweight, it works well on devices with limited resources, such as microcontrollers. It has become one of the most popular protocols for internet-of-things and edge devices.
The MQTT Broker
While there are many software packages for installing an MQTT broker, probably the most popular is Mosquitto. It is available for most operating systems, and comes with both broker and client software.
Installation on Linux (debian):
sudo apt install mosquitto mosquitto-clients
Once you have installed the broker, it will automatically start as a service that will run in the background, and clients can connect to it.
In Mosquitto version 2+ extra security was implemented requiring clients to connect with authentication. This is overkill for many purposes, so we will allow clients to connect anonymously by editing the configuration file.
On Ubuntu:
Locate /etc/mosquitto/mosquitto.conf
Open the file for editing:
sudo nano mosquitto.conf
Add the following line:
allow_anonymous true
However, there may be other factors in your OS setup that can affect the clients from connecting - most importantly your firewall settings.
In Ubuntu Linux, the most common firewall software is UFW. This comes by default with that distribution. The firewall can be configured to allow or disallow traffic on specific ports.
The port used by default for the Mosquitto broker is 1883. We must ensure that this is available for clients to connect to.
The command to see if UFW is running and what ports it is monitoring looks like this:
sudo ufw status
To allow connections through the firewall on port 1883 (the MQTT port) you can write a rule for UFW
sudo ufw allow 1883/tcp
Note that you can get a lot more specific with UFW rules, including limiting access to certain applications or IP addresses.
Using the MQTT Client
Once the broker is up and running, and the firewall is configured to allow connections, clients can connect. This is very easy to test on the local machine, because the Mosquitto installation come with a client you can use from the command line.
MQTT organizes messaging by topics that clients can both publish to and subscribe to for updates. The topics can include anything.
On the machine where we installed the broker we can test by subscribing and publishing to the "godot" topic.
mosquitto_sub -v -h 127.0.0.1 -t "godot/#"
This subscribes the mosquitto client to hear updates from the broker running on 127.0.0.1 (the local machine) for any message in the "godot" topic.
In a new window, lets test publishing a message.
mosquitto_pub -h 127.0.0.1 -t "godot/abcd" -m "Bingo!"
In the first window, you'll see the message appear.
From this you can see that devices can be either publishers, subscribers, or both. Any devices on the same network can use their client to communicate back and forth with this messaging.
What you can do with this:
MQTT clients are pretty ubiquitous since they are just based on TCP, a very common protocol.
If the client can be made to run on something like a microcontroller, messaging can be used to do things such boards are great at - controlling hardware.
In the next section, we will get an MQTT client working on the Raspberry Pi Pico W, a popular microcontroller built on the RP2040 chip.
To achieve this, we will need to:
- Flash the board with the language of choice (we are using MicroPython)
- Install an MQTT client written in that language
- Write code that connects to the network and uses the client code to connect to the broker
- Interpret the MQTT messaging into control of hardware
MQTT on MicroPython
Let's begin by prepping the board for programming
In the 'resources' folder you will find specific instructions, along with the UF2 file that is needed to flash the board with MicroPython. Once that is done you'll need to have a code editor that has support for connecting to the board.
Thonny is the code editor commonly used for this.
If you do not have Thonny installed, you can follow these instructions.
Ubuntu:
sudo apt install Thonny
Once completed you should be able to connect to the RP2040 with Thonny.
Resources
- Mosquitto man pages https://mosquitto.org/man/
- Godot MQTT client https://github.com/goatchurchprime/godot-mqtt
- Install broker/client on Linux http://www.steves-internet-guide.com/install-mosquitto-linux/
- Install broker/client on RPI https://randomnerdtutorials.com/how-to-install-mosquitto-broker-on-raspberry-pi/
- Core Electronics RP2040 guide https://core-electronics.com.au/guides/getting-started-with-mqtt-on-raspberry-pi-pico-w-connect-to-the-internet-of-things/
- RP2040 client https://github.com/micropython/micropython-lib/tree/master/micropython/umqtt.simple