Reiniciar Domoticz si esta caído mediante Node Red

jondi del grupo «Domoticz a lo spain» de telegram nos explica cómo reinicia domoticz si esta caído utilizando un flow en nodered.

Dividimos esta guía en varios apartados

Requisitos inciales

Para poder seguir este tutorial es necesario tener instalado Node Red en nuestra Raspberry: «Cómo instalar node red en nuestra raspberry pi«.

Descarga del software necesario

Damos por hecho que ya tenemos el software necesario a consecuencia del seguimiento del tutorial anterior para instalar Node red.

Configuración en Node Red

Abrimos node red (Recuerda que accedemos a ella introduciendo la IP de nuestra raspberry seguido de :1880) y empezamos instalando un plugin. Sigue las indicaciones de las imágenes:

Buscamos el plugin a cargar en node red: node-red-contrib-telegrambot, y lo instalamos.

A continuación cargamos el flow que os adjuntamos de la siguiente manera:

Introducimos en el recuadro siguiente texto (lo copiamos con control +c) y lo pegamos en el recuadro (con control + v):

[{"id":"ba51a3b3.a0db18","type":"tab","label":"Domoticz STATUS","disabled":false,"info":""},{"id":"8b29fb32.348358","type":"inject","z":"ba51a3b3.a0db18","name":"Get Domoticz Status","topic":"","payload":"","payloadType":"date","repeat":"180","crontab":"","once":true,"onceDelay":"200","x":160,"y":100,"wires":[["ee923545.738458"]]},{"id":"ee923545.738458","type":"http request","z":"ba51a3b3.a0db18","name":"Get Domoticz Status","method":"GET","ret":"obj","paytoqs":false,"url":"http://192.168.1.1:8080/json.htm?type=command&param=getversion","tls":"","persist":false,"proxy":"","authType":"basic","x":160,"y":200,"wires":[["eae9168a.365158","afd4a18e.14f678"]]},{"id":"eae9168a.365158","type":"switch","z":"ba51a3b3.a0db18","name":"Check Domoticz Status","property":"payload.status","propertyType":"msg","rules":[{"t":"eq","v":"OK","vt":"str"},{"t":"else"}],"checkall":"false","repair":false,"outputs":2,"x":170,"y":320,"wires":[["a5680baa.0c42b8"],["9a8bbb89.1c2b1"]]},{"id":"9a8bbb89.1c2b1","type":"function","z":"ba51a3b3.a0db18","name":"Count","func":"// initialise the counter to 0 if it doesn't exist already\nvar count = flow.get('count')||0;\ncount += 1;\n// store the value back\nflow.set('count',count);\n// make it part of the outgoing msg object\nmsg.count = count;\nreturn msg;","outputs":1,"noerr":0,"x":410,"y":340,"wires":[["6d82074d.b95d48"]]},{"id":"a5680baa.0c42b8","type":"function","z":"ba51a3b3.a0db18","name":"Count Reset","func":"// Reset the counter\nvar count = 0;\nflow.set('count',count);\n// make it part of the outgoing msg object\nmsg.count = count;\nreturn msg;","outputs":1,"noerr":0,"x":430,"y":300,"wires":[[]]},{"id":"6d82074d.b95d48","type":"switch","z":"ba51a3b3.a0db18","name":"Count Evaluation","property":"count","propertyType":"msg","rules":[{"t":"gte","v":"2","vt":"num"}],"checkall":"true","repair":false,"outputs":1,"x":610,"y":340,"wires":[["a9b03480.1bff58"]]},{"id":"a9b03480.1bff58","type":"exec","z":"ba51a3b3.a0db18","command":"sudo /etc/init.d/domoticz.sh","addpay":false,"append":"stop","useSpawn":"false","timer":"30","oldrc":false,"name":"Domoticz stop","x":740,"y":160,"wires":[[],[],["f78be828.56c0c","86c2e0dd.5a1f68"]]},{"id":"f78be828.56c0c","type":"exec","z":"ba51a3b3.a0db18","command":"sudo /etc/init.d/domoticz.sh","addpay":false,"append":"start","useSpawn":"false","timer":"","oldrc":false,"name":"Domoticz start","x":960,"y":200,"wires":[[],["8d067a40.78351"],["8d067a40.78351"]]},{"id":"8d067a40.78351","type":"function","z":"ba51a3b3.a0db18","name":"Count Reset","func":"// Reset the counter\nvar count = 0;\nflow.set('count',count);\n// make it part of the outgoing msg object\nmsg.count = count;\nreturn msg;","outputs":1,"noerr":0,"x":1150,"y":220,"wires":[[]]},{"id":"86c2e0dd.5a1f68","type":"function","z":"ba51a3b3.a0db18","name":"REINICIA","func":"msg.payload = {chatId :-371823045, \n type : 'message',\n content : 'REINICIO DOMOTICZ RPI4' }\nreturn msg;","outputs":1,"noerr":0,"x":940,"y":140,"wires":[["dc4f4567.5d641"]]},{"id":"dc4f4567.5d641","type":"telegram sender","z":"ba51a3b3.a0db18","name":"TELEGRAM","bot":"a10f5e56.78d3","haserroroutput":false,"outputs":1,"x":1150,"y":60,"wires":[[]]},{"id":"afd4a18e.14f678","type":"debug","z":"ba51a3b3.a0db18","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"false","x":430,"y":120,"wires":[]},{"id":"a10f5e56.78d3","type":"telegram bot","z":"","botname":"","usernames":"","chatids":"","baseapiurl":"","updatemode":"polling","pollinterval":"300","usesocks":false,"sockshost":"","socksport":"6667","socksusername":"anonymous","sockspassword":"","bothost":"","botpath":"","localbotport":"8443","publicbotport":"8443","privatekey":"","certificate":"","useselfsignedcertificate":false,"sslterminated":false,"verboselogging":false}]

Y tras pegar el texto clicamos sobre IMPORT:

Veremos que se nos carga una pestaña nueva denominada Domoticz STATUS. Clicamos sobre ella:

Configuramos a nuestro gusto:

  • Datos de telegram.
  • IP y puerto de domoticz.
  • Y el mensaje a vuestro gusto.

Importante tener en cuenta...

Si el flow detecta que está caído domoticz y en realidad lo está actualizando, entonces se corrompe al levantar el flow el servicio.

Por ello, si actualizáis el sistema deshabilitar el flow hasta que termine la actualización.

Cómo localizar errores en node red

Os damos un truquito para vuestra información. Tenemos un node en el listado de la izquierda que se llama DEBUG. Cuando lo llevamos a la pantalla principal, lo conectamos a un node y lo activamos, nos dá mucha información (como un LOG) en la columna de la derecha del todo. Os explicamos con unas cuantas imágenes cómo conseguirlo:

Mantén el cursor pulsando la bola del final del recuadro del mqtt/in y arrástrala hasta la bola del inicio del recuadro del debug:

Clicamos sobre deploy:

Activamos la cucaracha y a la derecha nos aparecerá el debug con info de errores /( y así podremos analizar qué estamos haciendo mal) o info correcta:

Inicio automático de Node RED con Raspberry Pi

Recordar que por defecto Node RED está apagado. Podemos iniciarlo de dos formas diferentes: manual o automático.

Para inicio manual introducimos en puTTY:

node-red-start

Para que Node Red inicie de forma automática (tras caídas de red, o tras apagar y encender la raspberry) lanzamos el siguiente comando en puTTY:

sudo systemctl enable nodered.service

Para cualquier duda o consulta tienes disponible el grupo de telegram «Domoticz a lo Spain» para entrar, ponerte cómodo y participar cuanto quieras.

Clica aquí para entrar en él

Cualquier duda, sugerencia o comentario será bien recibida en la web!