Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende ÜberarbeitungLetzte ÜberarbeitungBeide Seiten der Revision | ||
manuals:symcon:mqtt-integration [2016/11/30 21:40] – [Symcon] paulg4h | manuals:symcon:mqtt-integration [2018/09/22 18:52] – admin | ||
---|---|---|---|
Zeile 1: | Zeile 1: | ||
====== MQTT in Symcon Einbinden ====== | ====== MQTT in Symcon Einbinden ====== | ||
+ | |||
+ | <WRAP center round info 60%> | ||
+ | Stand September 2018, IPS 4.4 | ||
+ | </ | ||
+ | |||
Diese Anleitung zeigt wie man auf einem Raspberry PI 3 das MQTT Protokoll über Mosquitto und mqttwarn in Symcon schreibend und per Modul auch Beschreibbar ist. Also in beide Richtungen Ereigniss Basierend kommuniziert so wie ich es schon seit einem halben Jahr Produktiv mit diversen Arduinos und ESP8266 (PubSub Library) einsetze. | Diese Anleitung zeigt wie man auf einem Raspberry PI 3 das MQTT Protokoll über Mosquitto und mqttwarn in Symcon schreibend und per Modul auch Beschreibbar ist. Also in beide Richtungen Ereigniss Basierend kommuniziert so wie ich es schon seit einem halben Jahr Produktiv mit diversen Arduinos und ESP8266 (PubSub Library) einsetze. | ||
Zeile 8: | Zeile 13: | ||
**Auch müssen alle Werte in < | **Auch müssen alle Werte in < | ||
</ | </ | ||
+ | |||
===== Grund Installation am PI Einrichten ===== | ===== Grund Installation am PI Einrichten ===== | ||
Zeile 35: | Zeile 41: | ||
===== Pakete Installieren ===== | ===== Pakete Installieren ===== | ||
- | + | Einen MQTT Broker | |
- | ==== Mosquitto (MQTT Broker) ==== | + | aptitude install mosquitto |
- | aptitude install mosquitto | + | |
| | ||
- | ==== mqttwarn (mqtt daemon der alle Ereignisse zu Symcon | + | ===== Symcon |
- | [[https:// | + | |
- | Abhängige Pakete Installieren: | + | |
- | pip install paho-mqtt | + | |
- | Verzeichniss erstellen | + | |
- | cd /opt/ | + | |
- | Herunterladen mit: | + | |
- | git clone https:// | + | |
- | cd mqttwarn | + | |
- | chmod +x mqttwarn.py | + | |
- | cp qttwarn.ini.sample mqttwarn.ini | + | |
- | Derinhalt der mqttwarn.ini sollte so aussehen: | + | |
- | < | + | |
- | # mqttwarn example configuration file " | + | |
- | [defaults] | + | ==== MQTT Client zum Senden in Symcon Installieren ==== |
- | hostname | + | Zum Senden von Daten per MQTT_Publish aus jedem script: |
- | port = 1883 | + | https:// |
- | username | + | |
- | password | + | |
- | clientid | + | |
- | lwt | + | |
- | skipretained | + | |
- | cleansession = True | + | |
- | protocol | ||
- | ; logging | + | ==== Mosquitto an Symcon Anbinden ==== |
- | logformat | + | |
- | logfile | + | |
- | ; one of: CRITICAL, DEBUG, ERROR, INFO, WARN | + | Eine Kategorie anlegen |
- | loglevel | + | |
- | # | + | |
+ | In diesem Knoten werden dann alle Geräte und Datenpunkte Automatisch erstellt / Aktualisiert, | ||
+ | Datenpunkte/ | ||
+ | und erstellen das Script " | ||
- | ; path to file containing self-defined functions for formatmap and datamap | + | Die Datei: |
- | ; omit the ' | + | |
- | functions = ' | + | |
- | ; name the service providers you will be using. | + | mit folgendem Inhalt: |
- | launch | + | <code php><? |
+ | $d = false; $msg = ""; | ||
+ | $value = ""; | ||
+ | if ($d){ $msg .= " | ||
+ | //if (($_IPS[' | ||
+ | if ($_IPS[' | ||
+ | $value | ||
+ | if ($value == $_IPS[' | ||
+ | $msg .= " | ||
+ | $run = false; | ||
+ | } | ||
+ | } | ||
+ | if (($_IPS[' | ||
+ | | ||
+ | } | ||
+ | if ($d){ $msg .= " | ||
+ | $id = $_IPS[' | ||
+ | $topic = explode(";" | ||
+ | if((strlen($topic) > 3) and ($run)){ | ||
+ | switch(IPS_GetVariable($id)[' | ||
+ | case 0: //boolean | ||
+ | if($value == 1){ $value = " | ||
+ | break; | ||
+ | case 1: //Integer | ||
- | [config: | + | |
- | append_newline = True | + | case 2: //float |
- | targets = { | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | [config: | + | |
- | targets = { | + | case 3: //string |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | [config: | + | |
- | timeout = 60 | + | } |
- | targets = { | + | |
- | # | + | |
- | ' | + | } |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | ; special config for ' | + | if ($d){ $msg .= " |
- | [failover] | + | |
- | targets = log:error, file: | + | if(strlen($msg) > 0){ |
+ | | ||
+ | } | ||
- | [devices/# | + | ?> |
- | targets = http: | + | |
- | template = ipsrpc.json | + | |
</ | </ | ||
- | <WRAP center round info 100%> | ||
- | der letzte Abschnitt [devices/#] bedeutet das alle daten im MQTT Broker (mosquitto) unter devices/* an IPS übergeben werden! | ||
- | </ | ||
+ | Das Eigentliche Script welces die Daten per RPC vom mqttwarn Daemon entgegennimmt und ablegt, in dem nicht Vergessen die ID's in den ersten Zeilen durch die Eigenen ersetzen: | ||
- | dann noch das template | + | <code php> <? |
- | cd / | + | $d = true; $msg = ""; |
- | in form der Datei | + | |
- | vi ipsrpc.json | + | |
- | mit folgendem Inhalt erstellen: | + | |
- | < | + | |
- | set data = { | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | ' | + | |
- | } | + | |
- | %} | + | |
- | {{ data | jsonify }}</ | + | |
- | + | ||
- | === Supervisor === | + | |
- | Damit mqttwarn als Dienst ausgeführt wird verwende ich supervisor wie [[http:// | + | |
- | aptitude install supervisor | + | |
- | in dem Ornder | + | |
- | cd / | + | |
- | die Datei mqttwarn.conf anlegen | + | |
- | vi mqttwarn.conf | + | |
- | mit folgendem Inhalt | + | |
- | < | + | |
- | directory = / | + | |
- | command = / | + | |
- | user = root | + | |
- | environment= MQTTWARNINI="/ | + | |
- | + | ||
- | Nun kann mqttwarn gestartet werden mit: | + | |
- | service supervisor start | + | |
- | und z.B. in einem zweiten Terminal Fenster die Log Datei beobachtet werden: | + | |
- | tail -f / | + | |
- | was so aussehen sollte: | + | |
- | < | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | 2016-11-30 21: | + | |
- | + | ||
- | ===== Symcon ===== | + | |
- | Nach der Installation von IPS dort in einer Kategorie z.b. Datenpunlte/ | + | |
- | <code php><? | + | |
- | $d = false; $msg = ""; | + | |
//sample value: devices/ | //sample value: devices/ | ||
// mqtt topic to symcon variable id mapping | // mqtt topic to symcon variable id mapping | ||
$idParent = IPS_GetParent($_IPS[' | $idParent = IPS_GetParent($_IPS[' | ||
- | $archiveId = <archiv id> | + | $archiveId = 32289 / |
- | $relaisScriptId = <id des Relais scripts> | + | $relaisScriptId = 17676 / |
// get value from mqtt variable | // get value from mqtt variable | ||
- | $var = $_IPS[' | + | if( array_key_exists(" |
- | $varsplit | + | |
+ | $topic = $_IPS[' | ||
+ | $topics | ||
+ | $payload = $_IPS[' | ||
- | if(count($varsplit)> | ||
- | $topics = explode("/", | ||
- | $topic=$varsplit[0]; | ||
- | $payload=$varsplit[1]; | ||
$payload = str_replace(array(" | $payload = str_replace(array(" | ||
Zeile 209: | Zeile 155: | ||
for($i = 0; $i < count($topics); | for($i = 0; $i < count($topics); | ||
if ($i == (count($topics) -1)){ | if ($i == (count($topics) -1)){ | ||
- | $type = 2; | + | $type = 2; |
} else { | } else { | ||
$type = 0; | $type = 0; | ||
Zeile 221: | Zeile 167: | ||
} | } | ||
- | // | ||
IPS_SetIdent($idf, | IPS_SetIdent($idf, | ||
- | //Wert Setzen | ||
mqset($idf, | mqset($idf, | ||
- | |||
} | } | ||
- | if (strlen($msg) > 0){ | + | if ((strlen($msg) > 0) and ($d)){ |
| | ||
print $msg; | print $msg; | ||
- | } else { | + | } |
- | IPS_LogMessage(" | + | IPS_LogMessage(" |
- | } | + | |
} | } | ||
Zeile 243: | Zeile 185: | ||
function mqset($id, $value){ | function mqset($id, $value){ | ||
- | switch(IPS_GetVariable($id)[" | + | if(GetValue($id) != $value){ |
- | case 0: // boolean | + | switch(IPS_GetVariable($id)[" |
- | $val = filter_var($value, | + | case 0: // boolean |
- | SetValue($id, | + | $val = filter_var($value, |
- | break; | + | SetValue($id, |
- | case 1: // integer | + | break; |
- | $val = intval($value); | + | case 1: // integer |
- | SetValue($id, | + | $val = intval($value); |
- | break; | + | SetValue($id, |
- | case 2: // float | + | break; |
- | $val = floatval($value); | + | case 2: // float |
- | SetValue($id, | + | $val = floatval($value); |
- | break; | + | SetValue($id, |
- | case 3: // string | + | break; |
- | SetValue($id, | + | case 3: // string |
- | break; | + | SetValue($id, |
+ | break; | ||
+ | } | ||
} | } | ||
} | } | ||
Zeile 351: | Zeile 295: | ||
} | } | ||
?></ | ?></ | ||
+ | ==== Mosquitto (MQTT Broker) ==== | ||
+ | aptitude install mosquitto mosquitto-clients python-pip git -y | ||
+ | | ||
+ | ==== mqttwarn (mqtt daemon der alle Ereignisse zu Symcon weiterleitet) ==== | ||
+ | [[https:// | ||
+ | Abhängige Pakete Installieren: | ||
+ | pip install paho-mqtt jinja2 | ||
+ | Verzeichniss erstellen | ||
+ | cd /opt/ | ||
+ | Herunterladen mit: | ||
+ | git clone https:// | ||
+ | cd mqttwarn | ||
+ | chmod +x mqttwarn.py | ||
+ | cp mqttwarn.ini.sample mqttwarn.ini | ||
+ | Derinhalt der mqttwarn.ini sollte so aussehen: | ||
+ | < | ||
+ | # mqttwarn example configuration file " | ||
- | hier noch das switch Script damit sind " | + | [defaults] |
+ | hostname | ||
+ | port = 1883 | ||
+ | username | ||
+ | password | ||
+ | clientid | ||
+ | lwt = ' | ||
+ | skipretained = False | ||
+ | cleansession = True | ||
- | <code php><? | + | protocol |
- | $d = false; $msg = ""; | + | |
- | $value = ""; | + | |
- | if ($d){ $msg .= " | + | |
- | //if (($_IPS[' | + | |
- | if ($_IPS[' | + | |
- | | + | |
- | if ($value == $_IPS[' | + | |
- | $msg .= " | + | |
- | $run = false; | + | |
- | } | + | |
- | } | + | |
- | if (($_IPS[' | + | |
- | | + | |
- | } | + | |
- | if ($d){ $msg .= " | + | |
- | $id = $_IPS[' | + | |
- | $topic = explode(";", | + | |
- | if((strlen($topic) > 3) and ($run)){ | + | |
- | switch(IPS_GetVariable($id)[' | + | |
- | case 0: //boolean | + | |
- | if($value == 1){ $value = " | + | |
- | break; | + | |
- | case 1: //Integer | + | |
- | break; | + | ; logging |
- | case 2: //float | + | logformat = ' |
+ | logfile | ||
- | break; | + | ; one of: CRITICAL, DEBUG, ERROR, INFO, WARN |
- | case 3: //string | + | loglevel |
+ | # | ||
- | break; | + | ; path to file containing self-defined functions for formatmap and datamap |
- | } | + | ; omit the ' |
- | | + | functions |
- | MQTT_Publish(50729 / | + | |
- | } | + | |
- | if ($d){ $msg .= " | + | ; name the service providers you will be using. |
- | + | launch | |
- | if(strlen($msg) > 0){ | + | |
- | IPS_LogMessage("mqtt_switch_relais", | + | [config: |
- | } | + | append_newline = True |
+ | targets = { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | |||
+ | [config: | ||
+ | targets | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | |||
+ | [config: | ||
+ | timeout = 60 | ||
+ | targets = { | ||
+ | # | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | | ||
+ | |||
+ | ; special config for ' | ||
+ | [failover] | ||
+ | targets = log:error, file: | ||
+ | |||
+ | [devices/# | ||
+ | targets = log:info, http: | ||
+ | template = ipsrpc.json | ||
+ | </ | ||
+ | |||
+ | <WRAP center round info 100%> | ||
+ | der letzte Abschnitt [devices/#] bedeutet das alle daten im MQTT Broker | ||
+ | </ | ||
+ | |||
+ | |||
+ | dann noch das template | ||
+ | cd / | ||
+ | in form der Datei | ||
+ | vi ipsrpc.json | ||
+ | mit folgendem Inhalt erstellen: | ||
+ | <code>{% set data = { | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | ' | ||
+ | } | ||
+ | %} | ||
+ | {{ data | jsonify }}</ | ||
+ | |||
+ | === Supervisor === | ||
+ | Damit mqttwarn als Dienst ausgeführt wird verwende ich supervisor wie [[http:// | ||
+ | aptitude install supervisor | ||
+ | in dem Ornder | ||
+ | cd / | ||
+ | die Datei mqttwarn.conf anlegen | ||
+ | vi mqttwarn.conf | ||
+ | mit folgendem Inhalt | ||
+ | < | ||
+ | directory = / | ||
+ | command = / | ||
+ | user = root | ||
+ | environment= MQTTWARNINI="/ | ||
+ | |||
+ | Nun kann mqttwarn gestartet werden mit: | ||
+ | service supervisor start | ||
+ | und z.B. in einem zweiten Terminal Fenster die Log Datei beobachtet werden: | ||
+ | tail -f / | ||
+ | was so aussehen sollte: | ||
+ | < | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
+ | 2016-11-30 21: | ||
- | ?></ | ||