Table des matières:
- Étape 1: Configurer Raspberry Pi
- Étape 2: Configuration de MySQL sur Raspberry Pi
- Étape 3: Configuration des SensorBugs
- Étape 4: Installation du wrapper Python Bluetooth LE
- Étape 5: Scannez et trouvez l'adresse du SensorBug
- Étape 6: ajouter le script Python
- Étape 7: testez le script Python
- Étape 8: ajouter le script Python à la crontab
- Étape 9: Supplémentaire: Configurer le SensorBug pour la sortie de détection de position
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-23 14:46
Cette instructable explique comment mettre en place un système de surveillance de la température multi-nœuds avec le bogue du capteur Bluetooth LE de Blue Radios (BLEHome) et RaspberryPi 3BTgrâce au développement de la norme Bluetooth LE, il existe maintenant des capteurs sans fil basse consommation facilement disponibles sur le marché pour un coût très bas et peut fonctionner sur une seule pile bouton pendant des mois à la fois. L'un de ces capteurs que j'ai récupéré provient de Blue Radio, appelé Sensor Bugs. Coûtant environ 25 $ sur Amazon, il s'agit d'un appareil Bluetooth LE avec capteur de température, capteur de lumière et accéromètre, tous intégrés dans une petite unité qui peut communiquer sans fil. C'est un match parfait pour Raspberry Pi 3B, qui prend en charge la radio Bluetooth LE.
Étape 1: Configurer Raspberry Pi
La première étape consiste à obtenir une configuration Raspberry Pi fonctionnelle. Suivez les instructions du site Web de Raspberry Pi, chargez Raspbian sur une carte SD, insérez-le dans Raspberry Pi et démarrez-le. fuseau horaire au fuseau horaire actuel au lieu de UTC. Vous pouvez le faire via la commande: $ sudo dpkg-reconfigure tzdataLe reste de l'instruction suppose que la configuration est effectuée via l'interface de ligne de commande.
Étape 2: Configuration de MySQL sur Raspberry Pi
Il est utile d'avoir une base de données installée localement pour stocker toutes les données capturées. L'installation de MySQL sur Raspberry Pi est super facile. Il n'est pas non plus difficile de modifier le script pour se connecter à un serveur SQL en externe, vous pouvez sauter cette étape si vous souhaitez utiliser un serveur SQL sur le réseau. Il existe de nombreuses instructions sur le net, je vous suggère ceci:https:// www.stewright.me/2014/06/tutorial-install-…
Une fois le serveur SQL installé, vous pouvez utiliser le client MySQL CLI pour créer un utilisateur, une base de données et une table. Pour entrer dans MySQL CLI, utilisez la commande:
$ sudo mysql -uroot-pD'abord, créez un utilisateur local pour insérer les données capturées: > CREATE USER 'datasrc'@'localhost' IDENTIFYED BY 'datasrc000';Ensuite, créez une base de données et une table: > CREATE DATABASE SensorBug;Configuration de l'utilisateur permission: > ACCORDER TOUS LES PRIVILÈGES SUR SensorBug.* À 'datasrc'@'localhost';Ajoutez maintenant une nouvelle table à la base de données. Pour cet exemple, je vais ajouter un tableau avec les colonnes suivantes: DATE, HEURE, ADRESSE, LOCATION, TEMPERATURE et ACCEROMETRE
- DATE/HEURE - C'est la date et l'heure auxquelles les données sont enregistrées
- ADRESSE - Il s'agit du MAC du SensorBug à partir duquel le message est capturé
- EMPLACEMENT - Une chaîne lisible par l'homme pour indiquer où se trouve le capteur
- TEMPÉRATURE - C'est la température enregistrée
- ACCELE - C'est la valeur de la sortie de l'accéléromètre, utile pour enregistrer la position du capteur (si activé)
La commande qui fait cela est: > USE SensorBug; > CREATE TABLE data (date DATE, time TIME, address TINYTEXT, location TINYTEXT, temperature FLOAT, accele INT); Maintenant que la base de données est prête, nous pouvons passer à la configuration des sensorBugs.
Étape 3: Configuration des SensorBugs
Les bugs de capteur sont de petits appareils plutôt chouettes. Malheureusement, le fabricant n'a fourni que l'application IOS pour la programmation. Néanmoins, il est toujours possible de travailler avec si vous n'avez qu'un appareil Android. Première étape, couplez l'appareil avec un téléphone. Sans coupler l'appareil, le SensorBug ne publiera pas de données. J'ai essayé de voir si je pouvais le faire directement avec RaspberryPi, malheureusement, il semble que le pilote Bluetooth LE sur RaspberryPi soit encore expérimental et contienne des bogues pour l'empêcher de se coupler avec des appareils Bluetooth LE. La future version du pilote blueZ pourrait résoudre ce problème, mais à l'heure actuelle, il n'y a aucun moyen de coupler le SensorBug avec RaspberryPi. Heureusement, nous n'avons pas besoin de coupler l'appareil pour capturer ses données annoncées. La seule chose dont nous avons besoin est un téléphone pour configurer le SensorBug. Par défaut, le SensorBug commencera à publier les données de température à un intervalle de 1 s une fois qu'il sera associé à un appareil. Pour capturer les données de température, c'est tout ce qui est nécessaire. Si vous envisagez d'étendre pour utiliser le capteur de position ou de lumière, la configuration de l'appareil sera nécessaire. Pour commencer, nous allons coupler l'appareil et le déconnecter. Ce sera assez bon pour la capture de la température. Commencez par appuyer sur les deux boutons du SensorBug. Le voyant bleu/vert clignote, ce qui indique qu'il est sous tension. Appuyez sur l'un des boutons, la LED verte doit s'allumer, indiquer que l'appareil est sous tension. Si le voyant vert n'est pas allumé, appuyez sur les deux boutons pour essayer de rallumer l'appareil. Appuyez et maintenez enfoncé l'un des boutons jusqu'à ce que le voyant bleu commence à clignoter. Cela mettra l'appareil en mode paire. Allez dans le menu de configuration Bluetooth sur le téléphone et recherchez l'appareil SensorBug. Une fois qu'il apparaît, sélectionnez-le pour le coupler avec l'appareil. C'est tout, maintenant le SensorBug est alimenté et affiche les données de température
Étape 4: Installation du wrapper Python Bluetooth LE
Ensuite, nous devons installer la bibliothèque pour python pour parler à la pile Bluetooth LE. Les instructions peuvent être trouvées ici: https://github.com/IanHarvey/bluepyPour Python 2.7, il suffit de saisir les commandes suivantes:
$ sudo apt-get install python-pip libglib2.0-dev $ sudo pip install bluepy
Étape 5: Scannez et trouvez l'adresse du SensorBug
Pour connaître l'adresse MAC de SensorBug, utilisez cette commande: $ sudo hcitool lescan Vous devriez voir une sortie comme:
EC:FE:7E:10:B1:92 (inconnu) Si vous avez beaucoup d'appareils Bluetooth LE à proximité, il peut être difficile de savoir à qui vous parlez. Vous pouvez essayer bluetoothctl qui donne plus de détails:
$ sudo bluetoothctl[bluetooth]# scan on [NEW] Device EC:FE:7E:10:B1:92 SensorBug10B192 [CHG] Device EC:FE:7E:10:B1:92 ManufacturerData Key: 0x0085 [CHG] Device EC: FE:7E:10:B1:92 Valeur ManufacturerData: 0x02 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x00 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x3c [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x25 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x09 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x41 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x02 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x02 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x43 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x0b [CHG] Appareil EC:FE:7E:10:B1:92 ManufacturerData Valeur: 0x01 [CHG] Appareil EC:FE:7E:10:B1:92 Valeur ManufacturerData: 0x6f
Enregistrez l'adresse MAC, elle devra être entrée dans le script python pour filtrer les appareils Bluetooth LE indésirables
Étape 6: ajouter le script Python
Une copie du script Python est disponible sur:
drive.google.com/open?id=10vOeEAbS7mi_eXn_…
Voici le même fichier, attention à l'indentation lors de la copie:
Mettez également à jour l'adresse MAC dans le fichier python pour qu'elle corresponde à l'adresse du capteur obtenue à partir du résultat de l'analyse.
# Ce programme est un logiciel libre: vous pouvez le redistribuer et/ou modifier
# sous les termes de la licence publique générale GNU telle que publiée par
# la Free Software Foundation, soit la version 3 de la Licence, soit
# (à votre choix) toute version ultérieure.
#
# Ce programme est distribué dans l'espoir qu'il sera utile, # mais SANS AUCUNE GARANTIE; sans même la garantie implicite de
# COMMERCIALISATION ou ADÉQUATION À UN USAGE PARTICULIER. Voir le
# Licence publique générale GNU pour plus de détails.
#
# Vous devriez avoir reçu une copie de la licence publique générale GNU
# avec ce programme. Sinon, voir.
# bscan.py - Scanner et extracteur de données Bluetooth LE simple
à partir de bluepy.btle import Scanner, DefaultDelegate
heure d'importation
importer pymysql
structure d'importation
nom d'hôte = 'localhost'
nom d'utilisateur = 'datasrc'
mot de passe = 'datasrc000'
base de données = 'SensorBug'
#Entrez l'adresse MAC du capteur du lescan
SENSOR_ADDRESS = ["ec:fe:7e:10:b9:92", "ec:fe:7e:10:b9:93"]
SENSOR_LOCATION = ["Garage", "Extérieur"]
classe DecodeErrorException(Exception):
def _init_(self, valeur):
self.value = valeur
def _str_(self):
return repr(self.value)
classe ScanDelegate(DefaultDelegate):
def _init_(self):
DefaultDelegate._init_(self)
def handleDiscovery(self, dev, isNewDev, isNewData):
si estNouveauDev:
print "Périphérique découvert", dev.addr
elif isNewData:
print "Nouvelles données reçues de", dev.addr
def doQueryInsert (conn, addr, loc, temp, accero):
La table #blesensor est la date, l'heure, l'adresse, l'emplacement, la température, l'accéro
cur = conn.cursor()
dostr = 'INSÉRER DANS LES VALEURS DE données (CURRENT_DATE(), NOW(), %s, %s, %s, %s);'
cur.execute (dostr, (addr, loc, temp, accero))
conn.commit()
scanner = Scanner().withDelegate(ScanDelegate())
myConnection = pymysql.connect (host=hostname, user=username, passwd=password, db=database)
ManuDonnéesHex =
ReadLoop = True
essayer:
tandis que (ReadLoop):
appareils = scanner.scan(2.0)
ManuDonnées = ""
pour le développement dans les appareils:
entrée = 0
AccéroDonnées = 0
AccéroType = 0
DonnéesTemp = 0
pour saddr dans SENSOR_ADDRESS:
entrée += 1
if (dev.addr == saddr):
print "Périphérique %s (%s), RSSI=%d dB" % (dev.addr, dev.addrType, dev.rssi)
CurrentDevAddr = saddr
CurrentDevLoc = SENSOR_LOCATION[entry-1]
pour (type d'annonce, desc, valeur) dans dev.getScanData():
imprimer " %s = %s" % (desc, valeur)
if (desc == "Fabricant"):
ManuData = valeur
if (ManuData == ""):
print "Aucune donnée reçue, terminer le décodage"
Continuez
#print ManuData
pour i, j en zip (ManuData[::2], ManuData[1::2]):
ManuDataHex.append(int(i+j, 16))
#Commencer à décoder les données brutes du fabricant
si ((ManuDataHex[0] == 0x85) et (ManuDataHex[1] == 0x00)):
print "Octet d'en-tête 0x0085 trouvé"
autre:
print "Octet d'en-tête 0x0085 introuvable, arrêt du décodage"
Continuez
#Ignorer Majeur/Mineur
#Index 5 est 0x3c, indiquez le niveau de batterie et la configuration #
si (ManuDataHex[4] == 0x3c):
BatteryLevel = ManuDataHex[5]
ConfigCounter = ManuDataHex[6]
idx = 7
#print "TotalLen: " + str(len(ManuDataHex))
tandis que (idx < len(ManuDataHex)):
#print "Idx: " + str(idx)
#print "Données: " + hex(ManuDataHex[idx])
si (ManuDataHex[idx] == 0x41):
#Données d'accéromètre
idx += 1
AcceleroType = ManuDataHex[idx]
AcceleroData = ManuDataHex[idx+1]
idx += 2
elif (ManuDataHex[idx] == 0x43):
#Données de température
idx += 1
TempData = ManuDataHex[idx]
TempData += ManuDataHex[idx+1] * 0x100
TempData = TempData * 0,0625
idx += 2
autre:
idx += 1
print « Adresse du périphérique: » + CurrentDevAddr
print "Emplacement de l'appareil: " + CurrentDevLoc
print "Niveau de la batterie: " + str(BatteryLevel) + "%"
print "Config Counter: " + str(ConfigCounter)
print "Accelero Data: " + hex(AcceleroType) + " " + hex(AcceleroData)
print "Données Temp: " + str(DonnéesTemp)
doQueryInsert (myConnection, CurrentDevAddr, CurrentDevLoc, TempData, AcceleroData)
ReadLoop = Faux
sauf DecodeErrorException:
passe
Étape 7: testez le script Python
Le script doit être exécuté en root, donc:
$ sudo python bscan.pyDiscovered device ec:6e:7e:10:b1:92 Device ec:6e:7e:10:b1:92 (public), RSSI=-80 dB Flags = 06 Incomplet 16b Services = 0a18 Fabricant = 850002003c25094102024309016f Octet d'en-tête 0x0085 trouvé Adresse de l'appareil: ec:6e:7e:10:b1:92 Emplacement de l'appareil: Garage Niveau de batterie: 37% Compteur de configuration: 9 Données Accero: 0x2 Données de température 0x2: 16,5625
Étape 8: ajouter le script Python à la crontab
Le script python doit être exécuté à la racine, donc si vous souhaitez capturer les données automatiquement, il devra être ajouté à la crontab de la racine. Pour cet exemple, j'exécute le script toutes les 20 minutes Utilisez la commande:
$ sudo crontab -e
# Modifiez ce fichier pour introduire les tâches à exécuter par cron.
# # Chaque tâche à exécuter doit être définie sur une seule ligne # indiquant avec différents champs quand la tâche sera exécutée # et quelle commande exécuter pour la tâche # # Pour définir le temps, vous pouvez fournir des valeurs concrètes pour # minute (m), heure (h), jour du mois (dom), mois (mon), # et jour de la semaine (dow) ou utilisez '*' dans ces champs (pour 'any').# # Notez que les tâches seront démarrées basé sur la notion d'heure et de fuseaux horaires du système # du démon cron. # # La sortie des tâches crontab (y compris les erreurs) est envoyée par # e-mail à l'utilisateur auquel appartient le fichier crontab (sauf s'il est redirigé). # # Par exemple, vous pouvez exécuter une sauvegarde de tous vos comptes utilisateurs # à 5 heures du matin chaque semaine avec: # 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/ # # Pour plus d'informations consultez le pages de manuel de crontab(5) et cron(8) # # mh dom mon dow commande 0 * * * * python /home/pi/bscan.py 20 * * * * python /home/pi/bscan.py 40 * * * * python /home/pi/bscan.py
C'est ça. Le script python sera exécuté à intervalles réguliers et recodera la sortie dans la base de données SQL
Étape 9: Supplémentaire: Configurer le SensorBug pour la sortie de détection de position
Il est possible de configurer le SensorBug sur Android pour la sortie de détection de position. tandis que si l'appareil est debout, la valeur est 0x02Il ne différencie pas si la position X ou Y est en haut, tant que l'axe Z n'est pas en haut ou en bas. La façon la plus simple de le faire est d'utiliser l'application LightBlue. Le SensorBug devrait apparaître dans le menu de numérisation. Sélectionnez l'appareil que vous souhaitez configurer, accédez aux caractéristiques du GATT pour la configuration de l'accéléromètre UUID: 9DC84838-7619-4F09-A1CE-DDCF63225B11
Voir l'image: écrivez une nouvelle chaîne de configuration:
010d3f020200000002d00000002Lisez la chaîne de configuration pour confirmer l'écriture. Cela active l'accéléromètre pour la détection de position.
Conseillé:
Moniteur météorologique M5Stack M5stick C basé sur ESP32 avec DHT11 - Surveiller la température, l'humidité et l'indice de chaleur sur le M5stick-C avec DHT11 : 6 étapes
Moniteur météorologique M5Stack M5stick C basé sur ESP32 avec DHT11 | Surveiller l'indice d'humidité et de chaleur de la température sur M5stick-C avec DHT11 : Salut les gars, dans ces instructables, nous apprendrons comment interfacer le capteur de température DHT11 avec m5stick-C (une carte de développement par m5stack) et l'afficher sur l'écran de m5stick-C. Donc, dans ce tutoriel, nous allons lire la température, l'humidité & chauffer je
Surveiller la température de la pièce à la maison/au bureau sur votre bureau : 4 étapes
Surveiller la température ambiante de la maison/du bureau sur votre bureau : pour surveiller les pièces ou les bureaux ou tout autre endroit où nous pouvons utiliser ce projet et cela est affiché avec autant de détails comme un graphique, la température en temps réel et bien plus encore. Nous utilisons : https://thingsio.ai/ Tout d'abord, nous devons rendre compte sur cette plateforme IoT, un
Enregistrer une chanson sur un iPad : 11 étapes (avec photos)
Enregistrer une chanson sur un IPad : Une de mes amies m'a récemment demandé comment elle pouvait enregistrer certaines de ses chansons avec juste une guitare et un iPad. Je lui ai demandé si elle avait un autre matériel d'enregistrement tel qu'un microphone et une interface d'enregistrement. Malheureusement, la réponse était non, et elle n'est pas
ESP8266 : Comment surveiller la température et l'humidité : 12 étapes
ESP8266 : Comment surveiller la température et l'humidité : Dans le tutoriel d'aujourd'hui, nous utiliserons un ESP-01, qui est l'ESP8266 en configuration 01 (avec seulement 2 GPIO), pour les lectures de température et d'humidité du capteur DHT22. Je vais vous montrer un schéma électrique et la partie programmation ESP avec un Arduino
Le Projet Serre (RAS) : Surveiller les éléments pour réagir sur notre plantation : 18 étapes (avec photos)
Le Projet Serre (RAS) : Surveiller les éléments pour réagir sur notre plantation : Ce projet propose de surveiller la température, la luminosité et l'humidité de l'air, ainsi que la température et l'humidité du bosquet. Il propose aussi de mettre en réseau ces mesures qui sont si lisibles sur le site Actoborad.com Pour ce faire, nous connectons 4 capteurs au N