Exposes general purpose inputs and outputs (GPIO), hardware sensors and serial devices to an MQTT server. Ideal for single-board computers such as the Raspberry Pi.
Visit the documentation for more detailed information.
Hardware support is provided by specific GPIO, Sensor and Stream modules. It's easy to add support for new hardware and the list is growing fast.
- Beaglebone GPIO (
beaglebone
) - Linux Kernel 4.8+ libgpiod (
gpiod
) - GPIO Zero (
gpiozero
) - MCP23017 IO expander (
mcp23017
) - Orange Pi GPIO (
orangepi
) - PCF8574 IO expander (
pcf8574
) - PCF8575 IO expander (
pcf8575
) - PiFace Digital IO 2 (
piface2
) - Raspberry Pi GPIO (
raspberrypi
)
- ADS1x15 analog to digital converters (
ads1x15
) - AHT20 temperature and humidity sensor (
aht20
) - BH1750 light level sensor (
bh1750
) - BME280 temperature, humidity and pressure sensor (
bme280
) - BME680 temperature, humidity and pressure sensor (
bme680
) - DHT11/DHT22/AM2302 temperature and humidity sensors (
dht22
) - DS18S20/DS1822/DS18B20/DS1825/DS28EA00/MAX31850K temperature sensors (
ds18b
) - HCSR04 ultrasonic range sensor (connected to the Raspberry Pi on-board GPIO) (
hcsr04
) - INA219 DC current sensor (
ina219
) - LM75 temperature sensor (
lm75
) - MCP3008 analog to digital converter (
mcp3008
)
- Serial port (
serial
)
Requires Python 3.6+
pip3 install mqtt-io
python3 -m mqtt_io config.yml
Configuration is written in a YAML file which is passed as an argument to the server on startup.
See the full configuration documentation for details.
The following example will configure the software to do the following:
- Publish MQTT messages on the
home/input/doorbell
topic when the doorbell is pushed and released. - Subscribe to the MQTT topic
home/output/port_light/set
and change the output when messages are received on it. - Periodically read the value of the LM75 sensor and publish it on the MQTT topic
home/sensor/porch_temperature
. - Publish any data received on the
/dev/ttyUSB0
serial port to the MQTT topichome/serial/alarm_system
. - Subscribe to the MQTT topic
home/serial/alarm_system/send
and send any data received on that topic to the serial port.
mqtt:
host: localhost
topic_prefix: home
# GPIO
gpio_modules:
# Use the Raspberry Pi built-in GPIO
- name: rpi
module: raspberrypi
digital_inputs:
# Pin 0 is an input connected to a doorbell button
- name: doorbell
module: rpi
pin: 0
digital_outputs:
# Pin 1 is an output connected to a light
- name: porch_light
module: rpi
pin: 1
# Sensors
sensor_modules:
# An LM75 sensor attached to the I2C bus
- name: lm75_sensor
module: lm75
i2c_bus_num: 1
chip_addr: 0x48
sensor_inputs:
# The configuration of the specific sensor value to use (LM75 only has temperature)
- name: porch_temperature
module: lm75_sensor
# Streams
stream_modules:
# A serial port to communicate with the house alarm system
- name: alarm_system
module: serial
device: /dev/ttyUSB0
baud: 9600
Config for counter mode:
digital_inputs:
- name: impulse_gaszaehler_counter
module: rpi
pin: 4
is_counter: true
old_value: 18500
increment_per_impulse: 0.01
min_pulses_between_transmission: 1
file_path: /home/pi/counter_value.txt
To install RPi.GPIO correctly, use:
export CFLAGS=-fcommon
pip3 install RPi.GPIO
and install
sudo apt install python3-dev
Place under /etc/systemd/system/io2mqtt.service
:
[Unit]
Description=mqtt-io
Documentation=https://github.com/DominicWindisch/mqtt-io/
After=network-online.target
[Service]
Type=simple
Restart=always
RestartSec=2min
ExecStart=/opt/mqtt-io/venv/bin/python3.9 -m mqtt_io /opt/mqtt-io/venv/config.yml
[Install]
WantedBy=multi-user.target