This application, crafted in Go, facilitates seamless integration between your KNX installation and MQTT. Perfect for smart home enthusiasts and IoT integrators, this bridge offers customizable and efficient connectivity.
- Customizable Integration: Connect your KNX system with MQTT effortlessly.
- Automatic Type Conversion: Provide an XML export from ETS, and the app will handle type conversions automatically.
- Flexible MQTT Topics: Publish KNX events to MQTT topics formatted as knx/x/y/z, wherex/y/zrepresents the group address. You can also configure theknx/prefix and use names for group address sections.
To get the most out of this application, provide an ETS XML export of your group addresses and their datapoint types. This enables automatic conversion between raw types and ensures precise data handling. Without this export, you’ll be limited to handling raw bytes only.
For a detailed guide on setting up and customizing the KNX/MQTT bridge, refer to the example configuration file. This file is thoroughly documented and provides comprehensive instructions for tailoring the bridge to your specific needs.
Please note that the default configuration logs at the info level, which does not include detailed logs of successfully read KNX messages. During the integration phase, you may want to adjust the log level to debug to see incoming messages and gain better visibility into the bridge's operations.
You can build the application yourself, but using Docker is often more convenient. Here’s how you can get started with Docker:
Note that binding to the host's network is only necessary if you connect to KNX over multicast, i.e. tunnelMode: false.
docker run --rm -it --network host -v $(pwd)/config.yaml:/app/config.yaml -v $(pwd)/knx.xml:/app/knx.xml pakerfeldt/knx-mqtt:latest
services:
  knx-mqtt:
    image: pakerfeldt/knx-mqtt:latest
    restart: unless-stopped
    network_mode: "host"
    volumes:
      - ./config.yaml:/app/config.yaml
      - ./knx.xml:/app/knx.xml
The app supports several payload formats for MQTT messages:
| Type | Description | Requires KNX XML | 
|---|---|---|
| value | the value (e.g., 24.42) | Yes | 
| value-with-unit | String representation including the unit (e.g., 24.42 °C) | Yes | 
| json | JSON representation of the message | Yes | 
| bytes | Raw bytes as specified by KNX | No | 
When sending JSON messages, you can choose to include/exclude the following fields:
| Field | Description | 
|---|---|
| bytes | Raw bytes encoded in Base64 | 
| name | Name of the group address | 
| value | Value with preserved type or as string representation if emitValueAsString is true | 
| unit | Associated unit of the value | 
Read commands from KNX will be passed on to the address + /read, e.g. knx/1/2/3/read. If you subscribe
with wildcard, e.g.. knx/1/2/# you will get these read messages that you might want to discard. The
fact that these read messages are preserved from KNX to MQTT allows for having an external response to a
KNX initiated read request. With the config option ignoreReadCommands: true you can ignore any such
message from KNX.
KNX group addresses can be referred to using either their group address knx/x/y/z or their full name,
where x and y are the names of the group ranges and z is the name of the actual group address.
To send a read request, write to knx/x/y/z/read with any payload.
To write to a group address with its raw bytes, send a message to knx/x/y/z/write-bytes with the bytes as payload.
To write to a group address using a string representation, send a message to knx/x/y/z/write with the value as a string.
E.g. "25.35", "true".
See supported-dpts. Let me know if you're missing a specific DPT.
If you’re transitioning from knx-mqtt-bridge, the NodeJS version of this bridge, you’ll find the migration relatively straightforward. The configurations are similar enough to make the transition smooth.