Sien IoTea LoRa -oplossing (met Azure, opdatering 1812): 5 stappe
Sien IoTea LoRa -oplossing (met Azure, opdatering 1812): 5 stappe
Anonim
Sien IoTea LoRa -oplossing (met Azure, opdatering 1812)
Sien IoTea LoRa -oplossing (met Azure, opdatering 1812)

Microsoft Azure is 'n wolkdiens wat meer kragtige en stabiele rekenaarkrag bied. Hierdie keer het ons probeer om ons IoTea -data daarheen te stuur.

Stap 1: Dinge wat in hierdie projek gebruik word

Hardeware komponente

  • Grove - Koolstofdioksied sensor (MH -Z16)
  • Grove - Digitale ligsensor
  • Grove - Stofsensor (PPD42NS)
  • Grove-Suurstofsensor (ME2-O2-Ф20)
  • Grondvog- en temperatuursensor
  • LoRa LoRaWAN Gateway - 868MHz -stel met Framboos Pi 3
  • Grove - Temp & Humi & Barometersensor (BME280)

Sagteware -programme en aanlyndienste

  • Microsoft Visual Studio 2015
  • Microsoft Azure

Stap 2: Verhaal

Op die Mengdingberg noordoos van Ya'an, Sichuan, loop die bergrug wes na oos in 'n see van groen. Dit is 'n bekendste gesig vir die 36-jarige Deng, een van die min Mengding-teemakers van sy generasie, met 'n plantasie van 50 mu (= 3,3 hektaar) op 1100 m bo seespieël. Deng kom uit 'n familie teemakers, maar dit is nie 'n maklike taak om die erfenis van die familie voort te sit nie. 'Ons tee word grootliks in 'n organiese omgewing verbou om die uitstekende kwaliteit daarvan te verseker. Maar terselfdertyd is die groeidigtheid laag, die koste hoog en die bot oneweredig, wat die tee moeilik maak om te oes. Daarom is hoë-bergtee gewoonlik klein oeste en hul waardes word nie op die mark weerspieël nie.”Deng probeer die afgelope twee jaar die verbruikers se bewustheid van hoë-bergtee probeer verhoog om hul waarde te bevorder. En toe hy Fan ontmoet, wat op soek was na 'n plantasie om Seeed se IoTea -tegnologie te implementeer, was die perfekte oplossing vir 'n oplossing.

Stap 3: Hardewareverbinding

Volg die vorige tutoriaal om u hardeware aan te sluit.

Stap 4: Cloud Configure

Stap 1. Skep hulpbrongroep

Klik hier om aan te meld by Microsoft Azure. Voer dan hulpbrongroepe in die lys aan die linkerkant van die paneelbord in, klik op Voeg by om 'n hulpbrongroep by te voeg.

Beeld
Beeld

'N Hulpbrongroep word gebruik om alle hulpbronne in die projek te bestuur, nadat hulpbrongroepe gebruik is, verwyder die hulpbrongroep om alle hulpbronne uit te vee om heffings te vermy. Vul die naam van die hulpbrongroep in die geopende bladsy (soos iotea), kies inskrywing en die ligging van die hulpbrongroep indien nodig, klik op Skep om 'n hulpbrongroep te skep.

Stap 2. Skep Iot Hub

Nou kan u 'n wolkbron skep, klik op Skep 'n resous aan die linkerkant, kies Internet of Things - Iot Hub, dit maak 'n nuwe bladsy oop.

Kies op die oortjie Basies die hulpbrongroep wat u pas geskep het, en vul Iot Hub -naam (soos iotea), kies indien nodig inskrywing en streek, en draai dan na die oortjie Grootte en skaal.

Beeld
Beeld

Kies in die oortjie Grootte en skaal F1: Gratis vlak of B1: Basiese vlak in pryse en kombinasie van skaalvlak, basiese vlak neem 10,00 dollar per maand. Gaan laastens na die blad Review + create, kyk na u invoer en klik op Create om 'n Iot Hub te skep.

Beeld
Beeld

Stap 3. Stel LORIOT op

Voer die Iot Hub in wat u pas geskep het, klik op beleid vir gedeelde toegang - toestel, kopieer die primêre sleutel aan die regterkant.

Beeld
Beeld

Maak 'n nuwe blaaiervenster (of oortjie) oop, meld by u LORIOT -bedieningspaneel aan, draai na Toepassing - SampleApp, klik op Data -uitvoer in die beheergroep - Verander. Kies Azure Iot Hub in die uitvoertipe -groep verander, vul u Iot Hub -naam en primêre sleutel in en klik op die knoppie Bevestig verandering onderaan.

Beeld
Beeld

Stap 4. Voeg Iot -toestel by

Klik op Toestelle in die lys aan die linkerkant in LORIOT, kopieer u toestel EUI.

Beeld
Beeld

Terug na Azure Iot Hub, klik op Iot -toestelle in die lys aan die linkerkant van Iot Hub. Klik op Voeg by, vul toestel EUI in toestel -ID op die geopende bladsy.

BELANGRIK: Vee alle SEPRATOR IN DEVICE EUI uit, laat dit lyk soos 1122334455667788.

Beeld
Beeld

Klik op Stoor, alles klaar.

Stap 5. Ontvang D2C (Device to Cloud) -boodskappe

U kan Microsoft Docs volg om D2C -boodskappe te lees.

Stap 5: sagteware programmering

Sagteware -programmering is in drie dele verdeel: Node, Gateway en webwerf, volg die vorige handleiding om Node Part en Gateway Part te programmeer. Stap 1 tot en met 8 van die webwerf -gedeelte is ook dieselfde as vorige tutoriaal.

As u reeds Microsoft Azure opgestel het, maak 'n terminale oop, voer die wortelmap van u webwerf in, aktiveer virtuele omgewing:

cd ~/iotea-hb

bronbak/aktiveer

installeer Azure Event Hub -module via pip en skep 'n new.py -lêer (soos iothub_recv.py):

pip installeer azure-eventhub

raak iothub_recv.py aan

en skryf dan die kodes neer:

# --------------------------------------------------------------------------------------------

# Kopiereg (c) Microsoft Corporation. Alle regte voorbehou. # Gelisensieer onder die MIT -lisensie. Sien License.txt in die projekwortel vir lisensie -inligting. # ------------------------------------------------- ------------------------------------------- van azuurblou invoer eventhub van azuurblou. eventhub import EventData, EventHubClient, Offset import logging logger = logging.getLogger ('azure.eventhub') import db, json, time, datetime def get_time (): cntime = datetime.datetime.now () + datetime.timedelta (hours = +8) datum = cntime.strftime ('%Y-{}-{}'). Formaat (cntime.strftime ('%m'). Zfill (2), cntime.strftime ('%d'). Zfill (2)) uur = cntime.strftime ('%H'). Zfill (2) minute = cntime.strftime ('%M'). Zfill (2) tweede = cntime.strftime ('%S'). Zfill (2) terugkeer [datum, uur, minuut, tweede] def get_iothub_data (): list = ['0'] * 11 kliënt = EventHubClient.from_iothub_connection_string ('', debug = True) ontvanger = client.add_receiver ("$ default", " 3 ", operation = '/messages/events', offset = Offset (datetime.datetime.utcnow ())) try: client.run () eh_info = client.get_eventhub_info () print (eh_info) received = receiver.receive (time -out = 5) druk (ontvang) vir item in ontvangs: me ssage = json.loads (str (item.message)) print (boodskap) as 'data' in boodskap: data = boodskap ['data'] air_temp = str (int (data [0: 2], 16)) air_hum = str (int (data [2: 4], 16)) druk = str (int ((data [4: 8]), 16)) co2 = str (int (data [8:12], 16)) stof = str (int (data [12:16], 16)) beligting = str (int (data [16:20], 16)) o2 = str (rond (int (data [20:22], 16) / 10, 1)) grond_temp = str (int (data [22:24], 16)) grond_hum = str (int (data [24:26], 16)) spanning = str (rond (int (data [26:28], 16) / int ('ff', 16) * 5, 1)) error = str (int (data [28:], 16)) list = [air_temp, air_hum, druk, co2, stof, beligting, o2, grond_temp, grond_hum, spanning, fout] uiteindelik: client.stop () teruglys terwyl True: list = get_time () + get_iothub_data () db.insert (list) print (list)

Verander u verbindingsreeks voordat u die program begin

client = EventHubClient.from_iothub_connection_string ('', debug = True)

U kan u verbindingsreeks kry deur op Gedeelde toegangsbeleide te klik - eienaar van die internet in Iot Hub, die verbindingstring -primêre sleutel in die geopende bladsy is die verbindingsreeks.

Beeld
Beeld

Daarna kan u die program begin:

gunicorn iothub_recv: app