UCL-IIOT - Système d'alarme avec base de données et Node-red : 7 étapes
UCL-IIOT - Système d'alarme avec base de données et Node-red : 7 étapes
Anonim
UCL-IIOT - Système d'alarme avec base de données et Node-red
UCL-IIOT - Système d'alarme avec base de données et Node-red
UCL-IIOT - Système d'alarme avec base de données et Node-red
UCL-IIOT - Système d'alarme avec base de données et Node-red

Le but de cette version est d'enseigner la connexion d'Arduino avec Node-red et une base de données, afin que vous puissiez enregistrer des données et également les collecter pour une utilisation ultérieure.

Pour cette version, j'utilise un simple système d'alarme arduino qui génère 5 numéros de données, chacun séparé par une virgule.

Il n'est pas nécessaire d'avoir cette quantité exacte de données et le programme peut être n'importe quoi.

La partie importante est que les données sont séparées par des virgules comme on le voit sur cette capture d'écran.

La sortie pourrait par exemple ressembler à ceci: "324, 0, 0, 1, 1"

(la programmation terminée et les instructions pour la création de l'arduino sont liées au bas de ce tutoriel)

Étape 1: Premiers pas avec Node-red

Premiers pas avec Node-red
Premiers pas avec Node-red

Pour ce didacticiel, nous supposons que vous avez déjà installé Node-red, mais il existe des palettes supplémentaires utilisées pour ce projet dont nous avons besoin pour que cela fonctionne.

Recherchez le bouton "Gérer la palette" et installez les palettes suivantes.

  • node-red-tableau de bord
  • nœud-rouge-nœud-mysql
  • nœud-rouge-nœud-arduino
  • node-red-node-serialport

Il devrait afficher de nouvelles palettes sur le côté du menu du bouton Node-red.

Étape 2: Fractionnement des données dans Node-red

Fractionnement des données dans Node-red
Fractionnement des données dans Node-red

Maintenant que Node-red est prêt à fonctionner, nous devons commencer par diviser nos données en morceaux séparés.

C'est pourquoi nous nous sommes assurés de les séparer par des virgules à l'intérieur du code Arduino.

Commençons d'abord par déposer le nœud d'entrée Arduino, situé sur le panneau latéral gauche.

Vous devez vous assurer qu'il a le bon port série (Mine utilise COM4) et le débit en bauds (dans mon programme, j'utilise un débit en bauds de 9600)

S'il est correctement configuré, il doit indiquer qu'il est connecté.

Ensuite, nous créons un bloc fonctionnel Javascript et le connectons après le nœud d'entrée Arduino. Ce bloc nous permet de programmer en Javascript, et ici nous écrivons un code qui peut diviser nos données pour chaque virgule.

Dans ce bloc fonctionnel, j'ai divisé mes 5 données à l'aide du code suivant:

var m1 = {sujet: "light1", charge utile: msg.payload.split(", ")[0]}; var m2 = {sujet: "light2", charge utile: msg.payload.split(", ")[1]}; var m3 = {sujet: "light3", charge utile: msg.payload.split(", ")[2]}; var m4 = {sujet: "millis", charge utile: msg.payload.split(", ")[3]}; var m5 = {sujet: "onoff", charge utile: msg.payload.split(", ")[4]}; retour [m1, m2, m3, m4, m5];

(changer le code si nécessaire)

Assurez-vous que le nœud est défini sur 5 sorties (ou votre équivalent)

Comme le montre la capture d'écran, nous avons maintenant 5 sorties que nous relions chacune à un nœud de débogage et à un nœud de tableau de bord de texte. Cela sera utile lorsque nous aurons besoin de le voir sur l'interface utilisateur.

Étape 3: Base de données avec Wampserver

Base de données avec Wampserver
Base de données avec Wampserver

Pour que notre base de données fonctionne, vous devez avoir installé Wampserver. Une fois qu'il est installé et s'affiche sous la forme d'une icône verte (après avoir démarré tous les services), vous devez ouvrir le "phpMyAdmin" qui devrait vous amener à un écran de connexion. Sauf si vous l'avez précédemment modifié, entrez simplement "root" dans le nom d'utilisateur et connectez-vous.

Appuyez sur le bouton phpmyadmin sous les outils dans la barre de gauche et cela devrait ouvrir le menu de la base de données, qui ressemble à celui montré dans l'image ci-dessus.

Créez une nouvelle base de données et nommez-la en rapport avec votre projet, la mienne s'appelle "alarmsystem" (ces noms seront sensibles à la casse)

Sous cette base de données, créez une nouvelle table et nommez-la, la mienne s'appelle "alarmdata"

il vous demandera si vous souhaitez utiliser "latin1_swedish_ci" et nous le gardons comme cela.

Maintenant, vous créez 6 tables (1 de plus que les données dont nous disposons)

La première table doit utiliser le type de données "longtext"

et le reste de l'ensemble de données utilise "mediumtext"

Assurez-vous de les nommer. (le premier jeu de données doit être nommé "time"

Étape 4: Base de données

Base de données
Base de données

L'ensemble de données Wampserver devrait ressembler à ceci.

(mais sans les données réelles, car nous n'y sommes pas encore parvenus)

Étape 5: Node-red vers Wampserver

Node-red vers Wampserver
Node-red vers Wampserver

Maintenant, nous voulons que les données que nous sortons de notre arduino soient transférées sur notre serveur Wamp.

Commencez par créer un autre bloc fonction Javascript et connectez-le à notre nœud d'entrée arduino.

Dans ce bloc de script, nous divisons à nouveau nos données, mais nous les insérons également dans notre base de données.

var data = msg.payload.split(", ");var Green1 = data[0]; var Green2 = données[1]; var Alarme = données[2]; var Millis = données[3]; var IsActive = données[4]; var out = "INSERT INTO alarmsystem.alarmdata (Time, Green1, Green2, Alarm, Millis, IsActive) VALUES('"+new Date().toISOString().slice(0, 19).replace('T', ' ')+"', '"+Vert1+"', '"+Vert2+"', '"+Alarme+"', '"+Millis+"', '"+IsActif+"')"; msg.topic = out; renvoyer le message;

Remarquez que j'ai saisi "INSERT INTO alarmsystem.alarmdata", c'est le nom que nous avons donné à notre base de données et à notre table, assurez-vous d'y inscrire le nom exact que vous avez donné à votre base de données.

Connectez maintenant le bloc Javascript à un nœud de débogage ainsi qu'à un nœud "mysql" situé sous la palette de stockage sur le côté gauche.

sous le bloc mysql, vous le nommez de la même manière que votre base de données "alarmsystem"

changer l'utilisateur en "root" (le nom que nous avons utilisé pour nous connecter à notre serveur)

l'hôte, le port et la base de données doivent déjà être remplis avec:

Hôte: 127.0.0.1

Port: 3306

Base de données: système d'alarme

Si tout est fait correctement, il doit être connecté après le déploiement de vos modifications.

Vous devriez également pouvoir voir que la base de données enregistre maintenant vos données directement depuis l'Arduino.

Étape 6: Utilisation des données de Wampserver vers Node-red

Utilisation des données de Wampserver vers Node-red
Utilisation des données de Wampserver vers Node-red
Utilisation des données de Wampserver vers Node-red
Utilisation des données de Wampserver vers Node-red

Pour le dernier tronçon, nous voulons voir si nous pouvons prendre les données que nous avons enregistrées et les remettre dans notre Node-red et, espérons-le, les afficher.

Commencez par placer un nœud "inject"

Sous la rubrique dans ce nœud, nous mettons le code: SELECT*FROM alarmsystem.alarmdata

Celui-ci pourra trouver notre base de données lorsque nous appuierons dessus.

Connectez le nœud d'injection à un nouveau nœud "mysql" configuré exactement comme celui que nous avons fait à l'étape précédente.

Connectez le nœud mysql à un nœud de débogage et à un nœud de modèle trouvé sous le tableau de bord.

Le nœud de modèle sera notre table que nous pouvons mettre à jour pour afficher les données de la base de données au fur et à mesure de leur production.

Saisissez le code affiché dans la capture d'écran ci-dessus (modifiez-le si nécessaire) et il devrait maintenant afficher un tableau de données dans notre interface utilisateur Node-red.

Nous pouvons également ajouter un bouton de tableau de bord pour mettre à jour le tableau à partir de l'interface utilisateur elle-même.

Commencez par créer un nœud de bouton.

connecter le nœud de bouton à un bloc fonction Javascript.

dans le bloc fonction, nous insérons le code suivant.

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

(Green1 étant la première variable de données dans la table)

ce bloc fonction doit ensuite être connecté à l'entrée de notre nœud mysql que nous avons créé précédemment dans cette étape.

Étape 7: Finalisation

Finalisation
Finalisation

Maintenant, notre interface utilisateur devrait inclure une mise à jour en direct de nos données et un tableau avec les données de notre serveur lui-même.

Cela signifie que nous avons créé une connexion entre Arduino, un programme basé sur l'interface utilisateur et une base de données.

Si vous êtes intéressé par le fonctionnement de mon système d'alarme Arduino, j'ai ajouté un document qui explique comment il est programmé et configuré.

Ainsi qu'un export complet de la programmation node-red.

Conseillé: