UCL-IIOT: sistema d'alarma amb base de dades i vermell de node: 7 passos
UCL-IIOT: sistema d'alarma amb base de dades i vermell de node: 7 passos
Anonim
UCL-IIOT: sistema d’alarma amb base de dades i vermell de node
UCL-IIOT: sistema d’alarma amb base de dades i vermell de node
UCL-IIOT: sistema d'alarma amb base de dades i vermell de node
UCL-IIOT: sistema d'alarma amb base de dades i vermell de node

El propòsit d’aquesta compilació és ensenyar sobre la connexió d’Arduino amb Node-red i una base de dades, de manera que pugueu registrar dades i també recopilar-les per a un ús posterior.

Per a aquesta compilació faig servir un senzill sistema d’alarma arduino que genera 5 números de dades, cadascun separat amb una coma.

No cal tenir aquesta quantitat exacta de dades i el programa pot ser qualsevol cosa.

L’important és que les dades estan separades per comes tal com es veu en aquesta captura de pantalla.

La sortida, per exemple, podria ser així: "324, 0, 0, 1, 1"

(la programació acabada i les instruccions per a la creació de l'arduino estan enllaçades a la part inferior d'aquest tutorial)

Pas 1: Introducció a Node-red

Introducció a Node-red
Introducció a Node-red

Per a aquest tutorial suposem que ja heu instal·lat Node-red, però hi ha algunes paletes addicionals que s’utilitzen per a aquest projecte que necessitem perquè funcioni

Cerqueu el botó "Gestiona la paleta" i instal·leu les paletes següents.

  • node-red-dashboard
  • node-red-node-mysql
  • node-red-node-arduino
  • node-red-node-serialport

Hauria de mostrar algunes paletes noves al lateral del menú del botó vermell del node.

Pas 2: divisió de dades en vermell de node

Dividint dades en vermell de node
Dividint dades en vermell de node

Ara que Node-red està a punt, hem de començar dividint les nostres dades en trossos separats.

Per això, ens vam assegurar de separar-los amb comes dins del codi Arduino.

Primer comencem posant el node d'entrada Arduino, que es troba al tauler lateral esquerre.

Heu d’assegurar-vos que té el port sèrie correcte (el meu utilitza COM4) i la velocitat en bauds (al meu programa faig servir 9600 bauds)

Si està configurat correctament, hauria de dir que està connectat.

A continuació, creem un bloc de funció Javascript i el connectem després del node d’entrada Arduino, que ens permet programar en Javascript i aquí escrivim un codi que pot dividir les nostres dades per a cada coma.

En aquest bloc de funcions, divideixo les meves 5 dades mitjançant el codi següent:

var m1 = {topic: "light1", càrrega útil: msg.payload.split (",") [0]}; var m2 = {topic: "light2", càrrega útil: msg.payload.split (",") [1]}; var m3 = {topic: "light3", càrrega útil: msg.payload.split (",") [2]}; var m4 = {topic: "millis", càrrega útil: msg.payload.split (",") [3]}; var m5 = {topic: "onoff", càrrega útil: msg.payload.split (",") [4]}; retorn [m1, m2, m3, m4, m5];

(canvieu el codi segons calgui)

Assegureu-vos que el node estigui configurat en 5 sortides (o el vostre equivalent)

Com es veu a la captura de pantalla, ara tenim 5 sortides que enllacem cadascuna amb un node de depuració i un node de tauler de text. Això serà útil per quan ho hàgim de veure a la IU.

Pas 3: base de dades amb Wampserver

Base de dades amb Wampserver
Base de dades amb Wampserver

Perquè la nostra base de dades funcioni, cal que tingueu instal·lat Wampserver. Després d’instal·lar-la i mostrar-la com una icona verda (després d’haver iniciat tots els serveis), heu d’obrir el "phpMyAdmin" que us portarà a la pantalla d'inici de sessió. abans de canviar-lo, només cal que introduïu "root" al nom d'usuari i a l'inici de sessió.

Premeu el botó phpmyadmin que hi ha a sota de les eines de la barra esquerra i hauria d'obrir el menú de la base de dades, que s'assembla a la imatge superior.

Creeu una nova base de dades i bategeu-la amb alguna cosa relacionada amb el vostre projecte, la meva es diu "sistema d'alarma" (aquests noms diferenciaran entre majúscules i minúscules)

Sota aquesta base de dades, creeu una taula nova i anomeneu-la, la meva es diu "alarmdata"

us preguntarà si voleu utilitzar "latin1_sw Swedish_ci" i només el mantenim així.

Ara creeu 6 taules (1 més que les dades que tenim)

La primera taula ha d’utilitzar el tipus de dades "text llarg"

i la resta del conjunt de dades utilitza "text mitjà"

Assegureu-vos de posar-los un nom. (el primer conjunt de dades s'hauria de dir "hora"

Pas 4: base de dades

Base de dades
Base de dades

El conjunt de dades de Wampserver hauria de tenir un aspecte semblant.

(però sense les dades reals, ja que encara no hi hem arribat)

Pas 5: anoteu de vermell a Wampserver

Vermell de node a Wampserver
Vermell de node a Wampserver

Ara volem que les dades que proporcionem del nostre arduino vagin al nostre Wampserver.

Comenceu creant un altre bloc de funció Javascript i connecteu-lo al nostre node d’entrada arduino.

En aquest bloc de seqüències, tornem a dividir les nostres dades, però també les inserim a la nostra base de dades.

var data = msg.payload.split (","); var Green1 = data [0]; var Green2 = dades [1]; var Alarma = dades [2]; var Millis = dades [3]; var IsActive = dades [4]; var out = "INSERT INTO alarmsystem.alarmdata (Time, Green1, Green2, Alarm, Millis, IsActive) VALORS ('" + New Date (). toISOString (). slice (0, 19).replace (' T ',' ') + "', '" + Green1 + "', '" + Green2 + "', '" + Alarma + "', '" + Millis + "', '" + IsActive + "')"; msg.topic = fora; retorn msg;

Tingueu en compte que he introduït "INSERT INTO alarmsystem.alarmdata", aquest és el nom que hem donat a la nostra base de dades i taula, assegureu-vos que escriviu el nom exacte que vau donar a la vostra base de dades.

Ara connecteu el bloc Javascript a un node de depuració i també a un node "mysql" que es troba a la paleta d'emmagatzematge del costat esquerre.

sota el bloc MySQL, el nom és el mateix que la vostra base de dades "sistema d'alarma"

canvieu l'usuari per "root" (el nom que vam utilitzar per iniciar la sessió al nostre servidor)

l'amfitrió, el port i la base de dades ja s'han d'emplenar amb:

Amfitrió: 127.0.0.1

Port: 3306

Base de dades: sistema d’alarma

Si tot es fa correctament, s'hauria de connectar després de desplegar els canvis.

També hauríeu de poder veure que la base de dades ara registra directament les vostres dades des de l’Arduino.

Pas 6: utilitzar les dades des de Wampserver fins a vermell de node

Ús de dades des de Wampserver a vermell de node
Ús de dades des de Wampserver a vermell de node
Ús de dades des de Wampserver a vermell de node
Ús de dades des de Wampserver a vermell de node

Per a la recta final volem veure si podem agafar les dades que hem desat i tornar-les a posar al vermell del nostre node i, amb sort, mostrar-les.

Comenceu col·locant un node "injectar"

Sota el tema d’aquest node posem el codi: SELECT * FROM alarmsystem.alarmdata

Això serà capaç de trobar la nostra base de dades quan la premem.

Connecteu el node d'injecció a un nou node "mysql" configurat exactament igual que el que vam fer al pas anterior.

Connecteu el node mysql a un node de depuració i a un node de plantilla que es troba al tauler.

El node de plantilla serà la nostra taula que podem actualitzar per mostrar les dades de la base de dades a mesura que es produeixi.

Introduïu el codi que es mostra a la captura de pantalla anterior (canvieu si cal) i ara hauria de mostrar una taula de dades a la nostra interfície d’usuari vermella de node.

També podem afegir un botó de tauler per actualitzar la taula des de la pròpia interfície d’usuari.

Comenceu creant un node de botó.

connecteu el node de botó a un bloc de funció Javascript.

al bloc de funcions inserim el següent codi.

msg.topic = "SELECT * FROM alarmdata ORDER BY Green1 DESC LIMIT 20"; return msg;

(Green1 és la primera variable de dades de la taula)

aquest bloc de funcions ha d’estar connectat a l’entrada del nostre node mysql que hem fet anteriorment en aquest pas.

Pas 7: finalització

Finalitzant
Finalitzant

Ara la nostra interfície d’usuari hauria d’incloure una actualització en directe de les nostres dades i una taula amb dades del nostre propi servidor.

Això significa que hem creat una connexió entre Arduino, un programa basat en la interfície d’usuari i una base de dades.

Si us interessa saber com funciona el meu sistema d’alarma Arduino, he afegit un document que explica com es programa i es configura.

Així com una exportació completa de la programació en vermell del node.

Recomanat: