You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
11 KiB
128 lines
11 KiB
<!--
|
|
CO_OP_TRANSLATOR_METADATA:
|
|
{
|
|
"original_hash": "3ac42e284a7222c0e83d2d43231a364f",
|
|
"translation_date": "2025-08-25T17:07:20+00:00",
|
|
"source_file": "2-farm/lessons/4-migrate-your-plant-to-the-cloud/single-board-computer-connect-hub.md",
|
|
"language_code": "hi"
|
|
}
|
|
-->
|
|
# अपने IoT डिवाइस को क्लाउड से कनेक्ट करें - वर्चुअल IoT हार्डवेयर और रास्पबेरी पाई
|
|
|
|
इस पाठ के इस भाग में, आप अपने वर्चुअल IoT डिवाइस या रास्पबेरी पाई को IoT हब से कनेक्ट करेंगे, ताकि टेलीमेट्री भेज सकें और कमांड प्राप्त कर सकें।
|
|
|
|
## अपने डिवाइस को IoT हब से कनेक्ट करें
|
|
|
|
अगला कदम है अपने डिवाइस को IoT हब से कनेक्ट करना।
|
|
|
|
### कार्य - IoT हब से कनेक्ट करें
|
|
|
|
1. VS Code में `soil-moisture-sensor` फ़ोल्डर खोलें। सुनिश्चित करें कि यदि आप वर्चुअल IoT डिवाइस का उपयोग कर रहे हैं तो टर्मिनल में वर्चुअल एनवायरनमेंट चल रहा हो।
|
|
|
|
1. कुछ अतिरिक्त Pip पैकेज इंस्टॉल करें:
|
|
|
|
```sh
|
|
pip3 install azure-iot-device
|
|
```
|
|
|
|
`azure-iot-device` एक लाइब्रेरी है जो आपके IoT हब से संवाद करने के लिए उपयोग होती है।
|
|
|
|
1. निम्नलिखित इम्पोर्ट्स को `app.py` फ़ाइल के शीर्ष पर, मौजूदा इम्पोर्ट्स के नीचे जोड़ें:
|
|
|
|
```python
|
|
from azure.iot.device import IoTHubDeviceClient, Message, MethodResponse
|
|
```
|
|
|
|
यह कोड आपके IoT हब से संवाद करने के लिए SDK को इम्पोर्ट करता है।
|
|
|
|
1. `import paho.mqtt.client as mqtt` लाइन को हटा दें क्योंकि अब इस लाइब्रेरी की आवश्यकता नहीं है। सभी MQTT कोड, जिसमें टॉपिक नाम, `mqtt_client` का उपयोग करने वाला कोड और `handle_command` शामिल हैं, हटा दें। `while True:` लूप को रखें, बस इस लूप से `mqtt_client.publish` लाइन को हटा दें।
|
|
|
|
1. इम्पोर्ट स्टेटमेंट्स के नीचे निम्नलिखित कोड जोड़ें:
|
|
|
|
```python
|
|
connection_string = "<connection string>"
|
|
```
|
|
|
|
`<connection string>` को उस कनेक्शन स्ट्रिंग से बदलें जिसे आपने इस पाठ में पहले डिवाइस के लिए प्राप्त किया था।
|
|
|
|
> 💁 यह सबसे अच्छा तरीका नहीं है। कनेक्शन स्ट्रिंग्स को कभी भी सोर्स कोड में स्टोर नहीं करना चाहिए, क्योंकि इसे सोर्स कोड कंट्रोल में चेक किया जा सकता है और कोई भी इसे देख सकता है। हम इसे यहां सरलता के लिए कर रहे हैं। आदर्श रूप से आपको कुछ ऐसा उपयोग करना चाहिए जैसे एनवायरनमेंट वेरिएबल और [`python-dotenv`](https://pypi.org/project/python-dotenv/) जैसा टूल। आप इसके बारे में आगामी पाठ में अधिक जानेंगे।
|
|
|
|
1. इस कोड के नीचे, निम्नलिखित को जोड़ें ताकि एक डिवाइस क्लाइंट ऑब्जेक्ट बनाया जा सके जो IoT हब से संवाद कर सके, और इसे कनेक्ट करें:
|
|
|
|
```python
|
|
device_client = IoTHubDeviceClient.create_from_connection_string(connection_string)
|
|
|
|
print('Connecting')
|
|
device_client.connect()
|
|
print('Connected')
|
|
```
|
|
|
|
1. इस कोड को चलाएं। आप देखेंगे कि आपका डिवाइस कनेक्ट हो गया है।
|
|
|
|
```output
|
|
pi@raspberrypi:~/soil-moisture-sensor $ python3 app.py
|
|
Connecting
|
|
Connected
|
|
Soil moisture: 379
|
|
```
|
|
|
|
## टेलीमेट्री भेजें
|
|
|
|
अब जब आपका डिवाइस कनेक्ट हो गया है, तो आप MQTT ब्रॉकर के बजाय IoT हब को टेलीमेट्री भेज सकते हैं।
|
|
|
|
### कार्य - टेलीमेट्री भेजें
|
|
|
|
1. निम्नलिखित कोड को `while True` लूप के अंदर, स्लीप से ठीक पहले जोड़ें:
|
|
|
|
```python
|
|
message = Message(json.dumps({ 'soil_moisture': soil_moisture }))
|
|
device_client.send_message(message)
|
|
```
|
|
|
|
यह कोड एक IoT हब `Message` बनाता है जिसमें मिट्टी की नमी की रीडिंग JSON स्ट्रिंग के रूप में होती है, और इसे डिवाइस से क्लाउड संदेश के रूप में IoT हब को भेजता है।
|
|
|
|
## कमांड हैंडल करें
|
|
|
|
आपके डिवाइस को सर्वर कोड से एक कमांड हैंडल करने की आवश्यकता है ताकि रिले को नियंत्रित किया जा सके। यह एक डायरेक्ट मेथड रिक्वेस्ट के रूप में भेजा जाता है।
|
|
|
|
## कार्य - डायरेक्ट मेथड रिक्वेस्ट हैंडल करें
|
|
|
|
1. `while True` लूप से पहले निम्नलिखित कोड जोड़ें:
|
|
|
|
```python
|
|
def handle_method_request(request):
|
|
print("Direct method received - ", request.name)
|
|
|
|
if request.name == "relay_on":
|
|
relay.on()
|
|
elif request.name == "relay_off":
|
|
relay.off()
|
|
```
|
|
|
|
यह एक मेथड, `handle_method_request`, को परिभाषित करता है जिसे तब कॉल किया जाएगा जब IoT हब द्वारा एक डायरेक्ट मेथड कॉल किया जाएगा। प्रत्येक डायरेक्ट मेथड का एक नाम होता है, और यह कोड एक मेथड को अपेक्षित करता है जिसे `relay_on` कहा जाता है ताकि रिले को चालू किया जा सके, और `relay_off` ताकि रिले को बंद किया जा सके।
|
|
|
|
> 💁 इसे एक ही डायरेक्ट मेथड रिक्वेस्ट में भी लागू किया जा सकता है, जिसमें रिले की इच्छित स्थिति को एक पेलोड में पास किया जा सकता है जिसे मेथड रिक्वेस्ट के साथ पास किया जा सकता है और `request` ऑब्जेक्ट से उपलब्ध कराया जा सकता है।
|
|
|
|
1. डायरेक्ट मेथड्स को एक प्रतिक्रिया की आवश्यकता होती है ताकि कॉलिंग कोड को बताया जा सके कि उन्हें हैंडल किया गया है। `handle_method_request` फंक्शन के अंत में निम्नलिखित कोड जोड़ें ताकि रिक्वेस्ट के लिए एक प्रतिक्रिया बनाई जा सके:
|
|
|
|
```python
|
|
method_response = MethodResponse.create_from_method_request(request, 200)
|
|
device_client.send_method_response(method_response)
|
|
```
|
|
|
|
यह कोड डायरेक्ट मेथड रिक्वेस्ट को HTTP स्टेटस कोड 200 के साथ प्रतिक्रिया भेजता है, और इसे IoT हब को वापस भेजता है।
|
|
|
|
1. इस फंक्शन डिफिनिशन के नीचे निम्नलिखित कोड जोड़ें:
|
|
|
|
```python
|
|
device_client.on_method_request_received = handle_method_request
|
|
```
|
|
|
|
यह कोड IoT हब क्लाइंट को बताता है कि जब एक डायरेक्ट मेथड कॉल किया जाए तो `handle_method_request` फंक्शन को कॉल करें।
|
|
|
|
> 💁 आप इस कोड को [code/pi](../../../../../2-farm/lessons/4-migrate-your-plant-to-the-cloud/code/pi) या [code/virtual-device](../../../../../2-farm/lessons/4-migrate-your-plant-to-the-cloud/code/virtual-device) फ़ोल्डर में पा सकते हैं।
|
|
|
|
😀 आपका मिट्टी की नमी सेंसर प्रोग्राम IoT हब से कनेक्ट हो गया है!
|
|
|
|
**अस्वीकरण**:
|
|
यह दस्तावेज़ AI अनुवाद सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) का उपयोग करके अनुवादित किया गया है। जबकि हम सटीकता सुनिश्चित करने का प्रयास करते हैं, कृपया ध्यान दें कि स्वचालित अनुवाद में त्रुटियां या अशुद्धियां हो सकती हैं। मूल भाषा में उपलब्ध मूल दस्तावेज़ को प्रामाणिक स्रोत माना जाना चाहिए। महत्वपूर्ण जानकारी के लिए, पेशेवर मानव अनुवाद की सिफारिश की जाती है। इस अनुवाद के उपयोग से उत्पन्न किसी भी गलतफहमी या गलत व्याख्या के लिए हम उत्तरदायी नहीं हैं। |