Si quieres hacer experimentos con IOT o simplemente quieres automatizar tu hogar o laboratorio esta es tu guía! En esta guía te explicaré como instalar de cero un sistema headless en tu Raspberry Pi, Mosquitto un broker MQTT y Node Red un auténtico pegamento de tecnologías. Empezamos!
Necesitarás una Raspberry Pi, da igual el modelo con tal de que tengas una manera de conectarlo a tu red.
Para que nuestro sistema sea lo más estable posible, lo vamos a conectar mediante cable ethernet. Si quieres conectarlo por wifi hay infinidad de tutoriales en internet.
Aunque orientaremos la guía a Raspberry puedes utilizar otro sistema embebido con pequeños cambios.
Vamos a utilizar una versión lite (o reducida) de raspbian para este proyecto, ya que vamos a utilizar la raspi en modo headless, es decir sin utilizar monitor, ratón o demás periféricos.
Esta elección es debida a que la utilizaremos como un servidor, la conectaremos a nuestra red y siempre que trabajemos con ella lo haremos de manera remota desde otro ordenador conectado a la misma red.
A partir de ahora siempre nos comunicaremos con la raspi mediante ssh o posteriormente la interfaz de programación de NodeRed. Pero para poder conectarnos a ella primero debemos encontrarla en nuestra red!
Hay múltiples opciones para encontrar que IP le ha asignado nuestro router. Podemos conectarnos a nuestro router y buscar que dispositivos están conectados o hacer un escaneo de IPs en nuestra red. pero os voy a recomendar una fantástica herramienta open source de Adafruit. El Pi Finder te permite detectar raspis en tu red y hasta conectarte por ssh. Súper recomendable si no quieres complicarte.
Para conectarnos por ssh tenemos varias opciones.
La más sencilla es utilizar el Pi Finder del anterior apartado, utilizaremos el usuario “pi” y la contraseña por defecto “raspberry” y presionamos el botonaco “Terminal”
Si tu sistema operativo es windows puedes utilizar Putty
Si en cambio usas linux o macOS entra en la terminal y utiliza (sustituyendo las X por la IP de tu raspi):
ssh pi@XXX.XXX.XXX.XXX
Una vez ya conseguimos estar dentro de la raspi, vamos a configurarla. Haremos los cambios necesarios para que todo funcione correctamente.
Debido a que vamos a instalar un broker de MQTT y que posteriormente conectaremos nuestros dispositivos IOT a dicho broker vamos a configurar una ip fija a nuestra raspi. Mira en que rango de IPs tiene tu red, puede ser de la forma 192.168.0.XX. Elige una IP que esté libre en tu red y que te sea fácil de recordar (el rango suele ir de 0 a 255). Yo utilizaré por ejemplo la 192.168.0.210.
sudo nano /etc/dhcpcd.conf
interface eth0 static ip_address=XXX.XXX.XXX.XXX/24 static routers=192.168.0.1 static domain_name_servers=192.168.0.1
sudo reboot
ssh pi@192.168.0.XXX
Ahora utilizaremos este comando para configurar varios aspectos de la raspi.
sudo raspi-config
Aunque descargamos la última versión de la web, habrá actualizaciones intermedias del sistema, vamos a asegurarnos que tenemos todo con la última versión.
sudo apt-get update
sudo apt-get upgrade
Por seguridad evitaremos utilizar el usuario pi por lo que crearemos un nuevo usuario con un nuevo password.
sudo rm /etc/ssh/ssh_host* sudo ssh-keygen -A sudo adduser USERNAME sudo adduser USERNAME sudo sudo reboot
ssh USERNAME@192.168.0.XXX
<note tip>Como hemos cambiado las claves de ssh en el anterior paso, el ordenador lo detectará y a lo mejor tienes que eliminar la clave antigua en un fichero de tu sistema. En mac se soluciona poniendo en la terminal “nano /Users/TUUSUARIO/.ssh/known_hosts” y eliminando la linea de la ip de tu raspi</note>
sudo deluser --remove-home pi
Las raspis hacen un uso intensivo de las memorias sd por lo que suele pasar que al poco tiempo se suelen estropear. Por ello utilizaremos el sistema TMPFS que utiliza la memoria ram para evitar este problema.
sudo nano /etc/fstab
tmpfs /tmp tmpfs defaults,noatime,nosuid,size=30m 0 0 tmpfs /var/tmp tmpfs defaults,noatime,nosuid,size=30m 0 0 tmpfs /var/log tmpfs defaults,noatime,nosuid,mode=0755,size=30m 0 0 tmpfs /var/spool/mqueue tmpfs defaults,noatime,nosuid,mode=0700,gid=1001,size=30m 0 0
MQTT es un protocolo de comunicación de mensajes entre máquinas muy adecuado para IOT. Funciona con un sistema de publicación/suscripción. De manera muy simplificada los dispositivos publican en la red su información y a los que les interese escuchar esa información se pueden suscribir para poder recibirla. Tiene características muy interesantes como el QoS o calidad de servicio o la posibilidad de que los dispositivos dejen un “testamento” que se activa cuando desaparecen de la red. No me lío más y vamos a instalar Mosquitto, un broker de MQTT que se encargará de este tipo de mensajes en nuestra red.
sudo apt-get install mosquitto mosquitto-clients
Vamos a crear un usuario y password para Mosquitto.
cd /etc/mosquitto/
sudo mosquitto_passwd -c passwordfile USERNAME
sudo mosquitto_passwd -b passwordfile USERNAME
sudo mosquitto_passwd -D passwordfile USERNAME
sudo nano mosquitto.conf
allow_anonymous false password_file /etc/mosquitto/passwordfile
sudo systemctl stop mosquitto sudo update-rc.d mosquitto remove sudo rm /etc/init.d/mosquitto
sudo nano /etc/systemd/system/mosquitto.service
[Unit] Description=Mosquitto MQTT Broker daemon ConditionPathExists=/etc/mosquitto/mosquitto.conf AfteR=network.target Requires=network.target [Service] Type=simple ExecStart=/usr/sbin/mosquitto -c /etc/mosquitto/mosquitto.conf Restart=always [Install] WantedBy=multi-user.target
sudo systemctl daemon-reload sudo systemctl enable mosquitto sudo systemctl start mosquitto.service
Ahora instalaremos Node Red, con este auténtico pegamento de tecnologías podremos editar el comportamiento de nuestro sistema de una manera muy sencilla e intuitiva. La interfaz de Node Red es una página web que te servirá la raspi y desde donde puedes realizar toda la gestión y programación de tu sistema.
Realizar la instalación de Node Red y todas las aplicaciones que necesita para funcionar es muy sencillo gracias a un script que se encarga de todo, sólo hay que lanzar:
bash <(curl -sL https://raw.githubusercontent.com/node-red/raspbian-deb-package/master/resources/update-nodejs-and-nodered)
Versión actualizada (marzo 2020):
bash <(curl -sL https://raw.githubusercontent.com/node-red/linux-installers/master/deb/update-nodejs-and-nodered)
Node red por defecto no necesita usuario y contraseña, pero es muy importante por seguridad, por lo que instalaremos un complemento para que sólo se pueda entrar después de autentificarse. Además utilizaremos https para que cuando trabajemos con nuestra interfaz de Node Red, toda la información viaje por nuestra red interna de manera cifrada.
cd ~/.node-red
sudo npm install -g node-red-admin
<note tip>Puede que te salgan errores durante este paso, pero es normal y debería funcionar todo igual </note>
node-red-admin hash-pw
cd ~/.node-red/ openssl genrsa -out privatekey.pem 1024 openssl req -new -key privatekey.pem -out private-csr.pem openssl x509 -req -days 365 -in private-csr.pem -signkey privatekey.pem -out certificate.pem
node-red
nano settings.js
var fs = require("fs");
adminAuth: { type: "credentials", users: [{ username: "user", password: "COPIED HASH", permissions: "*" }] },
https: { key: fs.readFileSync('/home/USERNAME/.node-red/privatekey.pem'), cert: fs.readFileSync('/home/USERNAME/.node-red/certificate.pem') },
node-red
Casi todos los tutoriales recomiendan utilizar systemctl para iniciar Node Red, pero yo he tenido bastantes problemas por lo que recomiendo probar con PM2. Sólo tienes que ejecutar los siguientes comandos
sudo systemctl disable nodered.service sudo npm install -g pm2 pm2 start node-red pm2 save pm2 startup
Ya está! Ya puedes comenzar a cacharrear con Node Red y MQTT, hay muchos tutoriales por internet para hacer cosas chulísimas. En esta página podras encontrar tanto “Flows” o flujos como complementos que puedes instalar en tu Node Red, la visitarás muy a menudo! https://flows.nodered.org
Por último te puedo recomendar un chat de Telegram sobre Node Red en castellano : https://t.me/nodered
A disfrutarlo!