![UCL - IIOT Kasvihuone: 11 vaihetta UCL - IIOT Kasvihuone: 11 vaihetta](https://i.howwhatproduce.com/images/004/image-9085-7-j.webp)
Sisällysluettelo:
2025 Kirjoittaja: John Day | [email protected]. Viimeksi muokattu: 2025-01-23 14:42
![UCL - IIOT Kasvihuone UCL - IIOT Kasvihuone](https://i.howwhatproduce.com/images/004/image-9085-8-j.webp)
Tämä projekti on jatkoa aikaisemmalle Greenhouse-hankkeellemme (https://www.instructables.com/id/EAL-EMBEDDED-GREE…).
Tässä projektissa lisäsimme tietokannan, johon kirjaamme kaikki tietomme ja visualisoimme ne sitten solmupunaisella saadaksesi paremman yleiskuvan.
Tietokantaamme kirjaama sisältö on maaperän kosteus, lämpötila ja kosteus, jotka näkyvät eri kaavioissa.
Datalogginin lisäksi voimme myös hallita, mikä profiili on aktiivinen kasvihuoneessa ja etäohjata sitä.
Sitten voimme myös ohjata pumppua ja tuuletinta manuaalisesti.
Vaihe 1: Asennusopas
![Asennusohje Asennusohje](https://i.howwhatproduce.com/images/004/image-9085-9-j.webp)
Ensimmäinen askel on asentaa kaikki eri komponentit.
Suluissa () on lueteltu, mihin komponentti on kytketty. Esimerkiksi Arduino on kytketty Raspberry Pi -laitteeseen USB -kaapelilla.
Käytetty laitteisto:
- Arduino (Vadelma Pi)
- Raspberry Pi 3 B+
- Maaperän kosteusmittari (Arduino)
- DHT11 -anturi (Arduino)
- HG-320 upotettava vesipumppu (rele)
- 5V rele (Arduino)
- Tietokoneen tuuletin (rele)
- 230V virtalähde (pumppu)
Käytetty ohjelmisto:
- Raspbian (käyttöjärjestelmä Raspberry Pi: lle)
- Arduino IDE
- Python (Raspberry Pi)- PySerial- MySQLclient
- Solmu-punainen (Raspberry Pi)- Pythonshell- Yhteenveto- MySQL- Kojelauta
- MySQL -palvelin (freemysqlhosting.net)
Ensin sinun on liitettävä laitteistokomponentit, joten rakenna kasvihuone noudattamalla tätä opasta: Asennusopas.
Sitten sinun on asennettava Raspbian OS Raspberry Pi -laitteeseesi. Tämän jälkeen sinun on asennettava Python ja asennettava sitten python -kirjastot.
Seuraava askel on asentaa Node-Red Raspberry Pi -laitteeseen ja siirtyä sitten palettienhallintaan ja asentaa aiemmin mainitut moduulit.
Siirry sitten tälle sivustolle Ilmainen MySQL -palvelin ja luo ilmainen MySQL -palvelin.
Kun kaikki tämä on tehty, olet valmis siirtämään python-komentosarjan Raspberry Pi -laitteeseesi, tuomaan Node-Red-komentosarjan ja lataamaan Arduinon koodin.
Vaihe 2: Hallinnan esittely
![Image Image](https://i.howwhatproduce.com/images/004/image-9085-11-j.webp)
![](https://i.ytimg.com/vi/eS538gYEkO0/hqdefault.jpg)
Vaihe 3: Projektissa käytettyjen osien/ohjelmistojen luettelo
Olemme käyttäneet kasvihuoneen valmistuksessa seuraavaa tekniikkaa
- Arduino
- Raspberry Pi
- Solmu-Punainen
- Python
- PHPMyAdmin
Vaihe 4: I/0 -luettelo
![Kytkentäkaavio Kytkentäkaavio](https://i.howwhatproduce.com/images/004/image-9085-12-j.webp)
Vaihe 5: Kytkentäkaavio
Vaihe 6: Arduino -koodi
Arduino -koodi toimii tulostamalla anturien mittaamat tiedot sarjaliitäntään, josta Raspberry Pi lukee ja siirtää tietokantaan.
Arduinolla on myös joitain digitaalisia sisääntulonappeja, jotka on liitetty Raspberry Pi -laitteeseen, jonka Arduino lukee ja jos kolmesta kolmesta tulee HIGH, profiili muuttuu IF -lausekkeen vuoksi.
Olemme myös päivittäneet koodin käyttämään Milliä viiveen sijasta, mikä mahdollistaa koodin päiden ja muun koodin lukemisen koko ajan vanhan viiveen sijaan.
Vaihe 7: Raspberry Pi 3 B+
![Raspberry Pi 3 B+ Raspberry Pi 3 B+](https://i.howwhatproduce.com/images/004/image-9085-13-j.webp)
Käytimme Raspberry Pi 3 B+ -laitetta Arduinon yhdistämiseen Internetiin ja MySQL -tietokantaan. Tämä mahdollisti sen, että voimme tallentaa antureidemme tietoja ja luoda visuaalisen käyttöliittymän loppukäyttäjälle. Käyttöliittymässä käytimme Node-Redia Dashboard-paletin kanssa.
Mutta ennen kuin voisimme näyttää anturitietomme solmupunaisella, tarvitsimme tavan ladata tiedot MySQL-tietokantaan, ja teimme sitä varten Python-komentosarjan, joka toimisi Raspberry Pi -laitteellamme.
Vaihe 8: Python
![Python Python](https://i.howwhatproduce.com/images/004/image-9085-14-j.webp)
Python-komentosarjaa käytetään tietojen vastaanottamiseen Arduinolta tulevasta sarjaliikenteestä. Sitten skripti lähettää tiedot MySQL -tietokantaan.
Käytimme kahta kirjastoa, pyserial ja mysqlclient.
Joten ensimmäinen askel olisi ladata nämä kaksi kirjastoa:
- PySerial
- MySQLclient
PySerialia käytetään tietojen keräämiseen Arduinosta sarjaliikenteen kautta.
device = '/dev/ttyUSB0'
arduino = sarja. sarja (laite, 9600)
Ensimmäistä riviä käytetään COM-porttimme määrittämiseen. Raspberry Pi -laitteessa se on /dev /ttyUSB0, jota käytämme Arduinossa. Toinen rivi on sarjaportin avaaminen Arduinolle. Määritämme vain, mikä COM-portti ja millä nopeudella yhteys toimii.
Loput koodista ovat käynnissä jonkin aikaa.
Seuraavaksi käytämme useita Try and Except -lohkoja. Ensin koodi yrittää ajaa Try -lohkon sisällä, jos se epäonnistuu, se suorittaa Except -lohkon. Mutta jos Kokeile -lohko toimii hyvin, se ei suorita Paitsi -lohkoa, se ajaa vain loput koodista.
Joten Try-lohkojen sisällä on koodi, joka lukee sarjaliikenteen ja lähettää sen sitten MySQL-tietokantaamme.
hygrolist = arduino.readlines (1)
templist = arduino.readlines (2) humidlist = arduino.readlines (3)
Yllä oleva koodi on siis sarjaliikenteen rivien lukemiseen. Koodin lopussa oleva numero määrittelee sarjassa luetun rivin. Joten nämä rivit luokitellaan eri muuttujiin.
Kun tiedot Arduinolta vastaanotetaan, käytimme mysqlclient -moduulia tietojen lähettämiseen MySQL -palvelimellemme.
db = _mysql.connect (isäntä = "sql7.freemysqlhosting.net", user = "sql7256552", passwd = "3ebtbP8FQ2", db = "sql7256552")
Tämä rivi on tarkoitettu yhteyden muodostamiseen MySQL -tietokantaamme. Se määrittää palvelimen, käyttäjätunnuksen, salasanan ja mihin tietokantaan se muodostaa yhteyden palvelimen sisällä. Tässä sinun on määritettävä yhteys MySQL -tietokantaasi.
db.query ("INSERTINTO` TempHumid "(` lämpötila ",` kostea`, `hygro`) ARVOT (%s, %s, %s)" %(lämpötila, kostea, hygro))
Joten tässä otamme DB -yhteyden ja teemme SQL -kyselyn. Kysely sanoo, että arvot on lisättävä taulukon "TempHumid" sisälle ja sitten sarakkeisiin "temp", "humid" ja "hygro". Viimeinen osa "(%s, %s, %s)" on merkkijonomuotoilu ja sitä käytetään antamaan tietokannalle muoto, jonka se voi lukea.
Ja kaikki tämä toiminto on sijoitettu hetken silmukkaan, jotta saamme jatkuvasti tietoja MySQL -palvelimelle.
Jos haluat nähdä koko koodin, lataa python -komentosarja (TempHumid.py).
Vaihe 9: MySQL
![MySQL MySQL](https://i.howwhatproduce.com/images/004/image-9085-15-j.webp)
![MySQL MySQL](https://i.howwhatproduce.com/images/004/image-9085-16-j.webp)
MySQL -palvelimelle käytimme ilmaista palvelua osoitteessa www.freemysqlhosting.net. Olisimme voineet tehdä palvelimen paikallisesti Raspberry Pi: llä, mutta menimme ilmaisen palvelun kanssa tekemään siitä täydellisen yhteyden pilveen/Internetiin.
Päästäksesi MySQL: ään sinun on mentävä osoitteeseen phpmyadmin.co ja kirjauduttava sisään freemysqlhosting -tilisi tunnistetiedoilla.
Kun olet sisällä, sinun on luotava taulukko nimeltä "TempHumid", tämän taulukon sisälle sinun on luotava 4 saraketta nimeltä "ID", "temp", "kostea" ja "hygro". Ensimmäisessä sarakkeessa (ID) on valittava ruutu A_I (automaattinen lisäys). Näin ID -sarake antaa jokaiselle tietojoukolle tunnuksen. Kaikki seuraavat sarakkeet on asetettava INT (kokonaisluku) -arvoksi ja vakioarvoksi on asetettava NULL.
Vaihe 10: Solmu-punainen
![Solmu-Punainen Solmu-Punainen](https://i.howwhatproduce.com/images/004/image-9085-17-j.webp)
![Solmu-Punainen Solmu-Punainen](https://i.howwhatproduce.com/images/004/image-9085-18-j.webp)
![Solmu-Punainen Solmu-Punainen](https://i.howwhatproduce.com/images/004/image-9085-19-j.webp)
Projektissamme käytimme solmupunaista graafisen käyttöliittymän luomiseen. Node-Red toimii Raspberry Pi -laitteella ja kerää tietoja MySQL-tietokannastamme ja näyttää nämä tiedot donitsin muotoisilla mittareilla ja graafisilla kaavioilla, jotta loppukäyttäjä voi seurata tietoja. Node-Redin älykäs asia on, että sitä voi katsella millä tahansa laitteella, mikä tarkoittaa, että sivuston kokoa muutetaan sille laitteelle, joka katselee sisältöä.
Jos haluat asentaa solmu-punaisen ohjelmointimme, katso vaihe 1 ja lataa asiakirja nimeltä "Node-Red.docx". Kopioi ja liitä teksti solmupunaiseksi oikeassa yläkulmassa olevan tuontitoiminnon avulla.
Muuta sen jälkeen MySQL DB: n DB -asetuksia.
Suositeltava:
Automaattinen sisätilojen kasvihuone Ikea Sockerin perusteella: 5 vaihetta
![Automaattinen sisätilojen kasvihuone Ikea Sockerin perusteella: 5 vaihetta Automaattinen sisätilojen kasvihuone Ikea Sockerin perusteella: 5 vaihetta](https://i.howwhatproduce.com/images/001/image-481-54-j.webp)
Automaattinen sisätilojen kasvihuone Ikea Sockerin perusteella: Hei, tämä on ensimmäinen ohjeeni. Olen oppinut paljon tästä yhteisöstä, ja mielestäni on aika palauttaa nöyrät ideani. Olen pahoillani englannista, se on huono, mutta teen kaikkeni
Mahtava kasvihuone automaattisella kastelulla, Internet -yhteydellä ja paljon muuta: 7 vaihetta (kuvilla)
![Mahtava kasvihuone automaattisella kastelulla, Internet -yhteydellä ja paljon muuta: 7 vaihetta (kuvilla) Mahtava kasvihuone automaattisella kastelulla, Internet -yhteydellä ja paljon muuta: 7 vaihetta (kuvilla)](https://i.howwhatproduce.com/images/006/image-16906-j.webp)
Mahtava kasvihuone, jossa on automaattinen kastelu, Internet -yhteys ja paljon muuta: Tervetuloa tähän ohjeeseen. Marssin alussa olin puutarhakaupassa ja näin joitain kasvihuoneita. Ja koska halusin tehdä projektin kasveilla ja elektroniikalla jo pitkään, menin eteenpäin ja ostin sellaisen: https://www.instagram.com/p
IGreenhouse - Älykäs kasvihuone: 17 vaihetta (kuvilla)
![IGreenhouse - Älykäs kasvihuone: 17 vaihetta (kuvilla) IGreenhouse - Älykäs kasvihuone: 17 vaihetta (kuvilla)](https://i.howwhatproduce.com/images/008/image-23884-j.webp)
IGreenhouse - Älykäs kasvihuone: Kotona kasvatetut hedelmät ja vihannekset ovat usein parempia kuin ostamasi, mutta joskus voit menettää näkymäsi kasvihuoneesta. Tässä projektissa teemme älykkään kasvihuoneen. Tämä kasvihuone avaa ja sulkee ikkunat ja oven automaattisesti
Älykäs kasvihuone: 12 vaihetta
![Älykäs kasvihuone: 12 vaihetta Älykäs kasvihuone: 12 vaihetta](https://i.howwhatproduce.com/images/002/image-4971-32-j.webp)
Älykäs kasvihuone: Onko sinulla koskaan ollut ongelma, että kasvihuoneessa oli liian kuuma, joten kaikki kasvit kuolivat, koska unohdit avata tuuletusaukot? Älä katso enää, älykäs kasvihuone on ratkaisu tähän ongelmaan. kuinka rakentaa sinut
TerraDome: Mini trooppinen kasvihuone Arduinolla: 18 vaihetta (kuvilla)
![TerraDome: Mini trooppinen kasvihuone Arduinolla: 18 vaihetta (kuvilla) TerraDome: Mini trooppinen kasvihuone Arduinolla: 18 vaihetta (kuvilla)](https://i.howwhatproduce.com/images/001/image-301-62-j.webp)
TerraDome: Mini -trooppinen kasvihuone Arduinolla: TerraDome on sisätilojen kasvihuone kasveille ja trooppisten kukkien muotoiselle kahdeksankulmaiselle kupolille, jota ohjaa Arduino Mega, joka säätää lämpötilaa ja valaistusta eri anturien ja LCD -näytön kautta. Siinä on myös ovet Jurassic Park -puistoon (tai