21 KiB
आफ्नो IoT उपकरणलाई क्लाउडसँग जडान गर्नुहोस् - Wio Terminal
यस पाठको यस भागमा, तपाईं आफ्नो Wio Terminal लाई IoT Hub सँग जडान गर्नुहुनेछ, टेलिमेट्री पठाउन र आदेशहरू प्राप्त गर्न।
आफ्नो उपकरणलाई IoT Hub सँग जडान गर्नुहोस्
अर्को चरण भनेको आफ्नो उपकरणलाई IoT Hub सँग जडान गर्नु हो।
कार्य - IoT Hub सँग जडान गर्नुहोस्
-
VS Code मा
soil-moisture-sensor
प्रोजेक्ट खोल्नुहोस्। -
platformio.ini
फाइल खोल्नुहोस्।knolleary/PubSubClient
लाइब्रेरी निर्भरता हटाउनुहोस्। यो सार्वजनिक MQTT ब्रोकरसँग जडान गर्न प्रयोग गरिएको थियो, र IoT Hub सँग जडान गर्न आवश्यक छैन। -
तलका लाइब्रेरी निर्भरता थप्नुहोस्:
seeed-studio/Seeed Arduino RTC @ 2.0.0 arduino-libraries/AzureIoTHub @ 1.6.0 azure/AzureIoTUtility @ 1.6.1 azure/AzureIoTProtocol_MQTT @ 1.6.0 azure/AzureIoTProtocol_HTTP @ 1.6.0 azure/AzureIoTSocket_WiFi @ 1.0.2
Seeed Arduino RTC
लाइब्रेरीले Wio Terminal मा वास्तविक समय घडीसँग अन्तरक्रिया गर्न कोड प्रदान गर्दछ, जुन समय ट्र्याक गर्न प्रयोग गरिन्छ। बाँकी लाइब्रेरीहरूले तपाईंको IoT उपकरणलाई IoT Hub सँग जडान गर्न अनुमति दिन्छ। -
platformio.ini
फाइलको तलमा निम्न थप्नुहोस्:build_flags = -DDONT_USE_UPLOADTOBLOB
यो कम्पाइलर फ्ल्याग सेट गर्दछ जुन Arduino IoT Hub कोड कम्पाइल गर्दा आवश्यक हुन्छ।
-
config.h
हेडर फाइल खोल्नुहोस्। सबै MQTT सेटिङहरू हटाउनुहोस् र उपकरण कनेक्शन स्ट्रिङको लागि निम्न स्थिरांक थप्नुहोस्:// IoT Hub settings const char *CONNECTION_STRING = "<connection string>";
<connection string>
लाई तपाईंले पहिले प्रतिलिपि गरेको उपकरणको कनेक्शन स्ट्रिङले प्रतिस्थापन गर्नुहोस्। -
IoT Hub सँगको जडान समय-आधारित टोकन प्रयोग गर्दछ। यसको मतलब IoT उपकरणले हालको समय थाहा पाउन आवश्यक छ। Windows, macOS वा Linux जस्ता अपरेटिङ सिस्टमहरू जस्तो, माइक्रोकन्ट्रोलरहरूले इन्टरनेटमार्फत स्वतः हालको समय समक्रमण गर्दैनन्। यसको मतलब तपाईंले NTP सर्भरबाट हालको समय प्राप्त गर्न कोड थप्न आवश्यक छ। एकपटक समय प्राप्त भएपछि, यसलाई Wio Terminal मा वास्तविक समय घडीमा भण्डारण गर्न सकिन्छ, जसले उपकरणले पावर गुमाएको छैन भने सही समय पछि अनुरोध गर्न अनुमति दिन्छ।
ntp.h
नामक नयाँ फाइल निम्न कोडसँग थप्नुहोस्:#pragma once #include "DateTime.h" #include <time.h> #include "samd/NTPClientAz.h" #include <sys/time.h> static void initTime() { WiFiUDP _udp; time_t epochTime = (time_t)-1; NTPClientAz ntpClient; ntpClient.begin(); while (true) { epochTime = ntpClient.getEpochTime("0.pool.ntp.org"); if (epochTime == (time_t)-1) { Serial.println("Fetching NTP epoch time failed! Waiting 2 seconds to retry."); delay(2000); } else { Serial.print("Fetched NTP epoch time is: "); char buff[32]; sprintf(buff, "%.f", difftime(epochTime, (time_t)0)); Serial.println(buff); break; } } ntpClient.end(); struct timeval tv; tv.tv_sec = epochTime; tv.tv_usec = 0; settimeofday(&tv, NULL); }
यस कोडको विवरण यस पाठको दायराभन्दा बाहिर छ। यसले
initTime
नामक एक फंक्शन परिभाषित गर्दछ जसले NTP सर्भरबाट हालको समय प्राप्त गर्दछ र Wio Terminal मा घडी सेट गर्न प्रयोग गर्दछ। -
main.cpp
फाइल खोल्नुहोस् र सबै MQTT कोड हटाउनुहोस्, जसमाPubSubClient.h
हेडर फाइल,PubSubClient
भेरिएबलको घोषणा,reconnectMQTTClient
रcreateMQTTClient
मेथडहरू, र यी भेरिएबलहरू र मेथडहरूमा कुनै पनि कलहरू समावेश छन्। यो फाइलमा केवल WiFi सँग जडान गर्न, माटोको चिसोपन प्राप्त गर्न र यससँग JSON डकुमेन्ट सिर्जना गर्न कोड समावेश गर्नुपर्छ। -
IoT Hub लाइब्रेरीहरू र समय सेट गर्न हेडर फाइलहरू समावेश गर्न
main.cpp
फाइलको माथि निम्न#include
निर्देशनहरू थप्नुहोस्:#include <AzureIoTHub.h> #include <AzureIoTProtocol_MQTT.h> #include <iothubtransportmqtt.h> #include "ntp.h"
-
हालको समय सेट गर्न
setup
फंक्शनको अन्त्यमा निम्न कल थप्नुहोस्:initTime();
-
फाइलको माथि, समावेश निर्देशनहरूको ठीक तल, निम्न भेरिएबल घोषणा थप्नुहोस्:
IOTHUB_DEVICE_CLIENT_LL_HANDLE _device_ll_handle;
यसले
IOTHUB_DEVICE_CLIENT_LL_HANDLE
घोषणा गर्दछ, IoT Hub सँगको जडानको लागि ह्यान्डल। -
यसको तल, निम्न कोड थप्नुहोस्:
static void connectionStatusCallback(IOTHUB_CLIENT_CONNECTION_STATUS result, IOTHUB_CLIENT_CONNECTION_STATUS_REASON reason, void *user_context) { if (result == IOTHUB_CLIENT_CONNECTION_AUTHENTICATED) { Serial.println("The device client is connected to iothub"); } else { Serial.println("The device client has been disconnected"); } }
यसले एक क्यालब्याक फंक्शन घोषणा गर्दछ जुन IoT Hub सँगको जडानको स्थिति परिवर्तन हुँदा, जस्तै जडान वा डिस्कनेक्ट हुँदा, कल गरिन्छ। स्थिति सिरियल पोर्टमा पठाइन्छ।
-
यसको तल, IoT Hub सँग जडान गर्न फंक्शन थप्नुहोस्:
void connectIoTHub() { IoTHub_Init(); _device_ll_handle = IoTHubDeviceClient_LL_CreateFromConnectionString(CONNECTION_STRING, MQTT_Protocol); if (_device_ll_handle == NULL) { Serial.println("Failure creating Iothub device. Hint: Check your connection string."); return; } IoTHubDeviceClient_LL_SetConnectionStatusCallback(_device_ll_handle, connectionStatusCallback, NULL); }
यो कोडले IoT Hub लाइब्रेरी कोडलाई इनिसियलाइज गर्दछ, त्यसपछि
config.h
हेडर फाइलमा कनेक्शन स्ट्रिङ प्रयोग गरेर जडान सिर्जना गर्दछ। यो जडान MQTT मा आधारित छ। यदि जडान असफल हुन्छ भने, यो सिरियल पोर्टमा पठाइन्छ - यदि तपाईंले यो आउटपुटमा देख्नुभयो भने, कनेक्शन स्ट्रिङ जाँच गर्नुहोस्। अन्ततः कनेक्शन स्थिति क्यालब्याक सेटअप गरिन्छ। -
setup
फंक्शनमाinitTime
कलको तल यो फंक्शन कल गर्नुहोस्:connectIoTHub();
-
MQTT क्लाइन्टको जस्तै, यो कोड एकल थ्रेडमा चल्छ त्यसैले हबले पठाएको सन्देशहरू र हबमा पठाइएका सन्देशहरू प्रशोधन गर्न समय चाहिन्छ।
loop
फंक्शनको माथि निम्न थप्नुहोस्:IoTHubDeviceClient_LL_DoWork(_device_ll_handle);
-
यो कोड निर्माण र अपलोड गर्नुहोस्। तपाईं सिरियल मोनिटरमा जडान देख्नुहुनेछ:
Connecting to WiFi.. Connected! Fetched NTP epoch time is: 1619983687 Sending telemetry {"soil_moisture":391} The device client is connected to iothub
आउटपुटमा तपाईंले NTP समय प्राप्त भइरहेको देख्न सक्नुहुन्छ, त्यसपछि उपकरण क्लाइन्ट जडान भइरहेको देख्न सक्नुहुन्छ। जडान गर्न केही सेकेन्ड लाग्न सक्छ, त्यसैले उपकरण जडान भइरहेको बेला तपाईंले आउटपुटमा माटोको चिसोपन देख्न सक्नुहुन्छ।
💁 तपाईं NTP को UNIX समयलाई unixtimestamp.com जस्ता वेबसाइट प्रयोग गरेर पढ्न मिल्ने संस्करणमा रूपान्तरण गर्न सक्नुहुन्छ।
टेलिमेट्री पठाउनुहोस्
अब तपाईंको उपकरण जडान भएको छ, तपाईं MQTT ब्रोकरको सट्टा IoT Hub मा टेलिमेट्री पठाउन सक्नुहुन्छ।
कार्य - टेलिमेट्री पठाउनुहोस्
-
setup
फंक्शनको माथि निम्न फंक्शन थप्नुहोस्:void sendTelemetry(const char *telemetry) { IOTHUB_MESSAGE_HANDLE message_handle = IoTHubMessage_CreateFromString(telemetry); IoTHubDeviceClient_LL_SendEventAsync(_device_ll_handle, message_handle, NULL, NULL); IoTHubMessage_Destroy(message_handle); }
यो कोडले पास गरिएको स्ट्रिङबाट IoT Hub सन्देश सिर्जना गर्दछ, यसलाई हबमा पठाउँछ, त्यसपछि सन्देश वस्तु सफा गर्दछ।
-
सिरियल पोर्टमा टेलिमेट्री पठाउने लाइनको ठीक पछि
loop
फंक्शनमा यो कोड कल गर्नुहोस्:sendTelemetry(telemetry.c_str());
आदेशहरू ह्यान्डल गर्नुहोस्
तपाईंको उपकरणले रिले नियन्त्रण गर्न सर्वर कोडबाट आदेश ह्यान्डल गर्न आवश्यक छ। यो प्रत्यक्ष विधि अनुरोधको रूपमा पठाइन्छ।
कार्य - प्रत्यक्ष विधि अनुरोध ह्यान्डल गर्नुहोस्
-
connectIoTHub
फंक्शनको अघि निम्न कोड थप्नुहोस्:int directMethodCallback(const char *method_name, const unsigned char *payload, size_t size, unsigned char **response, size_t *response_size, void *userContextCallback) { Serial.printf("Direct method received %s\r\n", method_name); if (strcmp(method_name, "relay_on") == 0) { digitalWrite(PIN_WIRE_SCL, HIGH); } else if (strcmp(method_name, "relay_off") == 0) { digitalWrite(PIN_WIRE_SCL, LOW); } }
यो कोडले क्यालब्याक मेथड परिभाषित गर्दछ जुन IoT Hub लाइब्रेरीले प्रत्यक्ष विधि अनुरोध प्राप्त गर्दा कल गर्न सक्छ। अनुरोध गरिएको विधि
method_name
प्यारामिटरमा पठाइन्छ। यो फंक्शनले सिरियल पोर्टमा कल गरिएको विधि प्रिन्ट गर्दछ, त्यसपछि विधि नामको आधारमा रिले अन वा अफ गर्दछ।💁 यो एकल प्रत्यक्ष विधि अनुरोधमा पनि कार्यान्वयन गर्न सकिन्छ, रिलेको इच्छित अवस्था अनुरोधको साथ पास गर्न सकिने पेलोडमा पास गर्दै, जुन
payload
प्यारामिटरबाट उपलब्ध हुन्छ। -
directMethodCallback
फंक्शनको अन्त्यमा निम्न कोड थप्नुहोस्:char resultBuff[16]; sprintf(resultBuff, "{\"Result\":\"\"}"); *response_size = strlen(resultBuff); *response = (unsigned char *)malloc(*response_size); memcpy(*response, resultBuff, *response_size); return IOTHUB_CLIENT_OK;
प्रत्यक्ष विधि अनुरोधहरूलाई प्रतिक्रिया आवश्यक छ, र प्रतिक्रिया दुई भागमा हुन्छ - पाठको रूपमा प्रतिक्रिया, र रिटर्न कोड। यो कोडले निम्न JSON डकुमेन्टको रूपमा परिणाम सिर्जना गर्दछ:
{ "Result": "" }
यो त्यसपछि
response
प्यारामिटरमा प्रतिलिपि गरिन्छ, र यो प्रतिक्रियाको आकारresponse_size
प्यारामिटरमा सेट गरिन्छ। यो कोडले विधि सही रूपमा ह्यान्डल गरिएको देखाउनIOTHUB_CLIENT_OK
फर्काउँछ। -
क्यालब्याकलाई जडान गर्न
connectIoTHub
फंक्शनको अन्त्यमा निम्न थप्नुहोस्:IoTHubClient_LL_SetDeviceMethodCallback(_device_ll_handle, directMethodCallback, NULL);
-
loop
फंक्शनले IoT Hub द्वारा पठाइएका घटनाहरू प्रशोधन गर्नIoTHubDeviceClient_LL_DoWork
फंक्शन कल गर्नेछ। यो केवलdelay
को कारणले प्रत्येक 10 सेकेन्डमा कल गरिन्छ, जसको मतलब प्रत्यक्ष विधिहरू केवल प्रत्येक 10 सेकेन्डमा प्रशोधित हुन्छन्। यसलाई अझ कुशल बनाउन, 10 सेकेन्डको ढिलाइलाई धेरै छोटो ढिलाइको रूपमा कार्यान्वयन गर्न सकिन्छ, प्रत्येक पटकIoTHubDeviceClient_LL_DoWork
कल गर्दै। यसलाई गर्नloop
फंक्शनको माथि निम्न कोड थप्नुहोस्:void work_delay(int delay_time) { int current = 0; do { IoTHubDeviceClient_LL_DoWork(_device_ll_handle); delay(100); current += 100; } while (current < delay_time); }
यो कोडले बारम्बार लूप गर्नेछ,
IoTHubDeviceClient_LL_DoWork
कल गर्नेछ र प्रत्येक पटक 100ms को लागि ढिलाइ गर्नेछ। योdelay_time
प्यारामिटरमा दिइएको समयको लागि ढिलाइ गर्न आवश्यक जति पटक यो गर्नेछ। यसको मतलब उपकरणले प्रत्यक्ष विधि अनुरोध प्रशोधन गर्न 100ms भन्दा बढी कुर्नु पर्दैन। -
loop
फंक्शनमा,IoTHubDeviceClient_LL_DoWork
कल हटाउनुहोस्, रdelay(10000)
कललाई निम्नसँग प्रतिस्थापन गर्नुहोस्:work_delay(10000);
💁 तपाईं यो कोड code/wio-terminal फोल्डरमा फेला पार्न सक्नुहुन्छ।
😀 तपाईंको माटोको चिसोपन सेन्सर प्रोग्राम IoT Hub सँग जडान भएको छ!
अस्वीकरण:
यो दस्तावेज़ AI अनुवाद सेवा Co-op Translator प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।