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.
IoT-For-Beginners/translations/ne/2-farm/lessons/4-migrate-your-plant-to-the.../single-board-computer-conne...

130 lines
10 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "3ac42e284a7222c0e83d2d43231a364f",
"translation_date": "2025-08-27T12:03:00+00:00",
"source_file": "2-farm/lessons/4-migrate-your-plant-to-the-cloud/single-board-computer-connect-hub.md",
"language_code": "ne"
}
-->
# आफ्नो IoT उपकरणलाई क्लाउडसँग जडान गर्नुहोस् - भर्चुअल IoT हार्डवेयर र Raspberry Pi
यस पाठको यस भागमा, तपाईं आफ्नो भर्चुअल IoT उपकरण वा Raspberry Pi लाई IoT Hubसँग जडान गर्नुहुनेछ, टेलिमेट्री पठाउन र आदेशहरू प्राप्त गर्न।
## आफ्नो उपकरणलाई IoT Hubसँग जडान गर्नुहोस्
अर्को चरण भनेको आफ्नो उपकरणलाई IoT Hubसँग जडान गर्नु हो।
### कार्य - IoT Hubसँग जडान गर्नुहोस्
1. VS Code मा `soil-moisture-sensor` फोल्डर खोल्नुहोस्। यदि तपाईं भर्चुअल IoT उपकरण प्रयोग गर्दै हुनुहुन्छ भने टर्मिनलमा भर्चुअल वातावरण चलिरहेको छ भनेर सुनिश्चित गर्नुहोस्।
1. केही अतिरिक्त Pip प्याकेजहरू स्थापना गर्नुहोस्:
```sh
pip3 install azure-iot-device
```
`azure-iot-device` तपाईंको IoT Hubसँग संवाद गर्नको लागि पुस्तकालय हो।
1. `app.py` फाइलको माथि, पहिले नै भएका आयातहरू तल निम्न आयातहरू थप्नुहोस्:
```python
from azure.iot.device import IoTHubDeviceClient, Message, MethodResponse
```
यो कोडले तपाईंको IoT Hubसँग संवाद गर्नको लागि 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 Hubसँग संवाद गर्न सक्ने उपकरण क्लाइन्ट वस्तु सिर्जना गर्न र यसलाई जडान गर्न निम्न कोड थप्नुहोस्:
```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 Hubमा टेलिमेट्री पठाउन सक्नुहुन्छ।
### कार्य - टेलिमेट्री पठाउनुहोस्
1. `while True` लूप भित्र, सुत्नुअघि निम्न कोड थप्नुहोस्:
```python
message = Message(json.dumps({ 'soil_moisture': soil_moisture }))
device_client.send_message(message)
```
यो कोडले माटोको चिस्यानको रिडिङलाई JSON स्ट्रिङको रूपमा समावेश गर्ने IoT Hub `Message` सिर्जना गर्दछ, त्यसपछि यसलाई उपकरणबाट क्लाउड सन्देशको रूपमा IoT Hubमा पठाउँछ।
## आदेशहरू ह्यान्डल गर्नुहोस्
तपाईंको उपकरणले रिले नियन्त्रण गर्न सर्वर कोडबाट आदेश ह्यान्डल गर्न आवश्यक छ। यो प्रत्यक्ष विधि अनुरोधको रूपमा पठाइन्छ।
## कार्य - प्रत्यक्ष विधि अनुरोध ह्यान्डल गर्नुहोस्
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 Hubद्वारा प्रत्यक्ष विधि बोलाउँदा कल गरिनेछ। प्रत्येक प्रत्यक्ष विधिको नाम हुन्छ, र यो कोडले रिले अन गर्न `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 Hubमा फर्काउँछ।
1. यो कार्य परिभाषाको तल निम्न कोड थप्नुहोस्:
```python
device_client.on_method_request_received = handle_method_request
```
यो कोडले IoT Hub क्लाइन्टलाई प्रत्यक्ष विधि बोलाउँदा `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 Hubसँग जडान भएको छ!
---
**अस्वीकरण**:
यो दस्तावेज़ AI अनुवाद सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।